子ウィンドウの作成方法
#include <windows.h>
LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
ATOM InitApp(HINSTANCE);
BOOL InitInstance(HINSTANCE, int);
TCHAR szClassName[] = TEXT("Window01");
TCHAR szClassName2[] = TEXT("Window02");
int WINAPI WinMain(HINSTANCE hCurInst, HINSTANCE hPrevInst,LPSTR lpsCmdLine, int nCmdShow){
MSG msg;
BOOL bRet;
if (!InitApp(hCurInst))
return FALSE;
if (!InitInstance(hCurInst, nCmdShow))
return FALSE;
while ((bRet = GetMessage(&msg, NULL, 0, 0)) != 0) {
if (bRet == -1) {
break;
} else {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
}
return (int)msg.wParam;
}
ATOM InitApp(HINSTANCE hInst)
{
WNDCLASSEX wc;
WNDCLASSEX wc2;
wc.cbSize = sizeof(WNDCLASSEX);
wc.style = CS_HREDRAW | CS_VREDRAW;
wc.lpfnWndProc = WndProc;
wc.cbClsExtra = 0;
wc.cbWndExtra = 0;
wc.hInstance = hInst;
wc.hIcon = (HICON)LoadImage(
NULL, MAKEINTRESOURCE(IDI_APPLICATION),
IMAGE_ICON, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
wc.hCursor = (HCURSOR)LoadImage(
NULL, MAKEINTRESOURCE(IDC_ARROW),
IMAGE_CURSOR, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
wc.hbrBackground =
(HBRUSH)GetStockObject(WHITE_BRUSH);
wc.lpszMenuName = NULL;
wc.lpszClassName = szClassName;
wc.hIconSm = (HICON)LoadImage(
NULL, MAKEINTRESOURCE(IDI_APPLICATION),
IMAGE_ICON, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
wc2.cbSize = sizeof(WNDCLASSEX);
wc2.style = CS_HREDRAW | CS_VREDRAW;
wc2.lpfnWndProc = WndProc;
wc2.cbClsExtra = 0;
wc2.cbWndExtra = 0;
wc2.hInstance = hInst;
wc2.hIcon = (HICON)LoadImage(
NULL, MAKEINTRESOURCE(IDI_APPLICATION),
IMAGE_ICON, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
wc2.hCursor = (HCURSOR)LoadImage(
NULL, MAKEINTRESOURCE(IDC_ARROW),
IMAGE_CURSOR, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
wc2.hbrBackground =
(HBRUSH)GetStockObject(BLACK_BRUSH);
wc2.lpszMenuName = NULL;
wc2.lpszClassName = szClassName;
wc2.hIconSm = (HICON)LoadImage(
NULL, MAKEINTRESOURCE(IDI_APPLICATION),
IMAGE_ICON, 0, 0,
LR_DEFAULTSIZE | LR_SHARED);
if((RegisterClassEx(&wc)||RegisterClassEx(&wc2)==0))
return 0;
return TRUE;
}
BOOL InitInstance(HINSTANCE hInst, int nCmdShow)
{
HWND hWnd;
HWND hWnd2;
hWnd = CreateWindow(szClassName,
TEXT("親ウィンドウ"),
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
NULL,
NULL,
hInst,
NULL
);
if(!hWnd) return FALSE;
hWnd2 = CreateWindow(szClassName2,
TEXT("子ウィンドウ"),
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
CW_USEDEFAULT,
hWnd,
NULL,
hInst,
NULL
);
if(!hWnd2) return FALSE;
ShowWindow(hWnd, nCmdShow);
ShowWindow(hWnd2, nCmdShow);
UpdateWindow(hWnd);
UpdateWindow(hWnd2);
return TRUE;
}
LRESULT CALLBACK WndProc(HWND hWnd, UINT msg, WPARAM wp, LPARAM lp)
{
switch (msg) {
case WM_DESTROY:
PostQuitMessage(0);
break;
default:
return (DefWindowProc(hWnd, msg, wp, lp));
}
return 0;
}
子ウィンドウの作り方を理解したく、ただウィンドウを表示するプログラムを作ろうとしました。
しかし、うまくいきません。
一体なにがダメなんでしょうか?
お礼
(そのままですが・・・) 「ダイアログの仮想関数追加でPreTranslateMessageを追加 コンボボックス」 ・・・で調べました。 貴重なキーワードを頂き、感謝しています。また、最後まで教えて下さり、ありがとうございました。 方向性が定まっていないで、とてつもなく面倒な事をするところでしたυ それとは別に、一つ ミスタイプがありました。正しくは「->m_hWnd」ですね。 自分では思いつかないのに、あげ足取りですみません。 PreTranslateMessageは他にも応用が利きそうです。質問してよかったです。 以下、参考までに・・・ 【KeywordDlg.h】 class KeywordDlg : public CDialogEx { DECLARE_DYNAMIC(KeywordDlg) public: KeywordDlg(CWnd* pParent = NULL); // 標準コンストラクター virtual ~KeywordDlg(); protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV サポート // 生成された、メッセージ割り当て関数 virtual BOOL OnInitDialog(); //追加2011.08.17 virtual BOOL PreTranslateMessage(MSG* pMsg); //追加2011.09.02 DECLARE_MESSAGE_MAP() ・・・ }; 【KeywordDlg.cpp】 // PreTranslateMessage BOOL KeywordDlg::PreTranslateMessage (MSG* pMsg) { switch (pMsg->message) { //case WM_LBUTTONDOWN: // break; case WM_LBUTTONUP://コンボボックスの▼が押された時のみ拾ってくれるみたいで、無くても良いみたいですυ //HWND m_hWnd; //if(pMsg->hwnd == GetDlgItem(IDC_COMBO_OK_BOX)->m_hWnd ){ // LastFocus = _T("OK_BOX"); // DWORD dwSel; // if ((dwSel = ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->GetEditSel()) != CB_ERR){ // dwSel_OK = dwSel; // } // //MessageBox(_T("マウスが押されました")); //} break; case WM_MOUSEMOVE://カーソルの移動そのものを拾う //コンボボックスを横切っただけでも、拾われそうですが(?)、問題なしみたいです。 if(pMsg->hwnd == GetDlgItem(IDC_COMBO_OK_BOX)->m_hWnd ){ LastFocus = _T("OK_BOX"); DWORD dwSel; if ((dwSel = ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->GetEditSel()) != CB_ERR){ dwSel_OK = dwSel; } //MessageBox(_T("カーソルが移動しました")); } break; default: break; } return CDialog::PreTranslateMessage (pMsg); } ~ 一部抜粋 ~ void KeywordDlg::OnCbnEditchangeComboOkBox() { LastFocus = _T("OK_BOX"); DWORD dwSel; if ((dwSel = ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->GetEditSel()) != CB_ERR){ dwSel_OK = dwSel; } } void KeywordDlg::OnCbnSetfocusComboOkBox() { ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->SetEditSel(-1,-1);//選択なしで、最後の文字位置にカーソルを置く } void KeywordDlg::OnCbnKillfocusComboOkBox() { LastFocus = _T("OK_BOX"); } void KeywordDlg::OnBnClickedBtnAsterisk() { InsertStrIntoKeywords(_T("*")); } void KeywordDlg::InsertStrIntoKeywords(CString str){ CString ComboStr = _T(""); DWORD dwSel; if (LastFocus == _T("OK_BOX")){ ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->GetWindowText(ComboStr); dwSel = dwSel_OK; if (dwSel != CB_ERR){ ((CComboBox*)GetDlgItem(IDC_COMBO_OK_BOX))->SetWindowText(const_cast<LPTSTR>(static_cast<LPCTSTR>(ComboStr.Left(LOWORD(dwSel)) + str + ComboStr.Right(ComboStr.GetLength()-LOWORD(dwSel))))); dwSel_OK++; //連続して文字を挿入する場合を考慮 } }else if (LastFocus == _T("NG_BOX")){ ((CComboBox*)GetDlgItem(IDC_COMBO_NG_BOX))->GetWindowText(ComboStr); dwSel = dwSel_NG; if (dwSel != CB_ERR){ ((CComboBox*)GetDlgItem(IDC_COMBO_NG_BOX))->SetWindowText(const_cast<LPTSTR>(static_cast<LPCTSTR>(ComboStr.Left(LOWORD(dwSel)) + str + ComboStr.Right(ComboStr.GetLength()-LOWORD(dwSel))))); dwSel_NG++; //連続して文字を挿入する場合を考慮 } }else{ dwSel = CB_ERR; return; } } (変数の追加で、カテゴリを「Control」すればいいと思うのですが、万が一今までの記述で 不具合があるといけないので、今回は DDX_Control で設定した物は使わず、直で指定しています。) ◆Win32 メッセージ一覧 http://wisdom.sakura.ne.jp/system/winapi/windata1.html たった、一文字を挿入したいだけなのに~ぃ と思いましたが、出来て良かったです! 本当にありがとうございましたm(_ _)m しばらくして、締め切ります。