【.NET6+Avalonia】开发支持跨平台的仿WPF应用程序以及基于ubuntu系统的演示
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><strong><span style="font-size: 14pt">前言:</span></strong><span style="font-family: 楷体, "Kaiti SC"">随着跨平台越来越流行,.net core支持跨平台至今也有好几年的光景了。但是目前基于.net的跨平台,大多数还是在使用B/S架构的跨平台上;至于C/S架构,大部分人可能会选择QT进行开发,或者很早之前还有一款Mono可以支持.NET开发者进行开发跨平台应用。</span></span></p><p><span style="font-family: 楷体, "Kaiti SC"; font-size: 18px">以下内容,我使用Avalonia UI框架来开发支持可以跨平台的应用程序(仿WPF程序)。</span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">前提准备:</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">开发环境:Win10+VS2022企业版</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">运行环境:Win10 & Ubuntu20.04 LTS</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">.NET环境: .NET 6</span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">以下,正文:</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">0、在开始之前,需要添加一个拓展,名称叫 Avalonia for Visual Studio xxxx。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">安装完成以后,需要关闭所有当前运行的VS,然后会提示安装。选择安装即可。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002427828-1133962187.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">1、添加拓展成功以后,在创建新项目里面,创建项目时候,会多出两个项目选项。一个是无双向绑定的项目,另一个是基于MVVM双向绑定的项目。此处,我选择基于MVVM双向绑定的项目。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002449466-315543015.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">2、配置项目时候,最好对项目名称进行小写。大写可能Linux系统在识别的时候会有某些意想不到的bug(人品好的可能没有,人品不好的可以自行测试)。此处我的项目名称命名为linuxwpf</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002504956-480587762.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">3、新建的项目,初始项目文件以及代码,如下图所示。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002517435-360512822.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">4、直接运行,运行以后的画面,如下图所示。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002529581-1899901709.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">5、咱们改造一下,写一个按钮,然后点击弹出提示框,意思一下。此处需要引入nuget包:MessageBox.Avalonia</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002541322-275014167.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">6、引入nuget包以后,对主窗体页面进行改写,提供了个button,并且在对应的VM里面,添加一个Running方法,用于当做点击触发的绑定方法。同时方法里面提供了一个弹出消息提示框的功能。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002556775-1103497276.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">7、运行,验证一下,结果如图所示。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002606804-1179622836.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">8、按钮绑定的方法,还可以传输参数,如下图所示。跟往常传统的WPF双向绑定基本一致。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002619710-788366479.png" alt=""></span></p>
<p> </p>
<p>以上代码:VM部分:</p>
<div class="cnblogs_code">
<pre> <span style="color: rgba(0, 0, 255, 1)">public</span> <span style="color: rgba(0, 0, 255, 1)">class</span><span style="color: rgba(0, 0, 0, 1)"> MainWindowViewModel : ViewModelBase
{
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> public string Greeting => "Welcome to Avalonia!";</span>
<span style="color: rgba(0, 0, 255, 1)">public</span> <span style="color: rgba(0, 0, 255, 1)">void</span> Running(<span style="color: rgba(0, 0, 255, 1)">string</span><span style="color: rgba(0, 0, 0, 1)"> msg)
{
</span><span style="color: rgba(0, 0, 255, 1)">var</span> message = MessageBox.Avalonia.MessageBoxManager.GetMessageBoxStandardWindow(<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">标题</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">,msg);
message.Show();
}
}</span></pre>
</div>
<p>axaml部分:</p>
<div class="cnblogs_code">
<pre><Window xmlns=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">https://github.com/avaloniaui</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
xmlns:x</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">http://schemas.microsoft.com/winfx/2006/xaml</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
xmlns:vm</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">using:linuxwpf.ViewModels</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
xmlns:d</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">http://schemas.microsoft.com/expression/blend/2008</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
xmlns:mc</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">http://schemas.openxmlformats.org/markup-compatibility/2006</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
mc:Ignorable</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">d</span><span style="color: rgba(128, 0, 0, 1)">"</span> d:DesignWidth=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">800</span><span style="color: rgba(128, 0, 0, 1)">"</span> d:DesignHeight=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">450</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
x:Class</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">linuxwpf.Views.MainWindow</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
Icon</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">/Assets/avalonia-logo.ico</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">
Title</span>=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">linuxwpf</span><span style="color: rgba(128, 0, 0, 1)">"</span>>
<Design.DataContext>
<vm:MainWindowViewModel/>
</Design.DataContext>
<!--<TextBlock Text=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">{Binding Greeting}</span><span style="color: rgba(128, 0, 0, 1)">"</span> HorizontalAlignment=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">Center</span><span style="color: rgba(128, 0, 0, 1)">"</span> VerticalAlignment=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">Center</span><span style="color: rgba(128, 0, 0, 1)">"</span>/>-->
<Button Command=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">{Binding Running}</span><span style="color: rgba(128, 0, 0, 1)">"</span>CommandParameter=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">Hello World</span><span style="color: rgba(128, 0, 0, 1)">"</span> Content=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">点我</span><span style="color: rgba(128, 0, 0, 1)">"</span> HorizontalAlignment=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">Center</span><span style="color: rgba(128, 0, 0, 1)">"</span> VerticalAlignment=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">Center</span><span style="color: rgba(128, 0, 0, 1)">"</span>/>
</Window></pre>
</div>
<p> </p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">9、运行结果,如下图所示。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002633855-440580525.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">10、接下来,咱们把它部署到Linux系统上去实验一下。需要先创建个 xxx.desktop文件,用于指定可执行文件路径、快捷图标路径有关。其中,png图片随便搞一个就行。同时,需要对新增的这俩文件,属性设置为“始终复制”。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002646892-1067877813.png" alt=""></span></p>
<p> </p>
<p>以上配置代码:</p>
<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 0, 1)">
Name</span>=<span style="color: rgba(0, 0, 0, 1)">linuxwpf
Type</span>=<span style="color: rgba(0, 0, 0, 1)">Application
Exec</span>=/usr/share/ linuxwpf/<span style="color: rgba(0, 0, 0, 1)">linuxwpf
Icon</span>=/usr/share/icons/linuxwpf.png</pre>
</div>
<p> </p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">11、在项目文件里面,新增上面俩文件的有关配置,如图所示。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002658094-949474883.png" alt=""></span></p>
<p> </p>
<p>新增的配置代码:</p>
<div class="cnblogs_code">
<pre><ItemGroup>
<Content Include=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">linuxwpf.png</span><span style="color: rgba(128, 0, 0, 1)">"</span> CopyToPublishDirectory=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">PreserveNewest</span><span style="color: rgba(128, 0, 0, 1)">"</span>>
<LinuxPath>/usr/share/icons/linuxwpf.png</LinuxPath>
</Content>
<Content Include=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">linuxwpf.desktop</span><span style="color: rgba(128, 0, 0, 1)">"</span> CopyToPublishDirectory=<span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">PreserveNewest</span><span style="color: rgba(128, 0, 0, 1)">"</span>>
<LinuxPath>/usr/share/applications/linuxwpf.desktop</LinuxPath>
</Content>
</ItemGroup></pre>
</div>
<p> </p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">12、然后,在程序包管理器下,或者shell窗口,或者dos窗口,输入 dotnet tool install --global dotnet-deb</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">该命令的作用是,用于安装一个可以对.net项目进行打包成deb文件的工具。deb格式文件是linux系统下的一种安装包格式之一。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002716270-2014979571.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">13、指定到在项目目录下,准备进行项目打包。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002726297-1228926200.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">14、先输入 dotnet deb install 命令,用于下载 deb 工具。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002743295-677601269.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">15、然后输入 dotnet restore -r linux-x64 命令,用于重置指定的程序运行目标环境,例如 linux-x64 </span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002800387-1567845358.png" alt=""></span></p>
<p> </p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">16、最后输入 以下如图所示的命令,进行发布程序。该命令会在根目录下生成release文件夹。其中,指定操作方式是创建Deb文件,目标环境是.net6.0,以及运行时是 linux-x64环境。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002812891-1615627810.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">17、在根目录下,可以看到生成了一个deb文件,只需要把该文件拷贝到指定的linux系统上即可(前提是linux系统是带有图形界面的那种)</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002825459-25379850.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">18、在远程ubuntu系统上,新建一个测试用的文件夹叫wpf,用于存放上面的deb文件</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002842966-1983084179.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">19、使用命令,远程直接拷贝到指定的路径。远程拷贝命令说明:</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">命令:scp -v 远程用户 1@远程地址 1:/文件路径 1/文件 1 远程用户 2@远程地址 2:/文件路径 2 </span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">解释:从远程服务器 1 上面的文件 1 拷贝到远程服务器2 的文件路径 2 文件夹下</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002857506-2106605877.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">20、拷贝完成,可以开始安装了。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002910600-833376707.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">21、使用 dpkg -i xxx.deb命令,即可开始安装。如果没有dpkg命令可以用,需要先通过命令 (需要sudo权限) apt-get install -f 进行安装一些基础的组件先。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002938173-1608387641.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">22、此处安装完成以后,没有显示桌面图标,说明有点小问题,可能原因是xxx.desktop桌面图标文件里面配置的字符编码不是 UTF-8或者某个路径或配置文件配置不标准,大佬们可以自行去研究。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px">此处没有桌面图标,可以进入到安装路径下,在 /usr/shard/程序名称文件夹/ 下,可以找到对应的程序文件,直接运行即可。例如此处我的程序名称是linuxwpf,则直接运行,即打开程序窗口。通过点击按钮,弹出符合预期的提示框,说明该跨平台方案是成功的。</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 18px"><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315002955632-408086595.png" alt=""></span></p>
<p> </p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 16px">以上就是该博客的所有内容,如果有帮助,欢迎点赞、留言或转发。转发请注明出处:https://www.cnblogs.com/weskynet/</span></p>
<p><span style="font-family: arial, helvetica, sans-serif; font-size: 16px">如果有想法进行技术交流,也可以扫下面的二维码添加我个人微信,我可以拉入专属博客群进行答疑,或不定时进行其他技术分享。或者点击我的博客栏上的QQ群链接,加入QQ群,也是可以的。</span></p>
<p><img src="https://img2022.cnblogs.com/blog/1995789/202203/1995789-20220315011539845-820639385.png" alt=""></p>
<p> </p>
<p>再次感谢大家观看!祝大家写代码写的开心~~</p>
<p> </p>
</div>
<div id="MySignature" role="contentinfo">
<div style="text-align: left">
<p>本文作者:Wesky</p>
<p>微信号:WeskyNet001</p>
<p>公众号:Dotnet Dancer</p>
<p>文章链接:https://www.cnblogs.com/weskynet/p/16006818.html</p>
<img src="https://images.cnblogs.com/cnblogs_com/blogs/686424/galleries/2427775/o_241023072701_GZH.jpg" alt="微信公众号二维码" />
<p>欢迎扫一扫关注公众号,发现更多其他技术分享</p>
</div><br><br>
来源:https://www.cnblogs.com/weskynet/p/16006818.html
頁:
[1]