首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

更改mfc应用程序的标题栏颜色

更改MFC应用程序的标题栏颜色是通过自定义绘制窗口的方式实现的。以下是一个完善且全面的答案:

MFC应用程序的标题栏颜色可以通过以下步骤进行更改:

  1. 首先,在MFC应用程序的主框架类中,找到窗口创建的消息处理函数,一般是在InitInstance函数中。
  2. 在窗口创建之前,我们需要注册一个新的窗口类,以便能够自定义绘制窗口。
  3. 在窗口类注册之后,我们需要创建一个派生自CWnd的自定义窗口类,并重写它的OnNcPaint函数。
  4. 在OnNcPaint函数中,我们可以使用设备上下文(DC)来绘制标题栏的背景色。可以使用GDI+库或者直接使用GDI函数来实现。
  5. 在绘制完成后,我们需要调用默认的绘制函数来绘制其他窗口元素,如标题文字、按钮等。

下面是一个示例代码:

代码语言:txt
复制
// 在主框架类的InitInstance函数中添加以下代码
BOOL CMyApp::InitInstance()
{
   // ...

   // 注册新的窗口类
   WNDCLASS wndClass;
   wndClass.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW;
   wndClass.lpfnWndProc = ::DefWindowProc;
   wndClass.cbClsExtra = wndClass.cbWndExtra = 0;
   wndClass.hInstance = AfxGetInstanceHandle();
   wndClass.hIcon = LoadIcon(IDR_MAINFRAME);
   wndClass.hCursor = LoadCursor(IDC_ARROW);
   wndClass.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1);
   wndClass.lpszMenuName = NULL;
   wndClass.lpszClassName = _T("MyCustomWndClass");

   AfxRegisterClass(&wndClass);

   // 创建自定义窗口类
   CMyCustomWnd myWnd;
   myWnd.CreateEx(WS_EX_APPWINDOW, _T("MyCustomWndClass"), _T("My App"), WS_OVERLAPPEDWINDOW,
      CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL);

   // ...

   return TRUE;
}

// 自定义窗口类的头文件
class CMyCustomWnd : public CWnd
{
public:
   afx_msg void OnNcPaint();

   DECLARE_MESSAGE_MAP()
};

// 自定义窗口类的实现文件
BEGIN_MESSAGE_MAP(CMyCustomWnd, CWnd)
   ON_WM_NCPAINT()
END_MESSAGE_MAP()

void CMyCustomWnd::OnNcPaint()
{
   // 获取设备上下文
   CDC* pDC = GetWindowDC();

   // 绘制标题栏的背景色
   CRect rect;
   GetWindowRect(&rect);
   rect.bottom = rect.top + GetSystemMetrics(SM_CYCAPTION);
   pDC->FillSolidRect(&rect, RGB(255, 0, 0)); // 使用红色作为标题栏的背景色

   // 调用默认的绘制函数
   Default();

   // 释放设备上下文
   ReleaseDC(pDC);
}

这样,当MFC应用程序启动时,标题栏的背景色将会被更改为红色。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云数据库(TencentDB):https://cloud.tencent.com/product/cdb
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能(AI):https://cloud.tencent.com/product/ai
  • 腾讯云物联网(IoT):https://cloud.tencent.com/product/iot
  • 腾讯云区块链(BCS):https://cloud.tencent.com/product/bcs
  • 腾讯云元宇宙(Metaverse):https://cloud.tencent.com/product/metaverse

