Duilib教程-自动布局1
我們要實(shí)現(xiàn)一個(gè)帶標(biāo)題欄和狀態(tài)欄的程序,同時(shí)要支持拉伸,即包括最小化、最大化,圖如下:
?
XML:
<?xml version="1.0" encoding="utf-8" standalone="yes" ?><Window size="695,542"><VerticalLayout width="657" height="517" bkcolor="#FFA0A0A4"><HorizontalLayout name="title" height="32" bkcolor="#FF63A6F1"><Button text="X" bordersize="1" float="true" pos="608,0,0,0" width="60" height="30" bkcolor="#FF008067" bkcolor2="#0000C020" bordercolor="#00FFFF00" textcolor="#FF000000" disabledtextcolor="#FFA7A6AA" align="center" /></HorizontalLayout><HorizontalLayout name="mid" bkcolor="#FFBABABA" /><HorizontalLayout name="status" height="30" bkcolor="#FF808080" /></VerticalLayout></Window>?
在DUIDesigner中,拖動(dòng)窗口邊框,即可看到效果,標(biāo)題欄和狀態(tài)欄的位置都不變,即隨窗口大小而改變。
?
看屬性,發(fā)現(xiàn),status和title都有屬性 height,而中間的,什么屬性都沒有。在窗口設(shè)置如下:
title:
mid:
?
可以知道,pos即可以設(shè)置float屬性為false的拉伸操作,所以不只是LAYOUT可以隨窗口(準(zhǔn)確的說應(yīng)該是擁有它的LAYOUT)自由拉伸,普通的控件也可以,只要float為false。
?
Float意思為浮動(dòng),當(dāng)它為TRUE時(shí),它就浮動(dòng)在窗口上面,位置永遠(yuǎn)不會(huì)變(相對(duì)于擁有它的LAYOUT)。
當(dāng)它為FALSE時(shí),它浮不起來,停在水上,隨波逐流,所以能夠被流水(LAYOUT)改變它的大小。
?
注意,只有right和bottom才有效。如果不為0,那么它就是該高度,即不隨父LAYOUT改變大小(位置不能更改)。為0就是跟父LAYOUT更改大小。
?
在上面這個(gè)示例中,關(guān)閉按鈕并不隨著窗口改變位置,因?yàn)槲覀兛吹搅?#xff0c;它的float為TRUE。如果我們想要它永遠(yuǎn)停在最右邊呢?
看下面的XML:
<?xml version="1.0" encoding="utf-8" standalone="yes" ?><Window size="695,542"><VerticalLayout width="657" height="517" bkcolor="#FFA0A0A4"><HorizontalLayout name="title" height="32" bkcolor="#FF63A6F1"><Control /><Button text="X" bordersize="1" maxwidth="60" pos="608,0,0,0" width="60" height="30" bkcolor="#FF008067" bkcolor2="#0000C020" bordercolor="#00FFFF00" textcolor="#FF000000" disabledtextcolor="#FFA7A6AA" align="center" /></HorizontalLayout><HorizontalLayout name="mid" bkcolor="#FFBABABA" /><HorizontalLayout name="status" height="30" bkcolor="#FF808080" /></VerticalLayout></Window>?
我們加了一個(gè) float 的 Control,以及將關(guān)閉按鈕的 maxwidth設(shè)置為60,同時(shí)FLOAT設(shè)置為FALSE(float屬性默認(rèn)為false)。
?
這樣設(shè)置的意思是:關(guān)閉按鈕最大寬度為60,所以它不能被拉得更寬。
在它的左邊有一個(gè)FLOAT,它可以被任意拉伸。所以當(dāng)窗口被拉伸時(shí),關(guān)閉按鈕為60,左邊的control就被拉伸到?窗口寬 - 60。
?
如果最右邊要加最大化、最小化按鈕,實(shí)現(xiàn)原理也是一樣的。當(dāng)然,你可以在最右邊加一個(gè)LAYOUT,在這個(gè)LAYOUT上加上最小化、最大化、關(guān)閉按鈕,這樣層次感更強(qiáng),也更容易管理和修改。
總結(jié)
以上是生活随笔為你收集整理的Duilib教程-自动布局1的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Duilib教程-非DUI控件
- 下一篇: Duilib教程-自动布局2