Duilib的简单使用(六、DuiEditor的使用(编写360xml文件))

9 篇文章 6 订阅

一、前言

Duilib的简单使用(一、duilib demo)中我们介绍了利用duilib简单的构造一个项目
Duilib的简单使用(二、xml实现界面与业务分离)中我们介绍了XML在duilib中的使用
Duilib的简单使用(三、界面逻辑交互)中我们已经知道如何简单的进行界面的交互
Duilib的简单使用(四、换肤)中,我们提了一下Duilib强大的一键换肤功能。
Duilib的简单使用(五、DuiDesigner/DuiEditor的下载编译)中,我们介绍了DuiEditor的下载编译

那么这一篇我们来谈一谈,如何使用,我们就用DuiEditor来画个界面吧,360不错,毕竟大家都喜欢用duilib模仿360 好像。

二、xml文件编写

2.1 启动软件

在这里插入图片描述

2.2 新建项目

新建UI文件
在这里插入图片描述
在这里插入图片描述

保存为360.xml,一定要保存,因为,你不知道什么时候这个软件就崩溃了(随时可能崩溃,所以随时保存。)
在这里插入图片描述

2.3 编写主体框架

修改大小为800,572
在这里插入图片描述
修改布局颜色,
在这里插入图片描述
写5个HorizontalLayout
在这里插入图片描述
在之前的文章中,下载的duilib的代码中的bin文件夹下,有360的资源zip,复制过来,解压到当前目录。
在这里插入图片描述
将水平布局放到垂直布局里。
在这里插入图片描述

2.4 编写标题栏

添加图标和软件名
在这里插入图片描述
再写六个button
在这里插入图片描述
此时的xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<Window size="800,572">
	<VerticalLayout bkcolor="0xFFd1e8f5" bkcolor2="0xffc6e0f1" bkcolor3="0xff768d9b" bordersize="1">
		<HorizontalLayout inset="5,0,0,0">
			<HorizontalLayout inset="5,0,0,0">
				<Control width="16" height="16" bkimage="icon.png" />
				<Text width="100" height="16" text="360安全卫士6.0" textcolor="0xff447aa1" />
			</HorizontalLayout>
			<HorizontalLayout width="227" height="0" inset="5,0,0,0" pos="0,0,227,0">
				<Button height="16" width="30" text="求助" />
				<Button height="16" width="30" text="论坛" />
				<Button height="16" width="30" name="menubtn" normalimage="file='sys_dlg_menu.png' dest='0,0,30,16' source='0,0,28,16' "/>
				<Button height="16" width="30" name="minbtn" normalimage="file='sys_dlg_min.png' dest='0,0,30,16' source='0,0,28,16' "/>
				<Button height="16" width="30" name="maxtn" normalimage="file='sys_dlg_max.png' dest='0,0,30,16' source='0,0,28,16' "/>
				<Button height="16" width="30" name="restorebtn" normalimage="file='sys_dlg_restore.png' dest='0,0,30,16' source='0,0,28,16' "/>
				<Button height="16" width="30" name="closebtn" normalimage="file='sys_dlg_close.png' dest='0,0,40,16' source='0,0,40,16' "/>
			</HorizontalLayout>
		</HorizontalLayout>
		<HorizontalLayout />
		<HorizontalLayout />
		<HorizontalLayout />
		<HorizontalLayout />
	</VerticalLayout>
</Window>

三、运行

当前的XML效果
在这里插入图片描述
下一篇:Duilib的简单使用(七、DuiEditor的使用(编写360xml文件二))

使用Duilib库加载XML文件需要经过以下几个简单的步骤: 1. 在项目中添加Duilib库的头文件和库文件。 2. 在代码中创建窗口类,并在窗口类的构造函数中使用CDuiXMLBuilder类加载XML文件。 3. 在窗口类中实现消息处理函数。 具体的步骤如下: 1. 在项目中添加Duilib库的头文件和库文件。 ```cpp #include "UIlib.h" // 添加Duilib库的链接库文件 #pragma comment(lib, "DuiLib.lib") ``` 2. 在代码中创建窗口类,并在窗口类的构造函数中使用CDuiXMLBuilder类加载XML文件。 ```cpp class CMyWnd : public WindowImplBase { public: CMyWnd() { // 使用CDuiXMLBuilder类加载XML文件 CDuiXMLBuilder builder; CControlUI* pRoot = builder.Create(L"my.xml", (UINT)0, NULL, &m_pm); if (pRoot) { // 将加载的UI控件树作为窗口的根控件 this->Add(pRoot); } } virtual LPCTSTR GetWindowClassName() const { return _T("MyWnd"); } virtual void OnFinalMessage(HWND hWnd) { delete this; } virtual LRESULT OnClose(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled) { bHandled = TRUE; ::PostQuitMessage(0); return 0; } } ``` 3. 在窗口类中实现消息处理函数。 ```cpp class CMyWnd : public WindowImplBase { public: // ... virtual CDuiString GetSkinFile() { return _T("my.xml"); } virtual LPCTSTR GetWindowClassName() const { return _T("MyWnd"); } virtual void OnFinalMessage(HWND hWnd) { delete this; } virtual LRESULT OnClose(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled) { bHandled = TRUE; ::PostQuitMessage(0); return 0; } } ``` 以上是使用Duilib库加载XML文件的基本步骤,具体的实现还需要根据实际情况进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值