CStaticテキストコントロールのテキスト色をどのように変更しますか? CDC :: SetTextColorを使用する他の簡単な方法はありますか?
ありがとう...
新しいCStatic派生クラスを作成せずに、ダイアログクラスにON_WM_CTLCOLOR
を実装できます。
BEGIN_MESSAGE_MAP(CMyDialog, CDialog)
//{{AFX_MSG_MAP(CMyDialog)
ON_WM_CTLCOLOR()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
HBRUSH CMyDialog::OnCtlColor(CDC* pDC, CWnd *pWnd, UINT nCtlColor)
{
switch (nCtlColor)
{
case CTLCOLOR_STATIC:
pDC->SetTextColor(RGB(255, 0, 0));
return (HBRUSH)GetStockObject(NULL_BRUSH);
default:
return CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
}
}
上記のコードは、ダイアログ内のすべての静的コントロールのテキストを設定することに注意してください。ただし、pWnd
変数を使用して、必要なコントロールをフィルタリングできます。
残念ながら、CStaticクラスにSetTextColorメソッドはありません。 CStaticのテキストの色を変更したい場合は、もう少しコーディングする必要があります。
私の意見では、最良の方法は、独自のCStatic派生クラス(CMyStatic)を作成することであり、そこにはON_WM_CTLCOLOR_REFLECT通知メッセージが含まれます。
BEGIN_MESSAGE_MAP(CMyStatic, CStatic)
//{{AFX_MSG_MAP(CMyStatic)
ON_WM_CTLCOLOR_REFLECT()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
HBRUSH CColorStatic::CtlColor(CDC* pDC, UINT nCtlColor)
{
pDC->SetTextColor(RGB(255,0,0));
return (HBRUSH)GetStockObject(NULL_BRUSH);
}
明らかに、メンバー変数とセッターメソッドを使用して、赤色(RGB(255,0,0))を置き換えることができます。
よろしく。
* return(HBRUSH)GetStockObject(NULL_BRUSH); *によって引き起こされたペイントの問題(透明な背景)のフォローアップ。
以下のように簡単に変更:
HBRUSH hBrush = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTLCOLOR_STATIC &&
pWnd->GetSafeHwnd() == GetDlgItem(XXX)->GetSafeHwnd()
) pDC->SetTextColor(RGB(255, 0, 0));
return hBrush;
お役に立てれば。
ここで与えられた回答や他の場所から、色付け自体を処理するCStaticの代わりに使用される派生クラスを作成する方法は明らかではありませんでした。
以下は、MSVS 2013バージョン12.0.40629.00 Update 5を使用した場合の動作です。リソースエディターに「静的テキスト」コントロールを配置し、メンバー変数の型をTColorTextに置き換えることができます。
.hファイルで:
class TColorText : public CStatic
{
protected:
DECLARE_MESSAGE_MAP( )
public:
// make the background transparent (or if ATransparent == true, restore the previous background color)
void setTransparent( bool ATransparent = true );
// set background color and make the background opaque
void SetBackgroundColor( COLORREF );
void SetTextColor( COLORREF );
protected:
HBRUSH CtlColor( CDC* pDC, UINT nCtlColor );
private:
bool MTransparent = true;
COLORREF MBackgroundColor = RGB( 255, 255, 255 ); // default is white (in case someone sets opaque without setting a color)
COLORREF MTextColor = RGB( 0, 0, 0 ); // default is black. it would be more clean
// to not use the color before set with SetTextColor(..), but whatever...
};
.cppファイル:
void TColorText::setTransparent( bool ATransparent )
{
MTransparent = ATransparent;
Invalidate( );
}
void TColorText::SetBackgroundColor( COLORREF AColor )
{
MBackgroundColor = AColor;
MTransparent = false;
Invalidate( );
}
void TColorText::SetTextColor( COLORREF AColor )
{
MTextColor = AColor;
Invalidate( );
}
BEGIN_MESSAGE_MAP( TColorText, CStatic )
ON_WM_CTLCOLOR_REFLECT( )
END_MESSAGE_MAP( )
HBRUSH TColorText::CtlColor( CDC* pDC, UINT nCtlColor )
{
pDC->SetTextColor( MTextColor );
pDC->SetBkMode( TRANSPARENT ); // we do not want to draw background when drawing text.
// background color comes from drawing the control background.
if( MTransparent )
return nullptr; // return nullptr to indicate that the parent object
// should supply the brush. it has the appropriate background color.
else
return (HBRUSH) CreateSolidBrush( MBackgroundColor ); // color for the empty area of the control
}
非常に役立ちます。
https://msdn.Microsoft.com/de-de/library/0wwk06hc.aspx
同様に
HBRUSH hBrush = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
if (nCtlColor == CTLCOLOR_STATIC &&
pWnd->GetSafeHwnd() == GetDlgItem(XXX)->GetSafeHwnd()
) pDC->SetTextColor(RGB(255, 0, 0));
return hBrush;