ホーム ATL/WTL
シンプルツールバー
ドキュメント種別 ATL/WTL に関する文書
最終更新日 2007/09/24
PR
 今回は、フレームウィンドウにツールバーを追加します。 CFrameWindowImplクラステンプレートには簡単なツールバーを作成するために CreateSimpleToolBar()というメンバ関数が用意されています。


プロジェクトファイル ダウンロード
// stdafx.h
#pragma once

#include <atlbase.h>
#include <atlapp.h>
extern CAppModule _Module;
#include <atlwin.h>

#include <atlcrack.h>
#include <atlmisc.h>
#include <atlframe.h>
			

// MainWindow.h
#pragma once

class CMainWindow : public CFrameWindowImpl<CMainWindow>,
    public CMessageFilter, public CIdleHandler
{
public:
    // ウィンドウクラス名、共通リソースID、スタイル、背景色を登録
    DECLARE_FRAME_WND_CLASS_EX(_T("Hello"), IDR_MAINFRAME,
        CS_HREDRAW | CS_VREDRAW | CS_DBLCLKS, COLOR_WINDOW)

    virtual BOOL PreTranslateMessage(MSG* pMsg){
        return CFrameWindowImpl<CMainWindow>::PreTranslateMessage(pMsg);
    }

    virtual BOOL OnIdle(){
        return FALSE;
    }

    BEGIN_MSG_MAP(CMainWindow)
        MSG_WM_PAINT(OnPaint)
        MSG_WM_CREATE(OnCreate)
        MSG_WM_DESTROY(OnDestroy)
        COMMAND_ID_HANDLER_EX(ID_APP_ABOUT, OnAbout)
        COMMAND_ID_HANDLER_EX(ID_APP_EXIT, OnFileExit)
        CHAIN_MSG_MAP(CFrameWindowImpl<CMainWindow>)  // CFrameWindowImplへチェイン
    END_MSG_MAP()

    void OnPaint(CDCHandle /*dc*/){
        CPaintDC dc(m_hWnd);
        
        CRect rect;
        GetClientRect(rect);
        dc.DrawText(_T("Hello, ATL/WTL"), -1,
            rect, DT_SINGLELINE | DT_CENTER | DT_VCENTER);
    }

    int OnCreate(LPCREATESTRUCT lpCreateStruct){
        // ツールバーを作成
        CreateSimpleToolBar();

        // メッセージループにメッセージフィルタとアイドルハンドラを追加
        CMessageLoop* pLoop = _Module.GetMessageLoop();
        pLoop->AddMessageFilter(this);
        pLoop->AddIdleHandler(this);
        return 0;
    }

    void OnDestroy(){
        // メッセージループからメッセージフィルタとアイドルハンドラを削除
        CMessageLoop* pLoop = _Module.GetMessageLoop();
        pLoop->RemoveMessageFilter(this);
        pLoop->RemoveIdleHandler(this);
        SetMsgHandled(false);
    }

    void OnAbout(UINT uNotifyCode, int nID, CWindow wndCtl){
        MessageBox(_T("ATL/WTLプログラミング 第2版"));
    }

    void OnFileExit(UINT uNotifyCode, int nID, CWindow wndCtl){
        PostMessage(WM_CLOSE);
    }
};
			

// SampleProject.cpp
#include "stdafx.h"
#include "resource.h"
#include "MainWindow.h"

CAppModule _Module;

int APIENTRY _tWinMain(HINSTANCE hInstance, 
                       HINSTANCE hPrevInstance, 
                       LPTSTR    lpCmdLine, 
                       int       nCmdShow)
{
    UNREFERENCED_PARAMETER(hPrevInstance);
    UNREFERENCED_PARAMETER(lpCmdLine);

    _Module.Init(NULL, hInstance);

    CMessageLoop theLoop;
    _Module.AddMessageLoop(&theLoop);

    CMainWindow wnd;
    wnd.CreateEx();
    wnd.ShowWindow(nCmdShow);
    wnd.UpdateWindow();

    int nRet = theLoop.Run();

    _Module.RemoveMessageLoop();

    _Module.Term();

    return nRet;
}
			

 まず、プロジェクトにツールバーリソースを追加し、[ID]と[Prompt]を次のように設定します。

リソース名 ID Prompt
ツールバー IDR_MAINFRAME -
ツールバーボタン ID_APP_ABOUT バージョン情報を表示\nバージョン情報



ツールバーのIDは共通リソースIDとしてDECLARE_FRAME_WND_CLASS_EX()マクロでウィンドウに設定されます。

 次に、CMainWindowクラスのWM_CREATEメッセージハンドラで、 CreateSimpleToolBar()を呼び出してツールバーを作成します。

 次に、リソースIDがID_APP_ABOUTWM_COMMANDメッセージハンドラとして OnAbout()を追加します。このハンドラ関数ではメッセージボックスを表示します。

 これで、メインウィンドウにツールバーが追加され、ツールバー上のボタンを押すと、 OnAbout()が呼び出されるようになります。

なお、CreateSimpleToolBar()には3つの引数を渡すことができます。 第1引数にはツールバーリソースIDを指定します。デフォルト引数は 0 で、 この場合は共通リソースID(今回の例ではIDR_MAINFRAME)が使用されます。 第2引数にはツールバーのスタイルを指定します。デフォルト引数はATL_SIMPLE_TOOLBAR_STYLEで、 これはatlframe.hヘッダで次のように定義されています。

// atlframe.h
#define ATL_SIMPLE_TOOLBAR_STYLE \
    (WS_CHILD | WS_VISIBLE | WS_CLIPCHILDREN | WS_CLIPSIBLINGS | TBSTYLE_TOOLTIPS)
			

第3引数には識別子を指定します。デフォルト引数はATL_IDW_TOOLBARです。

CreateSimpleToolBar()は、内部でCreateSimpleToolBarCtrl()というメンバ関数を呼び出しており、 その呼び出しによって得られたツールバーのハンドルを、 CFrameWindowImplの基底クラスであるCFrameWindowImplBasem_hWndToolBarというHWND型のメンバ変数に代入します。 フレームウィンドウはツールバーに対する操作を、このm_hWndToolBarで識別されるハンドルに対して行います。

CFrameWindowImplBaseにはTTN_GETDISPINFOATTN_GETDISPINFOWメッセージハンドラが用意されています。 このため、ツールバーのボタン上にカーソルを乗せたときのTTN_GETDISPINFOA(W)メッセージが チェイン先のCFrameWindowImplに送られると、 自動的にツールバーボタンの[Prompt]で設定した文字列が、ツールチップとして表示されます。