如何在WTL和MFC中使用duilib及如何静态使用duilib库

如何在WTL和MFC中使用duilib及如何静态使用duilib库,第1张

现在把我在实现过程中遇到的问题及解决方法列举一下 以便大家以后遇到问题的时候做一个参考。

1.我喜欢用静态库,不喜欢用动态库,用动态库就好像穿衣服还要随身携带衣架一样,多余还麻烦。

所以在用这个库的时候 第一件事就是把动态库变成静态库。还有改用成 unicode字符集

(1).找到uilib.h头文件 注释掉原有的定义:添加新的宏 #define UILIB_API

//#ifdef UILIB_EXPORTS

//#define UILIB_API __declspec(dllexport)

//#else

//#define UILIB_API __declspec(dllimport)

//#endif

(2)编译后不会报错,然后 在使用时就可以直接包含这个静态库了 同时要注意一点 还需要包含 几个静态库oledlg.lib dui.lib winmm.lib comctl32.lib

虽然也不简单,但是却可以让程序生成后 只有一个exe 也没有其他累赘。

2. 包含之后 编译工程 会报错createtextserver没有定义什么的。这个是因为新版本中加入了richedit支持,这个directui的 需要用到 texthost和textserver 这时候 需要引用richedit.dll和richedit.lib 为了方便,我把这部分的导入 放到了duilib库里面了。 至于是什么代码我就不贴了 导入库的代码 是个程序员就会了。

3.如果你的wtl ATL MFC文件已经包含了 atltypes之类的头文件,那你会发现会出N多的 crect cpoint csize等 说不知道用哪个。因为duilib自己实现了这三个函数 和ATL MFC WL里面的冲突了。那么这时候怎么办呢?.. 当然是用宏了,我们在duilib的 uibase.h下面可以找到他们定义 在定义前加#ifndef DUI_NOTYPES 定义后追加 #endif 这样我们在WTL中引入duilib库的时候 引用前加入 #define DUI_NOTYPES 就可以屏蔽掉那些错误了。

4. 接下来的问题 都快让我崩溃了,不过最后还是解决了。

在前面问题逐一解决之后 你会发现 项目里的很多地方都莫名其妙的报错了,甚至连最基本的 CDC CmemeryDC Cpen什么的都不认了 报一堆错误。

错误原因在于duilib里面的 windowsx.h头文件,这个是sdk编程人员不可能不知道的头文件了,里面是一些宏的定义,大大的方便了sdk编程。

而在这里却成了阻碍,那么怎么办呢? 我看了下报错的地方 又看了下windowsx里面宏,发现其实原因很简单,里面的一些宏定义和WTL的函数定义冲突了。那么这个时候 我们需要使用微软的 函数保护机制了。在我的项目中有冲突的是下面几个函数 SelectFont SelectPen 其实还有很多 selectbrush等。报什么错就加什么 没有必要一次加齐。

#ifdef _INC_WINDOWSX

#undef SelectFont

#undef SelectPen

#endif // _INC_WINDOWSX

5.那么到这个时候就可以正常的在WTL中使用duilib库了。

6.那么我们来说说 那棵树的实现。

树无疑 就是里面的list靠缩进实现了。节点我选择用以下模式做的。这样后面排序的时候 我只需要交换CHorizontalLayoutUI就可以了 而无须改变

CListContainerElementUI 索引号了。

CListContainerElementUI

CHorizontalLayoutUI

控件

控件

CHorizontalLayoutUI

CListContainerElementUI

7.自动计算下滚动条,

CListContainerElementUI 没有自动计算下滚动条的功能,可能是因为是容器 里面的东西多少位置之类的都无法确定吧。

我的项目为了针对我这个项目 我在CHorizontalLayoutUI 插入了Ctextui 在底层库里面加入自动计算Ctextui 的宽度并设置CListContainerElementUI 宽度的逻辑就可以了

在这个过程总需要注意CListContainerElementUI 的setfixwight 有刷新的 会导致死循环 所以要加一个默认参数。

8.排序 排序就不多说的 原理比较简单 一个快速排序,然后 颠倒CHorizontalLayoutUI和 tag就可以了、我的快排写的 比较麻烦好像 因为当时比较着急 写的时候比较乱 不过还可以 至少实现功能了,但是目前只是叶子节点排序,如果想实现非叶子节点排序也不是不可以,但是会比较麻烦 因为我也不用 就没写,有兴趣的自己写下吧。

demo真是非常之简单,只有一个treeviwe 其他的什么都没有.连标题栏什么都没写 那些我相信大家很简单的就能写出来。我把demo放到csdn上 想看的下载吧 。转载。

