// CStringToCharDlg.cpp : 実装ファイル // #include "stdafx.h" #include "CStringToChar.h" #include "CStringToCharDlg.h" #ifdef _DEBUG #define new DEBUG_NEW #endif #include // setlocale int wchartToChar ( const wchar_t* pSrc , char* pDest , const size_t iDestSize ); int charToWchart ( const char* pSrc , wchar_t* pDest , const size_t sDestSize ); int CStringToChar ( CString pSrc , char* pDest , const size_t sDestSize ); // アプリケーションのバージョン情報に使われる CAboutDlg ダイアログ class CAboutDlg : public CDialog { public: CAboutDlg(); // ダイアログ データ enum { IDD = IDD_ABOUTBOX }; protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV サポート // 実装 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialog) END_MESSAGE_MAP() // CCStringToCharDlg ダイアログ CCStringToCharDlg::CCStringToCharDlg(CWnd* pParent /*=NULL*/) : CDialog(CCStringToCharDlg::IDD, pParent) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CCStringToCharDlg::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CCStringToCharDlg, CDialog) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() //}}AFX_MSG_MAP ON_BN_CLICKED(IDOK, &CCStringToCharDlg::OnBnClickedOk) END_MESSAGE_MAP() // CCStringToCharDlg メッセージ ハンドラ BOOL CCStringToCharDlg::OnInitDialog() { CDialog::OnInitDialog(); // "バージョン情報..." メニューをシステム メニューに追加します。 // IDM_ABOUTBOX は、システム コマンドの範囲内になければなりません。 ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX); ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE); if (pSysMenu != NULL) { CString strAboutMenu; strAboutMenu.LoadString(IDS_ABOUTBOX); if (!strAboutMenu.IsEmpty()) { pSysMenu->AppendMenu(MF_SEPARATOR); pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu); } } // このダイアログのアイコンを設定します。アプリケーションのメイン ウィンドウがダイアログでない場合、 // Framework は、この設定を自動的に行います。 SetIcon(m_hIcon, TRUE); // 大きいアイコンの設定 SetIcon(m_hIcon, FALSE); // 小さいアイコンの設定 // TODO: 初期化をここに追加します。 return TRUE; // フォーカスをコントロールに設定した場合を除き、TRUE を返します。 } void CCStringToCharDlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialog::OnSysCommand(nID, lParam); } } // ダイアログに最小化ボタンを追加する場合、アイコンを描画するための // 下のコードが必要です。ドキュメント/ビュー モデルを使う MFC アプリケーションの場合、 // これは、Framework によって自動的に設定されます。 void CCStringToCharDlg::OnPaint() { if (IsIconic()) { CPaintDC dc(this); // 描画のデバイス コンテキスト SendMessage(WM_ICONERASEBKGND, reinterpret_cast(dc.GetSafeHdc()), 0); // クライアントの四角形領域内の中央 int cxIcon = GetSystemMetrics(SM_CXICON); int cyIcon = GetSystemMetrics(SM_CYICON); CRect rect; GetClientRect(&rect); int x = (rect.Width() - cxIcon + 1) / 2; int y = (rect.Height() - cyIcon + 1) / 2; // アイコンの描画 dc.DrawIcon(x, y, m_hIcon); } else { CDialog::OnPaint(); } } // ユーザーが最小化したウィンドウをドラッグしているときに表示するカーソルを取得するために、 // システムがこの関数を呼び出します。 HCURSOR CCStringToCharDlg::OnQueryDragIcon() { return static_cast(m_hIcon); } void CCStringToCharDlg::OnBnClickedOk() { // TODO: ここにコントロール通知ハンドラ コードを追加します。 // ロケール指定 setlocale( LC_ALL, "Japanese" ); CString str( "CStringメッセージ" ); // 17byte // CString -> char* int iByte = str.GetLength() * sizeof( TCHAR ); char* buf = new char[iByte+1]; CStringToChar( str, buf, iByte ); OutputDebugStringA( buf ); // char* -> CString CString str2( buf ); OutputDebugString( str2 ); free( buf ); OnOK(); } //============================================================== // [概要] // CString から char* への変換を行う // [引数] // pSrc CString 変換するCString型の文字列。 // pDest char* 変換結果のchar型文字列。 // sDestSize const size_t pDestのサイズ // [戻り値] // int 0:正常,1:異常 //============================================================== int CStringToChar( CString pSrc , char* pDest , const size_t sDestSize ) { return wchartToChar( pSrc.GetBuffer(), pDest, sDestSize ); }