提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|行业资讯|编辑:龚雪|2023-05-17 10:53:40.300|阅读 157 次
概述:本文将为大家介绍.NET MAUI与WPF之间的共性,及如何帮助开发人员更简单的完成工作!
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
.NET多平台应用程序UI(. NET MAUI)的市场吸引力与日俱增,这是微软最新的开发平台,允许开发者使用单个代码库创建跨平台应用程序。尽管很多WPF开发人员还没有跟上 .NET MAUI的潮流,但我们将在这篇文章中为大家展示他的潜力,具体来说想描述一下WPF和.NET MAUI之前的共性。
PS:DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。
DevExpress技术交流群8:523159565 欢迎一起进群讨论
与Xamarin不同,.NET MAUI解决方案包含针对所有目标平台的单个项目。像WPF一样, .NET MAUI项目包含一个App.xaml文件和主视图,另外可以发现AppShell类被用作根视觉元素:
Resources文件夹包含跨每个平台使用的应用程序资源,开发者可以将特定于平台的资源放在Platforms目录的子文件夹中,以便在应用程序启动时执行相关代码。
.NET MAUI页面具有与WPF窗口或用户控件相似的结构,根元素包含命名空间声明和x:Class属性,该属性定义了代码背后的类名:
<?xml version="1.0" encoding="utf-8" ?> <ContentPage xmlns="//schemas.microsoft.com/dotnet/2021/maui" xmlns:x="//schemas.microsoft.com/winfx/2009/xaml" x:Class="MauiFirstApp.MainPage"> <ScrollView> <!--...--> </ScrollView> </ContentPage>
InitializeComponent方法是根据XAML自动生成的:
namespace MauiFirstApp; public partial class MainPage : ContentPage { public MainPage() { InitializeComponent(); } }
.NET MAUI绑定使用与WPF绑定相似的上下文,它有类似的模式、相对源、转换器等。.NET MAUI使用了与WPF的类似的概念,唯一的区别是这个属性叫做:
<ContentPage xmlns="//schemas.microsoft.com/dotnet/2021/maui" xmlns:x="//schemas.microsoft.com/winfx/2009/xaml" xmlns:local="clr-namespace:MauiFirstApp" x:Class="MauiFirstApp.MainPage"> <ContentPage.BindingContext> <local:ViewModel/> </ContentPage.BindingContext> <Label Text="{Binding FirstName}"/> </ContentPage>
.NET MAUI包含与和相似的东西,可以帮助开发者根据业务需求安排可视化元素:
<Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="Auto"/> <ColumnDefinition Width="*"/> </Grid.ColumnDefinitions> <ListView Grid.Column="0"/> <StackLayout Grid.Column="1" WidthRequest="50"> <Button Text="Print"/> <Button Text="Export"/> </StackLayout> </Grid>
资源字典存储应用程序资源(样式、模板、转换器等),开发者可以使用StaticResource或DynamicResource标记扩展来将这些资源应用到元素上:
<ContentPage xmlns="//schemas.microsoft.com/dotnet/2021/maui" xmlns:x="//schemas.microsoft.com/winfx/2009/xaml" xmlns:local="clr-namespace:MauiFirstApp" x:Class="MauiFirstApp.MainPage"> <ContentPage.Resources> <Color x:Key="ButtonBackgroundColor">DarkOrange</Color> <Color x:Key="ButtonForegroundColor">Black</Color> </ContentPage.Resources> <Button Text="Export" BackgroundColor="{StaticResource ButtonBackgroundColor}" TextColor="{StaticResource ButtonForegroundColor}"/> </ContentPage>
在.NET MAUI中,您可以使用 和来保持与WPF相同的UI灵活性:
<ListView> <ListView.ItemTemplate> <DataTemplate> <Label Text="{Binding FirstName}"/> </DataTemplate> </ListView.ItemTemplate> </ListView>
开发者可以创建显式和隐式样式来将类似的设置应用于多个元素:
<ContentPage.Resources> <Style TargetType="Button"> <Setter Property="Background" Value="Orange"/> <Setter Property="TextColor" Value="White"/> <Setter Property="CornerRadius" Value="4"/> </Style> </ContentPage.Resources> <StackLayout Orientation="Horizontal"> <Button Text="Next"/> <Button Text="Prev"/> </StackLayout>
声明式XAML触发器允许开发者有条件地应用样式:
<ContentPage.Resources> <Style TargetType="Editor" x:Key="redOnFocusStyle"> <Style.Triggers> <Trigger TargetType="Editor" Property="IsFocused" Value="True"> <Setter Property="Background" Value="Red"/> </Trigger> </Style.Triggers> </Style> </ContentPage.Resources> <StackLayout VerticalOptions="Start"> <Editor Text="Red on Focus" Style="{StaticResource redOnFocusStyle}"/> </StackLayout>
与WPF非常相似,可视元素的层次结构允许开发者轻松地识别控件的父元素和子元素,Parent属性包含直接可视父属性和Children属性——直接子属性,主要区别在于.NET MAUI没有逻辑树。
.NET MAUI使用与WPF相同的MVVM范例,许多MVVM框架(如Prism)都是跨平台的,因此您不太可能注意到许多差异。下面是一个基本的例子,演示了如何在视图模型中将编辑器绑定到属性,将按钮绑定到命令:
<?xml version="1.0" encoding="utf-8" ?> <ContentPage xmlns="//schemas.microsoft.com/dotnet/2021/maui" xmlns:x="//schemas.microsoft.com/winfx/2009/xaml" xmlns:local="clr-namespace:MauiFirstApp" x:Class="MauiFirstApp.MainPage"> <ContentPage.BindingContext> <local:ViewModel/> </ContentPage.BindingContext> <StackLayout VerticalOptions="Start"> <Editor Text="{Binding FirstName}"/> <Button Text="Process" Command="{Binding ProcessUserCommand}"/> </StackLayout> </ContentPage>
public class ViewModel : INotifyPropertyChanged { private string name; public string FirstName { get { return name; } set { name = value; OnPropertyChanged(); } } public ICommand ProcessUserCommand { get; } public ViewModel() { ProcessUserCommand = new Command(ProcessUser); } void ProcessUser() { Console.WriteLine(FirstName); } public event PropertyChangedEventHandler PropertyChanged; public void OnPropertyChanged([CallerMemberName] string name = "") => PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name)); }
.NET MAUI 依赖属性称为可绑定属性,它们使用类似的声明结构:一个静态字段和一个公共属性。BindableProperty.Create方法接受所有与DependencyProperty.Register类似的参数在WPF中注册:
public int MaxValue { get => (int)GetValue(MaxValueProperty); set => SetValue(MaxValueProperty, value); } public static readonly BindableProperty MaxValueProperty = BindableProperty.Create("MaxValue", typeof(int), typeof(MainPage), 0, propertyChanged: OnMaxValueChanged); private static void OnMaxValueChanged(BindableObject bindable, object oldValue, object newValue) { // ... }
WPF和.NET MAUI开发有许多共同之处,如果您熟悉WPF,可以毫不费力地创建一个功能强大的.NET MAUI应用程序。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
文章转载自:慧都网通过提供强大的3D CAD数据访问工具并适用于桌面、移动和Web的高级环境3D可视化发动机,HOOPS在提升造船设计和制造流程的效率方面发挥了重要作用。
HOOPS Luminate在汽车行业中的应用具有广泛的潜力和深远的影响。它通过提供高效的3D可视化、虚拟装配与拆解、性能分析、客户定制等功能,帮助汽车制造商在设计、生产和销售过程中提升效率、降低成本并提高产品质量。
在不断发展的软件开发世界中,使工具和框架与最新的平台版本保持同步至关重要,欢迎查阅~
全球航运业对国际贸易至关重要,全球 90% 以上的商品通过海运运输。准确监控和控制这些集装箱的移动对于维持高效的供应链至关重要。手动输入集装箱号码是这一程序的关键部分,它带来了相当大的挑战,例如人为错误和效率低下。
行业领先的界面控件开发包,帮助企业构建卓越应用!
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress WPF Subscription高效MVVM开发模式,WPF界面解决方案首选工具,帮助企业实现酷炫动效界面。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