<Controls>

<Window parent="">

<Attribute name="size" default="0,0" type="SIZE" comment="窗口的初始化大小,如(800,600)"/>

<Attribute name="sizebox" default="0,0,0,0" type="RECT" comment="窗口可拖动改变窗口大小的边距,如(4,4,6,6)"/>

<Attribute name="caption" default="0,0,0,0" type="RECT" comment="窗口可拖动的标题栏大小的边距,最后一个参数是指离上边框的距离,如(0,0,0,28)"/>

<Attribute name="roundcorner" default="0,0" type="SIZE" comment="窗口圆角大小,如(4,4)"/>

<Attribute name="mininfo" default="0,0" type="SIZE" comment="窗口最小大小,如(320,240)"/>

<Attribute name="maxinfo" default="0,0" type="SIZE" comment="窗口最大大小,如(1600,1200)"/>

<Attribute name="alpha" default="255" type="BYTE" comment="窗口的alpha值(0-255),如(100)"/>

<Attribute name="bktrans" default="false" type="BOOL" comment="窗口是否使用静态透明背景,如(false)"/>

<Attribute name="disabledfontcolor" default="0xFFA7A6AA" type="DWORD" comment="默认的disabled字体颜色,如(0xFFA7A6AA)"/>

<Attribute name="defaultfontcolor" default="0xFF000000" type="DWORD" comment="默认的字体颜色,如(0xFF000000)"/>

<Attribute name="linkfontcolor" default="0xFF0000FF" type="DWORD" comment="默认的link字体颜色,如(0xFF0000FF)"/>

<Attribute name="linkhoverfontcolor" default="0xFFD3215F" type="DWORD" comment="默认的linkhoverfont字体颜色,如(0xFFD3215F)"/>

<Attribute name="selectedcolor" default="0xFFBAE4FF" type="DWORD" comment="默认的selected字体颜色,如(0xFFBAE4FF)"/>

<Attribute name="showdirty" default="false" type="BOOL" comment="绘制脏矩形(屏幕上更新的区域被称为脏矩形)"/>

</Window>

<ChildLayout parent="Container" >

<Attribute name="xmlfile" default="" type="STRING" comment="子窗体XML布局文件"/>

</ChildLayout>

<Control parent="" notifies="setfocus killfocus timer menu windowinit(root)">

<Attribute name="name" default="" type="STRING" comment="控件名字,同一窗口内必须唯一,如(testbtn)"/>

<Attribute name="pos" default="0,0,0,0" type="RECT" comment="位置,如果为float控件则指定位置和大小,否则只指定大小,如(0,0,100,100)"/>

<Attribute name="padding" default="0,0,0,0" type="RECT" comment="外边距,如(2,2,2,2)"/>

<Attribute name="bkcolor" default="0x00000000" type="DWORD" comment="背景颜色,如(0xFFFF0000)"/>

<Attribute name="bkcolor2" default="0x00000000" type="DWORD" comment="背景渐变色2,和bkcolor配合使用,如(0xFFFFFF00)"/>

<Attribute name="bkcolor3" default="0x00000000" type="DWORD" comment="背景渐变色3,和bkcolor、bkcolor2配合使用,如(0xFFFF00FF)"/>

<Attribute name="bordercolor" default="0x00000000" type="DWORD" comment="边框颜色,如(0xFF000000)"/>

<Attribute name="focusbordercolor" default="0x00000000" type="DWORD" comment="获得焦点时边框的颜色,如(0xFFFF0000)"/>

<Attribute name="colorhsl" default="false" type="BOOL" comment="本控件的颜色是否随窗口的hsl变化而变化,如(false)"/>

<Attribute name="bordersize" default="0" type="INT | RECT" comment="可以设置INT或RECT类型的值。当值为ING时则左、上、右、下都用该值作为宽。值为RECT类型时则分别设置左、上、右、下的边框"/>

<Attribute name="leftbordersize" default="0" type="INT" comment="左边边框大小,如(1),设置该值大于0,则将忽略bordersize属性的设置"/>

<Attribute name="topbordersize" default="0" type="INT" comment="顶部边框大小,如(1),设置该值大于0,则将忽略bordersize属性的设置"/>

<Attribute name="rightbordersize" default="0" type="INT" comment="右边边框大小,如(1),设置该值大于0,则将忽略bordersize属性的设置"/>

<Attribute name="bottombordersize" default="0" type="INT" comment="底部边框大小,如(1),设置该值大于0,则将忽略bordersize属性的设置"/>

<Attribute name="borderstyle" default="0" type="INT" comment="边框样式的设置,数值范围0-5"/>

