wpf xaml突然不能自动补齐代码_Xaml+C#桌面客户端跨平台初体验
(給DotNet加星標,提升.Net技能)
轉自:大頭BigHeadcnblogs.com/Big-Head/p/12614118.html前言
隨著 .NET 5的到來,微軟在 .NET跨平臺路上又開始了一個更高的起點。
回顧.NET Core近幾年的成果,可謂是讓.NET重生了一次.
ASP .NET Core跨平臺解決了Windows服務器昂貴的費用和不能長時間待機的問題,讓Asp程序能夠跑在Linux甚至Mac上。
從博客園里.NET分類可以看到,每天都可以涌現大批ASP .NET Core的技術文章,越來越多的開發者或者公司開始嘗試這個船新的跨平臺框架。
然鵝,ASP的跨平臺是能夠使用html作為UI,C#作為后臺代碼完成的,html本來就是原生支持跨平臺的語言。如果要到達在客戶端方面的跨平臺,仍需要走很長一段路。
早些年的時候。微軟使用鈔能力收購了移動客戶端跨平臺開發的大佬Mono,并組建了新的Xamarin,一次開發就可以生成Android,iOS,UWP平臺的App,但也僅僅停留在移動客戶端跨平臺。
同樣在民間一些大佬的努力下,也創造出了很多PC跨平臺的輪子
比如:Electron.Net,GTK#,Qt#等等,這些框架都是使用Html或者Mono平臺的內容達到UI跨平臺的,而今天我則要推薦一款新的跨平臺方案AvaloniaUI。
準備
一個Linux的機器
這里推薦使用windows 10下的linux子系統,可以快速的在windows上操作linux子系統的文件目錄,用來快速上傳編譯的程序到linux。詳細操作可以看這篇文章啟用Windows10的Linux子系統并安裝圖形界面。
當然使用實體機,或者服務器都可以??傊罱K目的就是有一個可以連接帶圖形化界面的Linux系統。
安裝.Net Core Runtime
微軟官方給出了在Ubutnu安裝.Net Core的方法,這里我以Ubuntu為例,其他發行版本使用對應的包管理命令
1、注冊 Microsoft 密鑰和源
wget https://packages.microsoft.com/config/ubuntu/19.04/packages-microsoft-prod.deb -O packages-microsoft-prod.debsudo dpkg -i packages-microsoft-prod.deb
2、安裝.Net Core 3.1 Runtmime
sudo apt-get updatesudo apt-get install apt-transport-https
sudo apt-get update
sudo apt-get install dotnet-runtime-3.1
更多詳情可參考Microsoft Docs :Ubuntu 19.04 包管理器 - 安裝 .NET Core。
https://docs.microsoft.com/zh-cn/dotnet/core/install/linux-package-manager-ubuntu-1904
安裝VS拓展
如果VS拓展下載太慢,可以使用下面的網盤鏈接下載。
鏈接: https://pan.baidu.com/s/1sYnpC37IcH2VKQKjmqBALw 提取碼: wyqn
WPF/UWP的經驗
1、Xaml的語法
2、C#
3、最好了解MVVM模式或者ReactiveUI
Code
創建一個AvaloniaUI的項目
了解WPF/UWP通知模式的童鞋可以使用MVVM
項目結構
和WPF/UWP很相似的結構,但是不同的是Program.cs被重寫了
class Program{
// Initialization code. Don't use any Avalonia, third-party APIs or any
// SynchronizationContext-reliant code before AppMain is called: things aren't initialized
// yet and stuff might break.
public static void Main(string[] args) => BuildAvaloniaApp()
.StartWithClassicDesktopLifetime(args);
// Avalonia configuration, don't remove; also used by visual designer.
public static AppBuilder BuildAvaloniaApp()=> AppBuilder.Configure()
.UsePlatformDetect()
.LogToDebug()
.UseReactiveUI();
}
MainWindow.Xaml
可以說和WPF/Xaml大致一模一樣了,但是體驗不太好地就是在Xaml標簽頁的智能提示和顯示內容體驗,以及右側的實時渲染窗口是一幀一幀地刷新整個頁面。
ViewModel
Avalonia UI使用地是ReactiveUI來做的界面綁定和響應。和以往使用MVVMLight不同,綁定命令不用RelayCommand,而是直接在xaml綁定一個后臺的方法名。
發布
編碼完成在windows上測試通過之后,就可以把程序打包發到其他平臺上測試了。這里以Linux為例:
Alt+B-->選擇發布
根據目標平臺選擇配置保存。
點擊發布,稍等片刻。
跨平臺運行
以linux為例:
1、將Publish的文件夾上傳到Linux上
2、找到對應的程序名(沒有任何后綴),更改權限為”允許此文件作為程序運行“
3、雙擊運行,即可看到和Windows上一模一樣的效果。
問題
由于AvaloniaUI不是微軟官方出品,而是民間團隊開發,且目前仍處于預覽。我羅列一些自己遇到問題時的解決方案
1、嘗試Nuget把AvaloniaUI的包更新到最新
2、保證開發的.netcore配置比運行環境的.net core版本低
3、*字體渲染問題
這個問題是我遇到的最嚴重的問題,直接導致程序都不能渲染出來。如果有遇到這個問題的同學,可以首先在Program.cs下的Main函數里面加兩行代碼:
Console.WriteLine(SKTypeface.Default.FamilyName);Console.WriteLine(SKTypeface.FromFamilyName("Sans").FamilyName);
然后在linux里使用控制臺來運行程序,定位到程序目錄,更改程序權限為可執行程序
chmod -x 程序名運行程序
./程序名如果出現權限不足的可以使用如下
chmod 777 程序名如果運行程序后,控制臺打印了NullRefrence的錯誤,那就是缺少默認字體。估計是AvaloniaUI的團隊設置了程序的默認字體”Sans“。
只需要替換軟件默認字體就可以了,這里我使用微軟雅黑
<Applicationx:Class="AvaloniaTest.App"xmlns="https://github.com/avaloniaui"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="clr-namespace:AvaloniaTest"><Application.DataTemplates>
<local:ViewLocator />
Application.DataTemplates>
<Application.Resources>
<FontFamily x:Key="yh">微軟雅黑FontFamily>
Application.Resources>
<Application.Styles>
<StyleInclude Source="avares://Avalonia.Themes.Default/DefaultTheme.xaml" />
<StyleInclude Source="avares://Avalonia.Themes.Default/Accents/BaseLight.xaml" />
<Style Selector="Window">
<Setter Property="FontFamily" Value="{StaticResource yh}" />
Style>
Application.Styles>
Application>
并且需要在linux安裝微軟雅黑的字體
sudo apt-get install ttf-mscorefonts-installer博客園之前也有一位大佬體驗AvaloniaUI時候遇到字體的問題,可是他的樹莓派是可以渲染出窗體只是沒有文字,但是我測試了好幾個發行版本都是窗體都不渲染。大家可以參考一下他的文章樹莓派 Raspberry Pi 4,.net core 3.0 ,Avalonia UI 開發
運行效果
我嘗試使用Face++的 API接口,測試寫了一個有網絡請求的摳圖程序
Windows:
Linux:
其他
貼出一些參考網站給大家
官網:http://avaloniaui.net/
GitHub:https://github.com/AvaloniaUI/Avalonia
樹莓派使用AvaloniaUI:https://www.cnblogs.com/drzhong/p/11678701.html
Mac使用AvaloniaUI:https://www.cnblogs.com/seamas/p/11245348.html
你所不知道的C#中的細節
.NET Core使用NPOI導出復雜美觀的ExcelASP.NET Core AutoWrapper 自定義響應輸出看完本文有收獲?請轉發分享給更多人
關注「DotNet」加星標,提升.Net技能?
好文章,我在看??
總結
以上是生活随笔為你收集整理的wpf xaml突然不能自动补齐代码_Xaml+C#桌面客户端跨平台初体验的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux windows文件 编码_M
- 下一篇: dubbo官方文档_狂神说SpringB