duilib开发(十三):使用自定义图标

一、使用自定义图标

在之前的程序中我们都是使用的都是命令行窗口,因为这样方便调试,可以打印很多信息出来,接下来我们使用自定义的图标

1、首先找到一张.icon 图标图片放到指定目录下

2、vs 里面找到 资源视图 --> 添加 --> 资源 --> 选取一张图片,添加完成后会出现一个 Icon,然后我们加载图标

加载图标,试了一下不加这一行代码也是可以的

HICON hIcon = ::LoadIcon(_hInstance, "IDI_ICON1");

 运行观察效果

发现图标确实被改了,但是改的是命令行窗口的图标,接下来更改应用图标和去掉命令行黑窗口

// 去掉命令行黑窗口
#pragma comment( linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"" )

在 InitWindow 里面加上设置图标,这里需要引入 resource.h 头文件,上面加完图标就会生成这个文件

void PlayerWnd::InitWindow()
{
    SetIcon(IDI_ICON1);
}

到这里设置图标也就结束了,任务管理器的图标也是会改变的

如果想要点击关闭按钮最小化到托盘可以参考这一篇文章:https://segmentfault.com/a/1190000021506640,这个时候应该是要自定义标题栏,然后重新定义关闭事件

二、参考资料

1、duilib 修改 exe 图标和 任务栏图标 :https://blog.csdn.net/u010096608/article/details/103703346

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Duilib是一个基于C++的开源UI库,它提供了丰富的控件和功能,可以用于快速开发Windows桌面应用程序。在Duilib中,你可以自定义控件来满足特定的需求。 下面是一个示例,演示如何在Duilib中创建一个自定义控件: ```cpp // 自定义控件的头文件 CustomControl.h #pragma once #include "UIlib.h" class CCustomControl : public DuiLib::CControlUI { public: CCustomControl(); virtual ~CCustomControl(); LPCTSTR GetClass() const; LPVOID GetInterface(LPCTSTR pstrName); void DoEvent(DuiLib::TEventUI& event); void PaintStatusImage(HDC hDC); protected: bool m_bMouseHover; bool m_bMousePressed; }; // 自定义控件的实现文件 CustomControl.cpp #include "CustomControl.h" CCustomControl::CCustomControl() : m_bMouseHover(false) , m_bMousePressed(false) { } CCustomControl::~CCustomControl() { } LPCTSTR CCustomControl::GetClass() const { return _T("CustomControl"); } LPVOID CCustomControl::GetInterface(LPCTSTR pstrName) { if (_tcscmp(pstrName, _T("CustomControl")) == 0) return static_cast<CCustomControl*>(this); return CControlUI::GetInterface(pstrName); } void CCustomControl::DoEvent(DuiLib::TEventUI& event) { if (event.Type == DuiLib::UIEVENT_MOUSEENTER) { m_bMouseHover = true; Invalidate(); } else if (event.Type == DuiLib::UIEVENT_MOUSELEAVE) { m_bMouseHover = false; Invalidate(); } else if (event.Type == DuiLib::UIEVENT_BUTTONDOWN) { m_bMousePressed = true; Invalidate(); } else if (event.Type == DuiLib::UIEVENT_BUTTONUP) { m_bMousePressed = false; Invalidate(); } CControlUI::DoEvent(event); } void CCustomControl::PaintStatusImage(HDC hDC) { if (m_bMousePressed) { // 绘制按下状态的控件外观 } else if (m_bMouseHover) { // 绘制鼠标悬停状态的控件外观 } else { // 绘制正常状态的控件外观 } } ``` 在上面的示例中,我们创建了一个名为`CCustomControl`的自定义控件类,继承自`DuiLib::CControlUI`。在这个类中,我们重写了一些方法来处理控件的事件和绘制外观。你可以根据自己的需求来实现这些方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值