<Attribute name="borderround" default="0,0" type="SIZE" comment="边框圆角半径,如(2,2)"/>

<Attribute name="bkimage" default="" type="STRING" comment="背景图片,如(bk.bmp或file='aaa.jpg' res='' restype='0' dest='0,0,0,0' source='0,0,0,0' corner='0,0,0,0' mask='#FF0000' fade='255' hole='false' xtiled='false' ytiled='false')"/>

<Attribute name="width" default="0" type="INT" comment="控件预设的宽度,如(100)"/>

<Attribute name="height" default="0" type="INT" comment="控件预设的高度,如(30)"/>

<Attribute name="minwidth" default="0" type="INT" comment="控件的最小宽度,如(100)"/>

<Attribute name="minheight" default="0" type="INT" comment="控件的最小高度,如(30)"/>

<Attribute name="maxwidth" default="9999" type="INT" comment="控件的最大宽度,如(100)"/>

<Attribute name="maxheight" default="9999" type="INT" comment="控件的最大高度,如(30)"/>

<Attribute name="text" default="" type="STRING" comment="显示文本,如(测试文本)"/>

<Attribute name="tooltip" default="" type="STRING" comment="鼠标悬浮提示,如(请在这里输入你的密码)"/>

<Attribute name="userdata" default="" type="STRING" comment="自定义标识"/>

<Attribute name="enabled" default="true" type="BOOL" comment="是否可以响应用户 *** 作,如(true)"/>

<Attribute name="mouse" default="true" type="BOOL" comment="本控件是否可以响应鼠标 *** 作,如(true)"/>

<Attribute name="visible" default="true" type="BOOL" comment="是否可见,如(true)"/>

<Attribute name="float" default="false" type="BOOL" comment="是否使用绝对定位,如(true)"/>

<Attribute name="shortcut" default="" type="CHAR" comment="对应的快捷键,如(P)"/>

<Attribute name="menu" default="false" type="BOOL" comment="是否需要右键菜单,如(true)"/>

<Attribute name="keyboard" default="true" type="BOOL" comment="非CButtonUI类忽略该值,为false时不支持TAB_STOP,且该对象不处理键盘信息"/>

</Control>

<Container parent="Control" notifies="setfocus killfocus timer menu windowinit(root)">

<Attribute name="name" default="" type="STRING" comment="控件名字,同一窗口内必须唯一,如(testbtn)"/>

<Attribute name="pos" default="0,0,0,0" type="RECT" comment="位置,如果为float控件则指定位置和大小,否则只指定大小,如(0,0,100,100)"/>

<Attribute name="padding" default="0,0,0,0" type="RECT" comment="外边距,如(2,2,2,2)"/>

<Attribute name="bkcolor" default="0x00000000" type="DWORD" comment="背景颜色,如(0xFFFF0000)"/>

<Attribute name="bkcolor2" default="0x00000000" type="DWORD" comment="背景渐变色2,和bkcolor配合使用,如(0xFFFFFF00)"/>

<Attribute name="bkcolor3" default="0x00000000" type="DWORD" comment="背景渐变色3,和bkcolor、bkcolor2配合使用,如(0xFFFF00FF)"/>

<Attribute name="bordercolor" default="0x00000000" type="DWORD" comment="边框颜色,如(0xFF000000)"/>

<Attribute name="focusbordercolor" default="0x00000000" type="DWORD" comment="获得焦点时边框的颜色,如(0xFFFF0000)"/>

<Attribute name="colorhsl" default="false" type="BOOL" comment="本控件的颜色是否随窗口的hsl变化而变化,如(false)"/>

<Attribute name="bordersize" default="1" type="INT" comment="边框大小,如(1)"/>

<Attribute name="borderround" default="0,0" type="SIZE" comment="边框圆角半径,如(2,2)"/>

<Attribute name="bkimage" default="" type="STRING" comment="背景图片,如(bk.bmp或file='aaa.jpg' res='' restype='0' dest='0,0,0,0' source='0,0,0,0' corner='0,0,0,0' mask='#FF0000' fade='255' hole='false' xtiled='false' ytiled='false')"/>

<Attribute name="width" default="0" type="INT" comment="控件预设的宽度,如(100)"/>

<Attribute name="height" default="0" type="INT" comment="控件预设的高度,如(30)"/>

<Attribute name="minwidth" default="0" type="INT" comment="控件的最小宽度,如(100)"/>

<Attribute name="minheight" default="0" type="INT" comment="控件的最小高度,如(30)"/>

<Attribute name="maxwidth" default="9999" type="INT" comment="控件的最大宽度,如(100)"/>

