前面的教程应该让大家对duilib的整体有所映像了,下面就来介绍下duilib具体控件的使用。
由于官方没有提供默认的控件样式,所以我就尽量使用win7或者XP自带的按钮样式了,虽然界面比较土鳖,但是想要换成百度杀毒那样的界面,只需要更换图片即可,如果有哪位小伙伴能够提供一些控件样式,那就再好不过啦~
首先利用一下前面教程的框架,效果图如下:
data:image/s3,"s3://crabby-images/6051a/6051a35fa906b22dde8666947cd996605f3c04b9" alt=""
main.cpp的代码如下:
class CDuiFrameWnd : public WindowImplBase { public: virtual LPCTSTR GetWindowClassName() const { return _T("DUIMainFrame"); } virtual CDuiString GetSkinFile() { return _T("duilib.xml"); } virtual CDuiString GetSkinFolder() { return _T(""); } }; int APIENTRY _tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPTSTR lpCmdLine, int nCmdShow) { CPaintManagerUI::SetInstance(hInstance); CDuiFrameWnd duiFrame; duiFrame.Create(NULL, _T("DUIWnd"), UI_WNDSTYLE_FRAME, WS_EX_WINDOWEDGE); duiFrame.CenterWindow(); duiFrame.ShowModal(); return 0; }
XML代码如下(由于前面的教程里都一一介绍了各种属性,所以以后的XML就不一一注释了):
<?xml version="1.0" encoding="UTF-8"?> <Window size="800,600" mininfo="600,400" caption="0,0,0,32" sizebox="4,4,4,4"> <VerticalLayout bkcolor="#FFF0F0F0" bkcolor2="#FFAAAAA0"> <!-- 标题栏区 --> <HorizontalLayout height="32" bkcolor="#FFE6E6DC" bkcolor2="#FFAAAAA0"> <VerticalLayout /> <VerticalLayout width="77"> <Button name="minbtn" tooltip="最小化" float="true" pos="0,5,22,24" width="23" normalimage=" file='SysBtnMinNormal.bmp' " hotimage=" file='SysBtnMinFocus.bmp' " pushedimage=" file='SysBtnMinFocus.bmp' "/> <Button name="maxbtn" tooltip="最大化" float="true" pos="22,5,44,24" width="23" normalimage=" file='SysBtnMaxNormal.bmp' " hotimage=" file='SysBtnMaxFocus.bmp' " pushedimage=" file='SysBtnMaxFocus.bmp' " /> <Button name="restorebtn" visible="false" tooltip="还原" float="true" pos="22,5,44,24" width="23" normalimage=" file='SysBtnStoreNormal.bmp' " hotimage=" file='SysBtnStoreFocus.bmp' " pushedimage=" file='SysBtnStoreFocus.bmp' " /> <Button name="closebtn" tooltip="关闭" float="true" pos="44,5,74,24" width="28" normalimage=" file='SysBtnCloseNormal.bmp' " hotimage=" file='SysBtnCloseFocus.bmp' " pushedimage=" file='SysBtnCloseFocus.bmp' "/> </VerticalLayout> </HorizontalLayout> </VerticalLayout> </Window>
前面教程的Hello World就是一个大大的按钮,大家对按钮应该很熟悉了,下面我们来几个按钮样式吧:
XP默认按钮 data:image/s3,"s3://crabby-images/4294a/4294a7628a3dd6cbda32f768d3e498e5cf9eda20" alt=""
data:image/s3,"s3://crabby-images/adf31/adf31f0d108870c5db1bd87007153829f2bece25" alt=""
data:image/s3,"s3://crabby-images/e828e/e828eda71c664fdf9248fb220fe10124ab288d61" alt=""
data:image/s3,"s3://crabby-images/79142/791425e8684a307d45b08a5026f758e6b088e3d7" alt=""
data:image/s3,"s3://crabby-images/4294a/4294a7628a3dd6cbda32f768d3e498e5cf9eda20" alt=""
data:image/s3,"s3://crabby-images/adf31/adf31f0d108870c5db1bd87007153829f2bece25" alt=""
data:image/s3,"s3://crabby-images/e828e/e828eda71c664fdf9248fb220fe10124ab288d61" alt=""
data:image/s3,"s3://crabby-images/79142/791425e8684a307d45b08a5026f758e6b088e3d7" alt=""
win7默认按钮 data:image/s3,"s3://crabby-images/1f8bd/1f8bd63b261f34c72c2f36645b1452b76bf69637" alt=""
data:image/s3,"s3://crabby-images/8916c/8916c0ffabcadcbc28134b0e89244a7a6f2c360e" alt=""
data:image/s3,"s3://crabby-images/aa224/aa22403d4b7999ab718b89809975a80a07bb2f63" alt=""
data:image/s3,"s3://crabby-images/eeb1a/eeb1a8cdf83ae626bc3d4e2b8c142b1dd4544d07" alt=""
data:image/s3,"s3://crabby-images/1f8bd/1f8bd63b261f34c72c2f36645b1452b76bf69637" alt=""
data:image/s3,"s3://crabby-images/8916c/8916c0ffabcadcbc28134b0e89244a7a6f2c360e" alt=""
data:image/s3,"s3://crabby-images/aa224/aa22403d4b7999ab718b89809975a80a07bb2f63" alt=""
data:image/s3,"s3://crabby-images/eeb1a/eeb1a8cdf83ae626bc3d4e2b8c142b1dd4544d07" alt=""
百度杀毒
data:image/s3,"s3://crabby-images/5454e/5454edd4aace15a95177a59f8e902a98ab41f700" alt=""
data:image/s3,"s3://crabby-images/b6605/b6605871f978fde95d010f0b2a421dfd45e3b1f5" alt=""
data:image/s3,"s3://crabby-images/4a71c/4a71cc67e4baadf144c30becd4725db338eadfdf" alt=""
data:image/s3,"s3://crabby-images/5454e/5454edd4aace15a95177a59f8e902a98ab41f700" alt=""
百度卫士
data:image/s3,"s3://crabby-images/1a42f/1a42fe6bd032342b47a2967506feed6e26194532" alt=""
data:image/s3,"s3://crabby-images/d512c/d512c84d26c910c3e9db541d1ac658bd3140ad96" alt=""
data:image/s3,"s3://crabby-images/1a42f/1a42fe6bd032342b47a2967506feed6e26194532" alt=""
data:image/s3,"s3://crabby-images/610e9/610e9a64231816fe8ea1801a627a9d8fd01f5345" alt=""
上述图片资源请点击这里下载,下载后解压到exe目录即可,此时Debug文件夹如下(别忘了前面教程的SysBtn文件夹哦):
data:image/s3,"s3://crabby-images/52cd1/52cd10e1a903f1cfe68d3fae57099713de6b8b4f" alt=""
我们先用DuiDesigner添加一些按钮,并且把他们排整齐,如图:
保存之后就可以看到这几个按钮的pos等属性了,再手动将这几个Button节点加到前面的XML中,并添加图片属性,如下:
<?xml version="1.0" encoding="UTF-8"?> <Window size="800,600" mininfo="600,400" caption="0,0,0,32" sizebox="4,4,4,4"> <VerticalLayout bkcolor="#FFF0F0F0" bkcolor2="#FFAAAAA0"> <!-- 标题栏区 --> <HorizontalLayout height="32" bkcolor="#FFE6E6DC" bkcolor2="#FFAAAAA0"> <VerticalLayout /> <VerticalLayout width="77"> <Button name="minbtn" tooltip="最小化" float="true" pos="0,5,22,24" width="23" normalimage=" file='SysBtnMinNormal.bmp' " hotimage=" file='SysBtnMinFocus.bmp' " pushedimage=" file='SysBtnMinFocus.bmp' "/> <Button name="maxbtn" tooltip="最大化" float="true" pos="22,5,44,24" width="23" normalimage=" file='SysBtnMaxNormal.bmp' " hotimage=" file='SysBtnMaxFocus.bmp' " pushedimage=" file='SysBtnMaxFocus.bmp' " /> <Button name="restorebtn" visible="false" tooltip="还原" float="true" pos="22,5,44,24" width="23" normalimage=" file='SysBtnStoreNormal.bmp' " hotimage=" file='SysBtnStoreFocus.bmp' " pushedimage=" file='SysBtnStoreFocus.bmp' " /> <Button name="closebtn" tooltip="关闭" float="true" pos="44,5,74,24" width="28" normalimage=" file='SysBtnCloseNormal.bmp' " hotimage=" file='SysBtnCloseFocus.bmp' " pushedimage=" file='SysBtnCloseFocus.bmp' "/> </VerticalLayout> </HorizontalLayout> <!-- 客户区 --> <HorizontalLayout> <Button text="XP" float="true" pos="20,14,0,0" width="60" height="25" normalimage=" file='BtnStyleXPutton_nor.png' " hotimage=" file='BtnStyleXPutton_over.png' " pushedimage=" file='BtnStyleXPutton_down.png' " focusedimage=" file='BtnStyleXPutton_focus.png' " /> <Button text="win7" float="true" pos="20,50,0,0" width="60" height="25" normalimage=" file='BtnStylewin7utton_nor.png' " hotimage=" file='BtnStylewin7utton_over.png' " pushedimage=" file='BtnStylewin7utton_down.png' " focusedimage=" file='BtnStylewin7utton_focus.png' " /> <Button text="百度杀毒" float="true" pos="20,86,0,0" width="102" height="35" normalimage=" file='BtnStyleBDKVutton_nor.png' " hotimage=" file='BtnStyleBDKVutton_over.png' " pushedimage=" file='BtnStyleBDKVutton_down.png' " /> <Button float="true" pos="20,132,0,0" width="171" height="46" normalimage=" file='BtnStyleBDKV2utton_nor.png' " hotimage=" file='BtnStyleBDKV2utton_over.png' " pushedimage=" file='BtnStyleBDKV2utton_down.png' " /> </HorizontalLayout> </VerticalLayout> </Window>
效果如下:
data:image/s3,"s3://crabby-images/355d5/355d50b1da71a5cd8d00fa797f83bc404eed10f3" alt=""
用鼠标移上去,或者点击一下,看看是不是和系统按钮一样呢^_^
下面我们介绍一下duilib的另一种特性,那就是可以定制默认样式,这样做有什么好处呢?
假如我们有10个按钮,按钮样式都一样,如果用之前介绍的方式,则需要在每个Button节点都指定图片背景、宽度、高度等信息,一旦需要改动任何一个属性,则需要在10个按钮里面都改一次,所以为了方便修改,我们可以指定一个默认样式,就算有100个按钮,我们也只需要改一次属性。方法如下:
给<Window>节点添加一个Default节点即可,其中name属性填写控件的名字,value属性添加控件的属性的值,不过需要将双引号【"】换成【"】,单引号【'】换成【'】,单引号也可以不转换。
XML如下(由于标题栏基本不再变化,所以后面的教程将省略<!-- 标题栏区 -->那一段XML):
<Window size="800,600" mininfo="600,400" caption="0,0,0,32" sizebox="4,4,4,4"> <Default name="Button" value=" height="25" width="60" normalimage="file='BtnStyleXPutton_nor.png'" hotimage="file='BtnStyleXPutton_over.png'" pushedimage="file='BtnStyleXPutton_down.png'" focusedimage="file='BtnStyleXPutton_focus.png'" " /> <VerticalLayout bkcolor="#FFF0F0F0" bkcolor2="#FFAAAAA0"> <!-- 客户区 --> <HorizontalLayout> <Button text="XP" float="true" pos="20,14,0,0" height="25" /> <Button text="win7" float="true" pos="20,50,0,0" height="25" /> <Button text="百度杀毒" float="true" pos="20,86,0,0" height="25" /> <Button float="true" pos="20,132,0,0" height="25" /> </HorizontalLayout> </VerticalLayout> </Window>
XML是不是清爽多了呢^_^ 注意,这里面要指定height属性,不然会看不到按钮,估计是因为放在了HorizontalLayout水平布局里。(如果是VerticalLayout ,应该是指定width属性,这个只是猜测,暂未验证~(^o^)/~)
不过你会发现,启动的时候,最小化按钮图片不对了,那是因为最小化按钮没有指定focusedimage属性,所以就用了默认的focusedimage属性,只需要指定一下就行了。
data:image/s3,"s3://crabby-images/640b7/640b7de5378e97e949ea781a2c373ed628865b0d" alt=""
按钮的用法就介绍完啦,大家可以看到UI设计器里面还有下面这些控件,
data:image/s3,"s3://crabby-images/afeda/afeda793747d47124692d467f1e09a67c514efa1" alt=""
其中:
Control是所有控件的基类,一般放图片啥的就用它了。
Label和Text是用于放文字的,其中Label的对齐功能比Text要好一些,所以我一般用Label,这个对应于MFC的Static控件。
Edit显然就是编辑框啦,Button就不用多说了吧~
上面提到的控件都是简单控件,拖到设计器上就能直观的看到效果,绝大部分属性都和Button一样,就不赘述了,所有控件的所有属性都在【duilib控件 XML属性列表】里有详细说明(不过有一点点遗漏,需要去看源码),下一节将介绍复杂控件。