duilib进阶教程 -- Container控件 (3)

  前面两个教程的目的是教大家与MFC结合,那么从这篇起,将不再使用MFC,而使用纯win32项目,本文的所有知识已经在《duilib入门教程》里面讲过了,因此基础知识不再赘述。

  代码下载:http://download.csdn.net/detail/qq316293804/6433161

  效果如下(可拖拽边缘调节窗口大小,图片会自动居中)

  此例子唯一需要说明的就是XML,代码如下:

<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<Window size="800,520" sizebox="4,4,4,4" caption="0,0,0,32" mininfo="600,400">
    <VerticalLayout bkcolor="#FF070700">
        <HorizontalLayout height="40" />
        <HorizontalLayout>
            <VerticalLayout />
            <VerticalLayout width="336" bkimage="skin\bk_logo_light.png">
                <HorizontalLayout />
                <HorizontalLayout height="164" bkimage="skin\bk_logo_image.png">
                    <HorizontalLayout>
                        <VerticalLayout />
                        <VerticalLayout width="168">
                            <VerticalLayout height="40" />
                            <VerticalLayout height="20" bkimage="skin\bk_logo_text.png" />
                            <VerticalLayout />
                        </VerticalLayout>
                        <VerticalLayout />
                    </HorizontalLayout>
                </HorizontalLayout>
                <HorizontalLayout />
            </VerticalLayout>
            <VerticalLayout />
        </HorizontalLayout>
        <HorizontalLayout height="50" />
    </VerticalLayout>
</Window>

  可以看到到处都是HorizontalLayout 、VerticalLayout,然后几个bkimage也很乱,这里有几个原因:

  1、由于迅雷的中间那一块是由三个图片组成,所以布局很麻烦,其实用一张图片的话,就简洁很多了,这里估计是为了重用图片。

  2、方式不太对。

  如果中间只有一个图片的话,按照上面的XML布局就很简洁了,但由于有三个图片,这三个图片都需要自适应窗口大小,所以才造成上面的XML代码那么乱,那么有没有优化的地方呢?

  当然有,在《入门教程》里我们还有一个控件没有介绍,那就是Container,顾名思义就是容器控件,容器控件有什么用呢? 它的用处就是可以使子窗口的行为随着Container一致变化。比如我们的窗口有10个按钮,如果没放在Container里的话,那么想要隐藏所有控件,就必须调用10次隐藏函数,如果想将所有控件往左移的话,也需要操作10次,同样,上面因为有3个图片,所以为了让他们都适应窗口大小,我们做了3次布局。而如果这些控件都在Container里的话,那就方便多了,就算有100个按钮,如果要隐藏的话,我们只需要调用1次隐藏函数,即隐藏Container控件即可,这样它的子控件都会隐藏。同样,如果把上面3个图片都放到Container里去,我们的XML代码就简明多啦,优化后的代码如下:

<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<Window size="800,520" sizebox="4,4,4,4" caption="0,0,0,32" mininfo="600,400">
    <VerticalLayout bkcolor="#FF070700">
        <HorizontalLayout height="40" />
        <HorizontalLayout>
            <VerticalLayout />
            <VerticalLayout width="336">
                <HorizontalLayout />
                <Container height="290">
                    <Control float="true" pos="0,0,0,0" width="336" height="230" bkimage="skin\bk_logo_light.png" />
                    <Control float="true" pos="1,1,0,0" width="336" height="164" bkimage="skin\bk_logo_image.png" />
                    <Control float="true" pos="84,38,0,0" width="168" height="20" bkimage="skin\bk_logo_text.png" />
                </Container>
                <HorizontalLayout />
            </VerticalLayout>
            <VerticalLayout />
        </HorizontalLayout>
        <HorizontalLayout height="50" />
    </VerticalLayout>
</Window>

  可以看到bkimage都在一起了,HorizontalLayout、VerticalLayout 也不那么乱了,Container控件暂时就讲到这里啦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值