
需要在分支结构的代码中将m_bIsTopMost的值改回来,否则下次这个函数再响应消息时,只会执行一部分固定的代码。
2.::SetWindowText(pWnd,strTitle.Left(nstrTitle-nstrFlag).GetBuffer(256))
这一句有问题吧?GetBuffer与Left同为CString类的成员函数。
VC标准对话框的标题栏,是有windows系统控制颜色的(你可以通过修改桌面属性中的配色方案调整,看到实际效果),也就是说,在通常情况下,这个是不受程序控制的。作为新手,不推荐做这个改变,比较麻烦。
简单介绍一下修改标题栏颜色和样式的两个方案:(都比较麻烦)
修改对话框属性,去掉系统标题栏,然后自己在客户区自绘一个假的标题栏,加上自定义的几个系统消息响应按钮。这是多数漂亮的MFC工程界面常用的一种手段,优点是不仅可以改变颜色,而且可以改变形状,实现异形窗口和标题栏等等。百度搜“VC 自绘标题栏”可以看到很多文章。
禁止并重载部分NC非客户区消息,可以实现改变标题栏颜色,缺点是在一些极端情况下,效果不好(比如d出模态子对话框或者AfxMessageBox之类,会变成系统控制,颜色修改无效)。重载消息包括:WM_NCPAINT|| WM_NCACTIVATE||WM_NOTIFY||WM_SETTEXT,主要是第一个,重载后在通常状态下,就改变了颜色,注意重载后不要调用基类虚函数。
void CTestPopDlg::OnNcPaint()
{
// TODO: Add your message handler code here
CBitmap bmp
bmp.LoadBitmap( IDB_BITMAP1 )
CWindowDC dc ( this )
CDC memDC
memDC.CreateCompatibleDC( &dc )
CRect rect
GetWindowRect( &rect )
memDC.SelectObject( &bmp )
dc.StretchBlt( 0, 0, rect.Width(), 25, &memDC, 0, 0, 10, 25, SRCCOPY )
// Do not call CDialog::OnNcPaint() for painting messages
}
方案二大概就是这个样子。
方案一是彻底的解决办法,但代码很零散而且多(提示:可以使用界面库实现),方案二相对代码较少,但效果强差人意。
VC编程中用代码设置AfxMessageBox标题栏标题文字的方法,代码如下:BOOL CMainFrame::PreCreateWindow(CREATESTRUCT&cs)
{
if(!CFrameWnd::PreCreateWindow(cs))
return FALSE
cs.style=WS_OVERLAPPEDWINDOW//这个不能缺少
cs.lpszName= "我就是标题文字" //标题文字
return TRUE
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)