我在vc.net2003下写了一个改变Picture控件背景色的程序,开始按照网上的例子想用OnCtlColor()函数来实现,但是不管颜色是多少Picture控件背景色也没有变化,后来把Picture控件的type属性改为Enhanced Metafile后背景色可以变化了,但是改变背景色的语句也变得很简单,下面是我在改变type属性前后的代码
先建一个对话框,添加一个Picture控件,所有属性不变
添加三个按钮
头文件:
// 背景Dlg.h : 头文件
//#pragma once
#include "afxwin.h"
// CMyDlg 对话框
class CMyDlg : public CDialog
{
// 构造
public:
CMyDlg(CWnd* pParent = NULL); // 标准构造函数// 对话框数据
enum { IDD = IDD_MY_DIALOG }; protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
HICON m_hIcon; // 生成的消息映射函数
virtual BOOL OnInitDialog();
afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()
public:
//CStatic g_MyDraw;
afx_msg void OnBnClickedOk();
afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor);
afx_msg void OnBnClickedOk2();
afx_msg void OnBnClickedOk3();
afx_msg void OnBnClickedOk4();
};
cpp文件:
// 背景Dlg.cpp : 实现文件
//#include "stdafx.h"
#include "背景.h"
#include "背景Dlg.h"
#include ".\背景dlg.h"#ifdef _DEBUG
#define new DEBUG_NEW
#endif
  CBrush   m_brush;   
  COLORREF   m_color; 
  // 用于应用程序“关于”菜单项的 CAboutDlg 对话框class CAboutDlg : public CDialog
{
public:
CAboutDlg();// 对话框数据
enum { IDD = IDD_ABOUTBOX }; protected:
virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持// 实现
protected:
DECLARE_MESSAGE_MAP()
};CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
}void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()
// CMyDlg 对话框CMyDlg::CMyDlg(CWnd* pParent /*=NULL*/)
: CDialog(CMyDlg::IDD, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}void CMyDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//DDX_Control(pDX, IDC_PIC, g_MyDraw);
}BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
//}}AFX_MSG_MAP
ON_BN_CLICKED(IDOK, OnBnClickedOk)
ON_WM_CTLCOLOR()
ON_BN_CLICKED(IDOK2, OnBnClickedOk2)
ON_BN_CLICKED(IDOK3, OnBnClickedOk3)
ON_BN_CLICKED(IDOK4, OnBnClickedOk4)
END_MESSAGE_MAP()
// CMyDlg 消息处理程序BOOL CMyDlg::OnInitDialog()
{
CDialog::OnInitDialog(); // 将\“关于...\”菜单项添加到系统菜单中。 // IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenu.LoadString(IDS_ABOUTBOX);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
} // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
//  执行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标 // TODO: 在此添加额外的初始化代码

//m_brush.CreateSolidBrush(RGB(0,0,0));   
  //此处设置的RGB值可以改变控件的背景色。   
    
//m_color=RGB(0,0,0);   
  //此处设置控件的文字初始颜色。 

return TRUE;  // 除非设置了控件的焦点,否则返回 TRUE
}void CMyDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}}// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。void CMyDlg::OnPaint() 
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文 SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2; // 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
}
}//当用户拖动最小化窗口时系统调用此函数取得光标显示。
HCURSOR CMyDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}void CMyDlg::OnBnClickedOk()     //设置背景色红
{
m_color=RGB(128,0,255);//此处改变字体的颜色
CStatic*m_pStatic1=(CStatic*)GetDlgItem(IDC_PIC);
m_pStatic1->RedrawWindow();
}HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
// TODO:  在此更改 DC 的任何属性
if(pWnd->GetDlgCtrlID()   ==   IDC_PIC)   
{
pDC->SetBkMode(1);
pDC->SetBkColor(m_color);
                     pWnd->ReleaseDC(pDC);
return (HBRUSH)m_brush.GetSafeHandle();
}
// TODO:  如果默认的不是所需画笔,则返回另一个画笔
return CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
}改变type属性后的cpp代码:
只贴更改的部分
void CMyDlg::OnBnClickedOk()
{
m_brush.CreateSolidBrush(RGB(255,0,0));
CStatic*m_pStatic1=(CStatic*)GetDlgItem(IDC_PIC);
m_pStatic1->RedrawWindow();
m_brush.DeleteObject();
}HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)

if(pWnd->GetDlgCtrlID()   ==   IDC_PIC)   
{
return (HBRUSH)m_brush.GetSafeHandle();
}
// TODO:  如果默认的不是所需画笔,则返回另一个画笔
return CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
}
我想问一下第一个方法是哪里有问题,为什么只有在type属性为Enhanced Metafile后背景色才能变,

解决方案 »

  1.   

    你可以换个控件来显示颜色 eg:EDITHBRUSH CSetParameter::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) 
    {
    HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    //HBRUSH   b=CreateSolidBrush(RGB(255,255,255));
    // TODO: Change any attributes of the DC here
    if(pWnd->GetDlgCtrlID() == IDC_EDIT_OIL)
    {
    //pDC->SetTextColor(m_crTextColor);
    //pDC->SetBkMode(TRANSPARENT);
    pDC->SetBkColor(m_crBackgColorOil);
    return m_brBkgnd;
    }
    else if(pWnd->GetDlgCtrlID() == IDC_EDIT_OWSAME)
    {
    pDC->SetBkColor(m_crBackgColorOWSame);
    return m_brBkgnd;
    }
    }
      

  2.   

    enhanced metafile 是增强的图元文件的意思啊,你想要实现的功能就是属于增强的功能吧,这样理解你就记忆深刻了。随便说的,别见怪啊。
      

  3.   

    为什么网上的例子把type属性设置为Rectangle
    HBRUSH CMyDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
    {
    // TODO:  在此更改 DC 的任何属性
    if(pWnd->GetDlgCtrlID()   ==   IDC_PIC)   
    {
    pDC->SetBkMode(1);
    pDC->SetBkColor(m_color);
                         pWnd->ReleaseDC(pDC);
    return (HBRUSH)m_brush.GetSafeHandle();
    }
    // TODO:  如果默认的不是所需画笔,则返回另一个画笔
    return CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    }大家可以到http://community.csdn.net/Expert/topic/5457/5457927.xml?temp=.9715235去帮帮我
    另he_hawk(强)老兄我不想换啊,以后我还要在这里画点东西啊嘿嘿
      

  4.   

    搞定了嘿嘿
    if ((pWnd->GetDlgCtrlID() == IDC_PIC) && (nCtlColor == CTLCOLOR_STATIC))
    {
      COLORREF clr;
      clr = RGB(0,0,0);
      pDC->SetBkColor(clr);     //设置黑色的背景
      m_brush.CreateSolidBrush(clr);
      return m_brush;  //作为约定,返回背景色对应的刷子句柄
      }
    HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
    return hbr;这是OnCtlColor里的代码用pDC->SetBkColor(clr);同样可以更改Picture控件里的背景色
    但是type属性必须为 Enhanced  Metafile 关键是要有 nCtlColor == CTLCOLOR_STATIC