请注意,以上链接仅供参考,具体的产品选择应根据实际需求和情况进行评估。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Qt编写数据可视化大屏界面电子看板2-配色方案

    做完整个数据可视化大屏界面电子看板系统后,为了提升点逼格,需要提供好几套默认的风格样式以供选择,这样用户可以选择自己喜欢的配色方案来作为整个系统的颜色方案,去看了下市面上大部分的大屏电子看板系统,都是以蓝色为主,部分黑色,估计也许这就是大众的审美吧,那就在数据可视化大屏界面电子看板系统中也加入蓝色风格、深蓝色风格、黑色风格,三种,加上默认的紫色风格,共计内置4套风格选择,Qt的QSS是我见过的最牛逼的换肤控制样式界面颜色的东东,这个工具用好了,别提有多爽,直接qApp->setStyleSheet(qss);可以对整个应用程序换肤,如果自定义的控件定义了Q_PROPERTY的话,也会立即更改自定义控件的属性。

    00

    Qt编写数据可视化大屏界面电子看板7-窗体浮动

    窗体浮动的场景也比较多,用途也比较大,比如视频监控模块,有时候需要调整大小和位置,而不是作为dock嵌入到布局中,一旦嵌入到布局中,大小和位置都被布局接管了,只能任由布局使唤,按在地上摩擦的那种。所以窗体浮动独立出来以后,就可以当做单独的窗体使用了,八个方位任意调整大小,(做到这里,是不是想起来,很多人写的无边框窗体类,自己写代码实现边框的拉伸调整大小?原来Qt也内置类无边框调整大小的位置哈!)同时窗体可以拖动到任意位置,比如可以拖动到中间部位占领一个位置,能够调整到最佳的16:9的大小效果。此时的视频看起来就很爽了,这个效果其实是Qt内置的,我在自定义的标题栏中增加了双击浮动,再次双击最大化显示的功能而已。

    03

    Qt编写数据可视化大屏界面电子看板6-窗体打开关闭

    二级窗体的打开与关闭,这个功能也很有必要,由于整个系统中各种模块数量窗体数量比较多,后期可能还会增加更多,在4K屏幕上可以显示很多的模块,但是有时候有些模块不想显示出来,就需要将该模块关闭掉,直接在二级窗体的标题栏上增加关闭按钮,可能会影响整体的布局,此时提供鼠标右键菜单来控制各个模块的开关,就非常爽了,QDockWidget上场,QMainWindow类中如果有Dock类,则会自动生成右键菜单,自动将加载的窗体的名称生成菜单,前面可以打钩表示开启,没有打钩表示关闭,默认都是开启的,saveState()函数也会记录各个模块最后的开启和关闭状态,所以在应用restoreState()函数时候也会自动控制模块的开关,不得不说Qt在这个功能点上是下足了功夫,封装的非常好非常棒顶呱呱!

    05

    Qt编写数据可视化大屏界面电子看板8-调整间距

    在数据可视化大屏界面电子看板系统中,前期为了使用目标客户机,调整间距是必不可少的工作,QMainWindow中的QDockWidget,会默认生成布局和QSplitter调整宽高大小,鼠标移动到模块之间的缝隙处,鼠标指针会形成调整大小间距的那种,上下左右拉动就可以调整大小了。Qt的dock默认底部布局是被全部填充的,即一旦产生了底部Dock,则底部的左侧和右侧也属于底部布局,此时需要用setCorner方法来把这个布局给切掉,比如底部布局的左侧部分,可以切掉当做左侧布局使用,setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea);底部布局右侧部分,可以切掉当做右侧布局使用,setCorner(Qt::BottomRightCorner, Qt::RightDockWidgetArea);这样左右两侧的布局就有更大的空间来放置窗体了,这样可能更适合大部分的应用场景。如果只是切掉了一部分,比如切掉了右侧,则左侧和中间部分当做底部布局,放置一个长条状的大窗体,也是非常美观的,主要看具体的窗体大小了。

    03

    Qt编写数据可视化大屏界面电子看板9-曲线效果

    为了编写数据可视化大屏界面电子看板系统,为了能够兼容Qt4和嵌入式linux系统,尤其是那种主频很低的,但是老板又需要在这种硬件上(比如树莓派、香橙派、全志H3、imx6)展示这么华丽的界面时,就必须用最传统的painter方法来实现所有的控件了,一开始使用的QChart来实现各个子控件,在使用过程中发现比较鸡肋,个人感觉QChart是所有的子模块中源码写的最烂的,本人把QChart的源码看了一遍,比如饼图控件,居然放置一个label用来显示对应的文字描述,都懒得用painter去绘制,而且还有大量的类型转换,这个就效率大大降低了,虽然效果上挺好的,比如继承自QAnimation类自定义的chart动画类,还有个整体换肤的,但是在大量数据展示的时候,卡的一逼,比QWT和QCustomPlot差很远,本人看过QCustomPlot的源码,尽管就一个文件,(其实作者那边肯定是多个文件的,只不过发布的时候合并成一个文件发布的,毕竟这样对于用户来说使用还是很方便的,就是阅读不方便,毕竟大部分人用来是直接使用的而不是研究代码的。)但是里边的代码质量非常好非常高,本人特别推崇用QCustomPlot来展示曲线和柱状图等,效率很高,本人亲自试过最大展示50W数据点,还可以。据朋友所说,可能QWT质量还要更高,我没有研究过QWT的源码,不予置评,估计有可能是的。

    04

    Qt编写数据可视化大屏界面电子看板4-布局另存

    布局另存是数据可视化大屏界面电子看板系统中的额外功能之一,主要用于有时候用户需要在现有布局上做个微调,然后直接将该布局另存为一个布局配置文件使用,可以省略重新新建布局重新来一次大的调整的工作,此功能主要是用到了配置文件的保存,另存为一个不同名字的配置文件即可,属于非常简单的功能,在代码上来讲,其实Qt的配置文件类QSettings使用起来不要太方便,不仅支持WIN的注册表的读取写入,还支持跨平台的INI文件,说白了其实就是个文本文件,个人比较喜欢用INI文件作为配置文件,这样一方面跨平台,本人平时主要在嵌入式linux上做开发,INI文件是做好的选择。

    02

    Qt编写数据可视化大屏界面电子看板5-恢复布局

    恢复布局这个功能在整个数据可视化大屏界面电子看板系统中非常有用,很多时候不小心把现有布局拖动乱了,(当然如果不想布局被拖动改动,可以修改配置文件中的MoveEnable参数来控制,默认为真表示可以任意拖动布局,后期如果不想再被拖动可以设置为假。)人总归有不小心的时候,一旦不小心拖动了布局,则可以在软件没有退出之前恢复,鼠标右键菜单增加恢复布局这个功能就很有必要了,在保存布局以前,单击这个恢复布局,会自动恢复到当前布局的初始状态,如果不小心保存布局了,那就只能重新新建布局了,或者如果布局有备份的话就更好。恢复布局只能对当前布局进行恢复,而且是在未保存布局以前,以后就麻烦。

    03
    领券