void CinitpassDlg::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();
}
CFont *font = new CFont;
font->CreateFontW(200,0,0,0,700,0,0,0,0,OUT_DEVICE_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,_T("Aril"));
GetDlgItem(IDC_STATIC)->SetFont(font);
GetDlgItem(IDC_STATIC)->SetWindowTextW(L"PASS");
CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0)); }
這樣是可以顯示出PASS,但是改變顏色卻不能成功,但是如果將CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0));
這幾句加到CDialog::OnPaint()前面,或者是屏蔽掉CDialog::OnPaint()這一句就可以顯示出顏色。而且從CDialog::OnPaint也只是調用父類的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();
}
CFont *font = new CFont;
font->CreateFontW(200,0,0,0,700,0,0,0,0,OUT_DEVICE_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,_T("Aril"));
GetDlgItem(IDC_STATIC)->SetFont(font);
GetDlgItem(IDC_STATIC)->SetWindowTextW(L"PASS");
CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0)); }
這樣是可以顯示出PASS,但是改變顏色卻不能成功,但是如果將CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0));
這幾句加到CDialog::OnPaint()前面,或者是屏蔽掉CDialog::OnPaint()這一句就可以顯示出顏色。而且從CDialog::OnPaint也只是調用父類的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();
}
CFont *font = new CFont;
font->CreateFontW(200,0,0,0,700,0,0,0,0,OUT_DEVICE_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH,_T("Aril"));
GetDlgItem(IDC_STATIC)->SetFont(font);
GetDlgItem(IDC_STATIC)->SetWindowTextW(L"PASS"); CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0));
}
//這樣是可以顯示出PASS,但是改變顏色卻不能成功,但是如果將
/*
CRect rect;
CPaintDC dc(this);
GetClientRect(rect);
dc.FillSolidRect(rect,RGB(0,255,0));
這幾句加到CDialog::OnPaint()前面,或者是屏蔽掉CDialog::OnPaint()這一句就可以顯示出顏色。
而且從CDialog::OnPaint也只是調用父類的OnPaint()函數而已,怎麼會出現這個現象。
*/
此处已经绘图完毕了。个人猜测。
字体设置成功是由于字体改变,并不需要调用onpaint()。所以要想改变颜色应该在onpaint前面
此处已经绘图完毕了。个人猜测。
字体设置成功是由于字体改变,并不需要调用onpaint()。所以要想改变颜色应该在onpaint前面。没有具体验证,只是个人推测。