我在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后背景色才能变,
先建一个对话框,添加一个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后背景色才能变,
{
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;
}
}
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(强)老兄我不想换啊,以后我还要在这里画点东西啊嘿嘿
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