自定义按钮(1)

#ifndef __COLORBTN_H__
#define __COLORBTN_H__

/////////////////////////////////////////////////////////////////////////////

class CColorButton : public CButton
{
DECLARE_DYNAMIC(CColorButton)
public:
    CColorButton();
    virtual ~CColorButton();

    BOOL Attach(const UINT nID, CWnd* pParent,
        const COLORREF BGColor = RGB(192, 192, 192),        // gray button
        const COLORREF FGColor = RGB(1, 1, 1),                // black text
        const COLORREF DisabledColor = RGB(128, 128, 128),    // dark gray disabled text
        const UINT nBevel = 2
    );

   
protected:
    virtual void DrawItem(LPDRAWITEMSTRUCT lpDIS);
    void DrawFrame(CDC *DC, CRect R, int Inset);
    void DrawFilledRect(CDC *DC, CRect R, COLORREF color);
    void DrawLine(CDC *DC, CRect EndPoints, COLORREF color);
    void DrawLine(CDC *DC, long left, long top, long right, long bottom, COLORREF color);
    void DrawButtonText(CDC *DC, CRect R, const char *Buf, COLORREF TextColor);

    COLORREF GetFGColor() { return m_fg; }   
    COLORREF GetBGColor() { return m_bg; }
    COLORREF GetDisabledColor() { return m_disabled; }
    UINT GetBevel() { return m_bevel; }

private:
    COLORREF m_fg, m_bg, m_disabled;
    UINT m_bevel;

};
#endif





#include "stdafx.h"
#include "colorbtn.h"
 
#ifdef _DEBUG
#undef THIS_FILE
static char BASED_CODE THIS_FILE[] = __FILE__;
#endif

// no automatic class substitution for this file!
#ifdef CColorButton
#undef CColorButton      CColorButton
#endif

// CColorButton
IMPLEMENT_DYNAMIC(CColorButton, CButton)

CColorButton::CColorButton()

#if (_MFC_VER < 0x0250)
  hwndOwner = NULL;  // initialize hwndOwner for GetOwner() and SetOwner() support in MFC < 2.5
#endif
}



CColorButton::~CColorButton()
{
}



BOOL CColorButton::Attach(const UINT nID, CWnd* pParent, const COLORREF BGColor, const COLORREF FGColor, const COLORREF DisabledColor, const UINT nBevel)
{
    if (!SubclassDlgItem(nID, pParent))
        return FALSE;

    m_fg = FGColor;
    m_bg = BGColor;
    m_disabled = DisabledColor;
    m_bevel = nBevel;

    return TRUE;
}


void CColorButton::DrawItem(LPDRAWITEMSTRUCT lpDIS)
{
    CDC* pDC = CDC::FromHandle(lpDIS->hDC);

    UINT state = lpDIS->itemState;
    CRect focusRect, btnRect;
    focusRect.CopyRect(&lpDIS->rcItem);
    btnRect.CopyRect(&lpDIS->rcItem);

    //
    // Set the focus rectangle to just past the border decoration
    //
    focusRect.left += 4;
    focusRect.right -= 4;
    focusRect.top += 4;
    focusRect.bottom -= 4;
     
    //
    // Retrieve the button's caption
    //
    const int bufSize = 512;
    TCHAR buffer[bufSize];
    GetWindowText(buffer, bufSize);
   

    //
    // Draw and label the button using draw methods
   
    DrawFilledRect(pDC, btnRect, GetBGColor());
    DrawFrame(pDC, btnRect, GetBevel());
      DrawButtonText(pDC, btnRect, buffer, GetFGColor());


    //
    // Now, depending upon the state, redraw the button (down image) if it is selected,
    // place a focus rectangle on it, or redisplay the caption if it is disabled
    //
    if (state & ODS_FOCUS) {
        DrawFocusRect(lpDIS->hDC, (LPRECT)&focusRect);
        if (state & ODS_SELECTED){
            DrawFilledRect(pDC, btnRect, GetBGColor());
            DrawFrame(pDC, btnRect, -1);
              DrawButtonText(pDC, btnRect, buffer, GetFGColor());
            DrawFocusRect(lpDIS->hDC, (LPRECT)&focusRect);
        }
    }
    else if (state & ODS_DISABLED) {
        //COLORREF disabledColor = bg ^ 0xFFFFFF; // contrasting color
          DrawButtonText(pDC, btnRect, buffer, GetDisabledColor());
    }
}


void CColorButton::DrawFrame(CDC *DC, CRect R, int Inset)
{
    COLORREF dark, light, tlColor, brColor;
    int i, m, width;
    width = (Inset < 0)? -Inset : Inset;
   
    for (i = 0; i < width; i += 1) {
        m = 255 / (i + 2);
        dark = PALETTERGB(m, m, m);
        m = 192 + (63 / (i + 1));
        light = PALETTERGB(m, m, m);
         
          if ( width == 1 ) {
            light = RGB(255, 255, 255);
            dark = RGB(128, 128, 128);
        }
       
        if ( Inset < 0 ) {
            tlColor = dark;
            brColor = light;
        }
        else {
            tlColor = light;
            brColor = dark;
        }
       
        DrawLine(DC, R.left, R.top, R.right, R.top, tlColor);                            // Across top
        DrawLine(DC, R.left, R.top, R.left, R.bottom, tlColor);                            // Down left
     
        if ( (Inset < 0) && (i == width - 1) && (width > 1) ) {
            DrawLine(DC, R.left + 1, R.bottom - 1, R.right, R.bottom - 1, RGB(1, 1, 1));// Across bottom
            DrawLine(DC, R.right - 1, R.top + 1, R.right - 1, R.bottom, RGB(1, 1, 1));    // Down right
        }
          else {
            DrawLine(DC, R.left + 1, R.bottom - 1, R.right, R.bottom - 1, brColor);        // Across bottom
            DrawLine(DC, R.right - 1, R.top + 1, R.right - 1, R.bottom, brColor);        // Down right
        }
          InflateRect(R, -1, -1);
    }
}



void CColorButton::DrawFilledRect(CDC *DC, CRect R, COLORREF color)
{
    CBrush B;
    B.CreateSolidBrush(color);
    DC->FillRect(R, &B);
}
 

void CColorButton::DrawLine(CDC *DC, CRect EndPoints, COLORREF color)
{
    CPen newPen;
    newPen.CreatePen(PS_SOLID, 1, color);
    CPen *oldPen = DC->SelectObject(&newPen);
    DC->MoveTo(EndPoints.left, EndPoints.top);
    DC->LineTo(EndPoints.right, EndPoints.bottom);
    DC->SelectObject(oldPen);
    newPen.DeleteObject();
}

void CColorButton::DrawLine(CDC *DC, long left, long top, long right, long bottom, COLORREF color)
{
    CPen newPen;
    newPen.CreatePen(PS_SOLID, 1, color);
    CPen *oldPen = DC->SelectObject(&newPen);
    DC->MoveTo(left, top);
    DC->LineTo(right, bottom);
    DC->SelectObject(oldPen);
    newPen.DeleteObject();
}


void CColorButton::DrawButtonText(CDC *DC, CRect R, const char *Buf, COLORREF TextColor)
{
    COLORREF prevColor = DC->SetTextColor(TextColor);
    DC->SetBkMode(TRANSPARENT);
    DC->DrawText(Buf, strlen(Buf), R, DT_CENTER|DT_VCENTER|DT_SINGLELINE);
    DC->SetTextColor(prevColor);
}


       






评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值