您现在的位置是:网站首页> 编程资料编程资料
MAUI使用Maui.Graphics.Controls绘制控件详解_实用技巧_
2023-05-24
297人已围观
简介 MAUI使用Maui.Graphics.Controls绘制控件详解_实用技巧_
简介
Microsoft.Maui.Graphics是一个完全采用C#的iOS,Android,Windows,macOS,Tizen和Linux的跨平台图形库。
对于MAUI项目当中绘制的方案是使用不同平台的控件来而非自绘。 当然MAUI当中也使用了Microsoft.Maui.Graphics,
MAUI Preview9更新中, 引入了新的API能够轻松的将边框、阴影、形状添加到其中。
Microsoft.Maui.Graphics.Controls
Microsoft.Maui.Graphics.Controls是一个.NET MAUI 实验性项目,该项目通过Microsoft.Maui.Graphics库来绘制控件, 具有多种内置主题,这意味着, 您可以在你现有的MAUI项目当中使用它。
接下来, 主要讲解如何使用Microsoft.Maui.Graphics.Controls 以及如何扩展自行绘制控件。
使用Microsoft.Maui.Graphics.Controls
首先, 创建一个MAUI项目, 添加新的Nuget包源并且安装它。
确保Nuget包源的依赖版本与当前MAUI项目版本移植6.0.101-preview.10.2068
打开MauiProgram文件, 添加 ConfigureGraphicsControls
public static MauiApp CreateMauiApp() { var builder = MauiApp.CreateBuilder(); builder .UseMauiApp() .ConfigureFonts(fonts => { fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular"); }).ConfigureGraphicsControls(); return builder.Build(); } 启动后,效果如下所示:
说明: 可以通过ConfigureGraphicsControls(Microsoft.Maui.Graphics.Controls.DrawableType.Fluent)参数配置控件的风格, 提供了: Cupertino, Fluent ,Material 三种选项。
绘制控件
如果你想要完全实现自定义控件或者修改控件的某些方面, 你都可以使用它来做到这一点, 下来演示如何使用该库来绘制自定义的圆形控件。
1.创建Circle类, 继承于GraphicsView, 并且重写Draw方法,绘制指定宽度颜色的圆形。
public class Circle : Microsoft.Maui.Graphics.Controls.GraphicsView { public static readonly BindableProperty ForegroundProperty = BindableProperty.Create(nameof(Foreground), typeof(Color), typeof(Circle), null); public Color Foreground { get => (Color)GetValue(ForegroundProperty); set => SetValue(ForegroundProperty, value); } public static readonly BindableProperty SizeProperty = BindableProperty.Create(nameof(Size), typeof(float), typeof(Circle), null); public float Size { get { return (float)GetValue(SizeProperty); } set { SetValue(SizeProperty, value); } } public override void Draw(ICanvas canvas, RectangleF dirtyRect) { base.Draw(canvas, dirtyRect); canvas.SaveState(); canvas.FillColor = Foreground; var x = dirtyRect.X; var y = dirtyRect.Y; canvas.FillEllipse(x, y, Size, Size); canvas.RestoreState(); } }2.XAML中声明控件,设置指定大小及颜色
3.启动项目,查看控件对应效果:
总结
本篇文章主要介绍如何在MAUI项目中使用Microsoft.Maui.Graphics.Controls, 以及通过它实现自定义控件的扩展功能。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- ASP.NET Core基础之异常中间件_基础应用_
- ASP.NET Core中的wwwroot文件夹_基础应用_
- ASP.NET Core基础之请求处理管道_基础应用_
- ASP.NET Core基础之中间件_基础应用_
- ASP.NET Core应用程序配置文件AppSetting.json_基础应用_
- ASP.NET Core基础之Startup类_基础应用_
- ASP.NET Core基础之启动设置_基础应用_
- ASP.NET Core托管模型CreateDefaultBuilder()方法_基础应用_
- ASP.NET Core基础之Main方法讲解_基础应用_
- .Net Core3.0 WebApi 项目框架搭建之使用Serilog替换掉Log4j_实用技巧_



