Avalonia-.NET 的跨平台 UI 框架
簡介
Avalonia 是 dotnet 的跨平臺 UI 框架,提供靈活的樣式系統并支持 Windows、Linux、macOS 等多種操作系統。Avalonia 已經成熟并且可以投入生產。我們還在測試版中支持 iOS、Android,并在早期階段通過 WASM 支持瀏覽器。
使用
在WPF中,當你在xaml文件中定義完UI并設置x:Name就可以在后臺中直接使用對象名稱進行操作.那是因為vs在你設計時自動生成了.g.i.cs文件(你可以在/obj中看到)
而ava中不同,你需要在后臺中自己Get到這個UI對象(與Android類似): 例如:
axaml中定義一個名稱為 TB_Title的TextBlock文本標簽:
<TextBlock?x:Name="TB_Title"?HorizontalAlignment="Center"?Foreground="White"?FontSize="14"?VerticalAlignment="Center"?Margin="10,0,0,10"?Text="My?Avalonia?Desktop?App"/>在cs中定義并更改標簽內容:
TextBlock?TB_Title?=?this.Get<TextBlock>("TB_Title"); TB_Title.Text?=?"嘻嘻";這里就用到了this.Get(string Name)方法
T:表示對象類型 Name:為x:Name中定義的名稱
注意:在后臺查找UI對象 若不是局部變量 應需考慮 時序問題 否則在使用時對象可能是null
建議將所有的控件優先查找出來(如果你控制得比較好可以不用..)
有幾點比較坑的地方:
1.直接在axaml中定義事件有時候不會成功,可以在后臺中定義,例如:
<Button?x:Name="btn"?Click="Btn_Click">Click?Me</Button> void?Btn_Click(object?sender,?RoutedEventArgs?args) {//... }若不成功可以:
this.Get<Button>("btn").Click+=Btn_Click;當然還有很多更加強大的功能,請查閱官方文檔
文檔地址
https://docs.avaloniaui.net/docs/getting-started/programming-with-avalonia
Github地址
https://github.com/AvaloniaUI/Avalonia?
最后大家如果喜歡我的文章,還麻煩給個關注并點個贊, 希望net生態圈越來越好!
總結
以上是生活随笔為你收集整理的Avalonia-.NET 的跨平台 UI 框架的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C# Barrier类
- 下一篇: AgileConfig 1.6.0 发布