MFC編 目次

 MFC全般

 

・MFCの開発環境をそろえよう
・MFCをスタティックリンクしたときに出るエラー
・関数追加時に出るエラー
・Windows XPスタイルの外観にする

 文字列操作

 

・CStringの基本1 文字列の連結と追加
・ATL/MFC共有版のCStringについて
・CStringと三項演算子の問題

 DDX/DDV

 

・DDXの基本1
・DDXの基本2
・DDX変数に複数コントロールを割り当てる
・DDX変数を配列にする

 ダイアログ

 

・ダイアログの色変更

 ボタン

 

・ボタンの基本

 チェックボックス

 

・チェックボックスの基本
・プッシュボタンのようなチェックボックス
・チェックボックスの色変更

 エディットボックス

 

・エディットボックスの基本
・エディットボックスの色変更

 コンボボックス

 

・コンボボックスの基本
・コンボボックスに初期データを入れる
・コンボボックスの色変更
・拡張コンボボックス

 リストボックス

 

・リストボックスの基本
・リストボックスの色変更
・チェックリストボックスを作る

 ラジオボタン

 

・ラジオボタンの基本
・ラジオボタンの色変更

 スタティックテキスト

 

・スタティックテキストの内容を動的に変更する
・スタティックテキストに複数行入力する
・スタティックテキストの文字色変更

 リストコントロール

 

・リストコントロールの基本1
・リストコントロールの基本2
・リストコントロールの一行全体を選択する
・リストコントロールを単一行選択にする
・フォーカスが移ったときも選択状態を維持する
・アイテムにユーザデータを付加する
・アイテムにアイコンをつける
・アイテムに状態イメージをつける
・ヘッダ項目にアイコンをつける

 ツリーコントロール

 

・ツリーコントロールの基本

 タブコントロール

 

・タブコントロールの基本1
・タブコントロールの基本2
・タブコントロールをXPスタイルにする

 スライダコントロール

 

・スライダコントロールの基本1
・スライダコントロールの基本2

 スピンコントロール

 

・スピンコントロールの基本

 プログレスバー

 

・プログレスバーの基本

 日時指定コントロール

 

・日時指定コントロールの基本

 月間予定表コントロール

 

・月間予定表コントロールの基本
・月間予定表のプロパティと色変更

 IPアドレスコントロール

 

・IPアドレスコントロールの基本
・IPアドレスコントロールの操作

 ピクチャーコントロール

 

・ピクチャーコントロールの基本

 アニメーションコントロール

 

・アニメーションコントロールの基本

 時刻管理

 

・CTimeとCTimeSpan
・CTimeの引数について

 メニュー

 

・ダイアログにメニューをつける
・ダイアログにポップアップメニューをつける

 ステータスバー

 

・ダイアログにステータスバーをつける
・ステータスバーに文字列を表示する

 プロパティシート

 

・プロパティシートの基本1
・プロパティシートの基本2

 コモンダイアログ

 

・ファイル選択ダイアログ
・フォント選択ダイアログ
・色選択ダイアログ

 ファイル入出力

 

・ファイル入出力の基本
・テキストファイルの入出力
・ファイルの検索、列挙1
・ファイルの検索、列挙2

 ネットワーク

 

・MFCソケット通信の基本 (クライアント編)
・MFCソケット通信の基本 (サーバ編)
・MFC非同期ソケット (クライアント編1)
・MFC非同期ソケット (クライアント編2)
・MFC非同期ソケット(サーバ編1)
・MFC非同期ソケット(サーバ編2)

 デバイスコンテキスト

 

・デバイスコンテキストの基本
・文字列の描画
・ペンを使った描画
・ブラシを使った描画1
・ブラシを使った描画2

 FTPクライアント

 

・FTPクライアントを作る1
・FTPクライアントを作る2
・FTPクライアントを作る3
・FTPクライアントを作る4
・FTPクライアントを作る5

 ドキュメント・ビュー

 

・ドキュメント・ビューの基本
・エディットビューの基本
・リストビューの基本
・ツリービューの基本
・フォームビューの基本

 ダイアログバー

 

・ダイアログバーの基本
・ダイアログにダイアログバーをつける

 

 

トップページへ戻る

コンボボックスの色変更

 今回はコンボボックスの色の変更方法をやります。さっそく、前回のプロジェクトに次のように1つボタンを追加します。

 "色選択"ボタンが押されると、色選択ダイアログを表示し、コンボボックスの文字列を、指定した色で描画します。

 色情報はCOLORREF型の変数で扱います。ここではダイアログのメンバ変数に保持します。

 では、コードを実装していきましょう。まずは、コンストラクタで色情報の初期値を入れておきます。