<Attribute name="maxheight" default="9999" type="INT" comment="控件的最大高度,如(30)"/>

<Attribute name="text" default="" type="STRING" comment="显示文本,如(测试文本)"/>

<Attribute name="tooltip" default="" type="STRING" comment="鼠标悬浮提示,如(请在这里输入你的密码)"/>

<Attribute name="userdata" default="" type="STRING" comment="自定义标识"/>

<Attribute name="enabled" default="true" type="BOOL" comment="是否可以响应用户 *** 作,如(true)"/>

<Attribute name="mouse" default="true" type="BOOL" comment="本控件是否可以响应鼠标 *** 作,如(true)"/>

<Attribute name="mousechild" default="true" type="BOOL" comment="本控件的子控件是否可以响应用户 *** 作,如(true)"/>

<Attribute name="visible" default="true" type="BOOL" comment="是否可见,如(true)"/>

<Attribute name="float" default="false" type="BOOL" comment="是否使用绝对定位,如(true)"/>

<Attribute name="shortcut" default="" type="CHAR" comment="对应的快捷键,如(P)"/>

<Attribute name="menu" default="false" type="BOOL" comment="是否需要右键菜单,如(true)"/>

<Attribute name="inset" default="0,0,0,0" type="RECT" comment="容器的内边距,如(2,2,2,2)"/>

<Attribute name="vscrollbar" default="false" type="BOOL" comment="是否使用竖向滚动条,如(true)"/>

<Attribute name="hscrollbar" default="false" type="BOOL" comment="是否使用横向滚动条,如(true)"/>

<Attribute name="childpadding" default="0" type="INT" comment="子控件之间的额外距离,如(4)"/>

</Container>

<VerticalLayout parent="Container" notifies="setfocus killfocus timer menu windowinit(root)">

<Attribute name="name" default="" type="STRING" comment="控件名字,同一窗口内必须唯一,如(testbtn)"/>

<Attribute name="pos" default="0,0,0,0" type="RECT" comment="位置,如果为float控件则指定位置和大小,否则只指定大小,如(0,0,100,100)"/>

<Attribute name="padding" default="0,0,0,0" type="RECT" comment="外边距,如(2,2,2,2)"/>

<Attribute name="bkcolor" default="0x00000000" type="DWORD" comment="背景颜色,如(0xFFFF0000)"/>

<Attribute name="bkcolor2" default="0x00000000" type="DWORD" comment="背景渐变色2,和bkcolor配合使用,如(0xFFFFFF00)"/>

<Attribute name="bkcolor3" default="0x00000000" type="DWORD" comment="背景渐变色3,和bkcolor、bkcolor2配合使用,如(0xFFFF00FF)"/>

<Attribute name="bordercolor" default="0x00000000" type="DWORD" comment="边框颜色,如(0xFF000000)"/>

<Attribute name="focusbordercolor" default="0x00000000" type="DWORD" comment="获得焦点时边框的颜色,如(0xFFFF0000)"/>

<Attribute name="colorhsl" default="false" type="BOOL" comment="本控件的颜色是否随窗口的hsl变化而变化,如(false)"/>

<Attribute name="bordersize" default="1" type="INT" comment="边框大小,如(1)"/>

<Attribute name="borderround" default="0,0" type="SIZE" comment="边框圆角半径,如(2,2)"/>

<Attribute name="bkimage" default="" type="STRING" comment="背景图片,如(bk.bmp或file='aaa.jpg' res='' restype='0' dest='0,0,0,0' source='0,0,0,0' corner='0,0,0,0' mask='#FF0000' fade='255' hole='false' xtiled='false' ytiled='false')"/>

<Attribute name="width" default="0" type="INT" comment="控件预设的宽度,如(100)"/>

<Attribute name="height" default="0" type="INT" comment="控件预设的高度,如(30)"/>

<Attribute name="minwidth" default="0" type="INT" comment="控件的最小宽度,如(100)"/>

<Attribute name="minheight" default="0" type="INT" comment="控件的最小高度,如(30)"/>

<Attribute name="maxwidth" default="9999" type="INT" comment="控件的最大宽度,如(100)"/>

<Attribute name="maxheight" default="9999" type="INT" comment="控件的最大高度,如(30)"/>

<Attribute name="text" default="" type="STRING" comment="显示文本,如(测试文本)"/>

<Attribute name="tooltip" default="" type="STRING" comment="鼠标悬浮提示,如(请在这里输入你的密码)"/>

<Attribute name="userdata" default="" type="STRING" comment="自定义标识"/>

<Attribute name="enabled" default="true" type="BOOL" comment="是否可以响应用户 *** 作,如(true)"/>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11761794.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存