Silverlight布局系統正確優化方法
Silverlight的開發工具的使用之所以能被廣大開發者們所接受,除了其功能的強大之外,還有一點就是應用的靈活性。它的各種特點決定了其在這一領域中的領先地位。在這里我們將會為大家介紹一下Silverlight布局系統的優化方法。#t#
我對Silverlight布局系統一直感到不滿,原因無他,太過羅嗦爾。它靈活是足夠靈活了,但對于界面布局并沒有提供一個簡潔的表達機制,使得即使非常常見的界面也總是生成一大坨又臭又長的XAML,寫得累,看的人更累。特別是和競爭對手Flex的布局機制比較,Flex可以說既靈活又簡單,Silverlight則是既靈活又麻煩。
Silverlight里面常用的布局容器幾乎都可以挑挑毛病:
Canvas:只支持絕對坐標布局使得Canvas在應用程序布局方面純粹是個雞肋,要求稍微靈活一點的界面就派不上用場了。Flex也有一個Canvas,不過Flex Canvas支持左/中/右對齊,并且可以指定絕對寬度或相對寬度,所以Flex Canvas比Silverlight Canvas要好用得多,在各種界面布局里也是常見的選擇。
StackPanel:StackPanel不支持Grid的百分比布局是很大的遺憾。很多時候,我只需要單行或單列布局,但控件則需要絕對/相對混合布局,StackPanel不能提供這種靈活性。這使得我不得不使用語法更加羅嗦的Grid。
Grid:如果和GridSplitter聯合做多面板布局的話,99%的情況下需要關心的無非是左右或上下兩個面板,而Grid和GridSplitter需要指定一大堆屬性才能正常工作,增加了無謂的負擔。
在忍受這些毛病很長時間以后,我終于決定拋開Silverlight的默認布局容器,自己寫一套更加方便的自定義Silverlight布局系統管理器。你可以猜到,我寫的這套容器很大程度上參考了Flex,甚至大部分類的命名都向Flex看齊——比如HBox、VBox。和Silverlight內置類沖突的則換個名字,比如FlexCanvas模擬了Flex的Canvas組件,HSplitBox相當于Flex HDevideBox,HeaderBox相當于Flex Panel。
編寫自定義容器實際上比原先想象的要簡單,無非是實現MeasureOverride/ArrangeOverride兩個方法而已。只是要考慮到各種布局情況需要仔細計算。另外一點不滿的地方是,創建Dependency Property的語法純粹是折磨人的工作。
這里僅舉一個常見的Silverlight布局系統例子,你可以比較一下用自定義布局可以比默認的布局系統節省多少代碼。
例子: 我們都很熟悉的瀏覽器地址欄,文本框隨容器自動擴展。
用Silverlight布局:
- < Grid>
- < Grid.ColumnDefinations>
- < ColumnDefination Width="Auto" />
- < ColumnDefination Width="*" />
- < ColumnDefination Width="Auto" />
- < /Grid.ColumnDefinations>
- < TextBlock Grid.Column="0"
Text="Address" />- < TextBox Grid.Column="1" />
- < Button Grid.Column="2"
Content="Go" />- < /Grid>
自定義布局:
- < yh:HBox>
- < TextBlock Text="Address" />
- < TextBox yh:Box.Width="100%" />
- < Button Content="Go" />
- < /yh:HBox>
Silverlight布局系統的介紹就到這里,希望對大家有些幫助。