CComboDlg::CComboDlg(CWnd* pParent /*=NULL*/)
    : CDialog(CComboDlg::IDD, pParent)
    , m_xvCombo(0)
{
    m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
    m_color = RGB(255, 0, 0);
}

 コントロールが描画されるときは、親ウィンドウにWM_CTLCOLORメッセージが送られます。このメッセージが送られたときに、コンボボックスの色を変更します。

 コンボボックスは、エディットボックスとリストボックスの組み合わせでできています。コンボボックス自体の色変更をするのではなく、これらの部品に色変更処理を追加します。

 ダイアログクラスのプロパティからメッセージアイコンをクリックし、WM_CTLCOLORを選択し、CWnd::OnCtlColor()関数をオーバーライドします。

 OnCtlColor()関数では、次のようにコンボボックスの色変更処理を追加します。

HBRUSH CComboDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
    HBRUSH          hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    HWND            hwnd = NULL;
    COMBOBOXINFO    comboInfo;    
    bool            bChangeColor = false;
    int             err = 0;
    
    hwnd = pWnd->GetSafeHwnd();
    
    comboInfo.cbSize = sizeof COMBOBOXINFO;
    if (!m_xcCombo.GetComboBoxInfo(&comboInfo)) err = 1;
    
    // コンボボックスの色変更
    if (!err)
    {
        // エディット
        if (nCtlColor == CTLCOLOR_EDIT)
        {
            // 標準、ドロップダウンはhwndItem
            // ドロップダウンリストはhwndCombo
            if (hwnd == comboInfo.hwndItem || 
                hwnd == comboInfo.hwndCombo)
            {
                bChangeColor = true;
            }
        }
        // リスト
        if (nCtlColor == CTLCOLOR_LISTBOX)
        {
            if (hwnd == comboInfo.hwndList) bChangeColor = true;
        }
        // 色変更
        if (bChangeColor)
        {
            // 文字色
            pDC->SetTextColor(m_color);
            // 背景色
            hbr = static_cast<HBRUSH>(GetStockObject(BLACK_BRUSH));
            pDC->SetBkColor(RGB(0, 0, 0));
        }
    }
    return hbr;
}

 OnCtlColor()関数の第2引数は、描画されようとしているコントロールのポインタ、第3引数はコントロールの種類が渡されます。コンボボックスの場合は、エディットボックス、リストボックスがコンボボックスの子ウィンドウになっているので、まずそれらのウィンドウハンドルを取得しておきます。

 ウィンドウハンドルを取得するには、CComboBox::GetComboBoxInfo()関数を使います。この関数を使う場合は、関数を呼ぶ前にcbSizeメンバに構造体のサイズをセットしておきます。

BOOL CComboBox::GetComboBoxInfo(PCOMBOBOXINFO pcbi) const;
説明: CComboBoxオブジェクトの情報を取得
引数: pcbi:PCOMBOBOXINFO構造体のポインタ
戻り値: 正常終了した場合はTRUE。それ以外の場合はFALSE

 OnCtlColor()の引数で渡されたウィンドウが、コンボボックスが持つエディットボックス、リストボックスのウィンドウと一致するかを調べ、一致する場合に色変更をします。

 エディットボックス部分は、コンボボックスのスタイルが"標準"、"ドロップダウン"の場合はhwndItemメンバ、"ドロップダウンリスト"の場合はhwndComboメンバと比較します。

 文字色の変更は、CDC::SetTextColor()関数を使います。

 背景色の変更は、hbrに設定したい色のブラシをセットし、さらにCDC::SetBkColor()関数を実行します。ここではストックオブジェクトを使っていますが、独自の色を設定したい場合は、独自のブラシを作成します。

 もしhbrにブラシをセットしないと、次のようになってしまいます。文字領域以外の背景部分が白いままになってしまいます。

 次は"色選択"ボタンが押されたときのイベントハンドラです。

// "色選択"ボタン押下
void CComboDlg::OnBnClickedColorsel()
{
    CColorDialog    CColorDialog(m_color);
    int             err = 0;

    // 色選択ダイアログ表示
    if (CColorDialog.DoModal() == IDOK)
    {
        // 選択された色を取得
        m_color = CColorDialog.GetColor();
        // 表示更新
        Invalidate();
    }
    return;
}

 色選択のダイアログは、CColorDialogクラスを使います。コンストラクタにCOLORREF型の変数を渡すと、初期状態でその色が選択された状態になります。

 選択された色を取得するには、CColorDialog::GetColor()関数を使います。選択された色でコンボボックスを更新するために、CWnd::Invalidate()関数を1度呼び出します。こうするとWM_CTLCOLORメッセージが発行されます。

 では、ビルドして実行してみましょう。色選択ダイアログで任意の色を選択すると、コンボボックスの文字色が変わります。