MAUI 自定義繪圖入門

在2022的5月份,某軟正式發布了 MAUI 跨平臺 UI 框架。我本來想著趁六一兒童節放假來寫幾篇關于 MAUI 入門的博客,可惜發現我不擅長寫很入門的博客。再加上 MAUI 似乎是為了趕發布日期而發布,只能勉強說能開發了,能用了。于是我就來開始假定大家是一個成熟的 MAUI 開發者了,開始進入復雜控件自繪的自定義繪圖渲染的博客

在 MAUI 里面,默認將會在 Microsoft.Maui.Dependencies 引用 Microsoft.Maui.Graphics 的負載。在 Microsoft.Maui.Graphics 里,提供了跨平臺的獨立繪圖能力,在 GitHub 上作為獨立的開源項目,開源在 https://github.com/dotnet/Microsoft.Maui.Graphics

也如 Microsoft.Maui.Graphics 在它開源項目里面描述的一樣,使用 Microsoft.Maui.Graphics 不會被局限于 MAUI 框架上,可以在任何的應用框架下使用上 Microsoft.Maui.Graphics 庫,就和其他的 NuGet 包一樣去使用。換句話說,我可以在 WPF 或 WinForms 或者是純控制臺里面使用 Microsoft.Maui.Graphics 進行繪圖

另外,我也可以自己注入 Microsoft.Maui.Graphics 的實現定義,擴展其他渲染引擎或框架作為繪圖的基礎支持

回到主題,本文將告訴大家如何在 MAUI 里面使用 Microsoft.Maui.Graphics 提供的繪圖能力進自繪。對于任何的 UI 框架來說,只要能實現好的自繪,就能擴展出超級多炫酷的界面效果,同時也可以方便將舊技術積累遷移到此 UI 框架上。無疑,在MAUI上就實現了這一點

這部分的內容,在當前是 2022.06 還沒有多少文檔,官方的文檔里面都說 MAUI 還是預覽版,別聽官方說的,在5月就發布了。發布在 6.0.312 的 dotnet 版本上

在 MAUI 里面接入 Microsoft.Maui.Graphics 從而實現自繪是有框架層的支持的,只是實現的方式稍微有點繞

先安裝 VisualStudio 2022 預覽版用于新建 MAUI 項目。由于 MAUI 的發布和 VisualStudio 的發布日期對不上,現在只能通過預覽版本了,不過后續會合入到正式版本

在新建的項目里面,新建一個類型,讓這個類型繼承?Microsoft.Maui.Graphics.IDrawable?接口。于是此類型即可通過實現 Draw 方法,被框架層調用到,從而在 Draw 方法里面執行繪圖。例如和官方的例子一樣,將此類型命名為 GraphicsDrawable 如以下代碼

public class GraphicsDrawable : IDrawable{    public void Draw(ICanvas canvas, RectF dirtyRect){}
}

在 Draw 里面通過 DrawLine 畫出一段線條。為了讓線條可見,再加上設置線條的顏色和粗細值的代碼

public void Draw(ICanvas canvas, RectF dirtyRect){canvas.StrokeColor = Colors.Red;canvas.StrokeSize = 6;canvas.DrawLine(10, 10, 90, 100);}

完成了這一步之后,還需要將 GraphicsDrawable 接入到 MAUI 框架里面

在 MAUI 框架里提供了 GraphicsView 元素用來對接 Microsoft.Maui.Graphics 的繪圖功能。在 GraphicsView 的 Drawable 屬性里面,就是用來傳入 IDrawable 的對象的

對接的第一步是將咱寫的?GraphicsDrawable?類型定義成資源,方便后續代碼都在 XAML 里面實現。為了演示方便,以下代碼都寫在 MainPage.xaml 里

<?xml version="1.0" encoding="utf-8" ?><ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"xmlns:local="clr-namespace:HejawrawceaJurheakelerela"x:Class="HejawrawceaJurheakelerela.MainPage"><ContentPage.Resources><local:GraphicsDrawable x:Key="GraphicsDrawable"></local:GraphicsDrawable></ContentPage.Resources></ContentPage>

還請將以上代碼的?local?的命名空間更換為你的項目對應的命名空間

接著在 GraphicsView 里使用以上定義的資源,如以下代碼

<GraphicsView x:Name="GraphicsView" WidthRequest="100" HeightRequest="100" Drawable="{StaticResource GraphicsDrawable}"></GraphicsView>

運行程序,即可看到界面畫出一條線

52773393a0c7588da6b6bfaf82ec85f6.png

可以看到調用堆棧如下

e414ce9eefabec49dbfaac30bb52de9e.png

也就是實際的實現是由 Win2D 提供的

以上是在 Windows 平臺上運行的,那既然 MAUI 宣稱是跨平臺的,那在其他的平臺上又是如何

接下來在安卓平臺上跑一下

34f0b771741da04285dc5589b45875b7.png

同樣也看一下調用堆棧

26577fe595feb00374566c3f9d9e61b0.png

可以看到調用堆棧和 Windows 平臺上,符合預期的不同,也就是說 Microsoft.Maui.Graphics 根據不同的平臺選用不同的繪制底層技術

這就是 MAUI 自繪的開始,如何繪制出漂亮的界面就靠大家發揮

試用了幾天的 MAUI 發現了比上次我用預覽版本有了很大的進步,比如 Windows 端的調試部署極大的提升。當然,這不是 MAUI 團隊的努力,而是 Windows App SDK 團隊的努力,將原本的 UWP 很多逗比邏輯和交互給優化的。自然,不足之處也是有的,那就是 MAUI 團隊還是太小了,好多東西還沒磨完,不過這會隨著開發的投入逐步完善。現在的 MAUI 已經達到了 Demo 級,小工具級可用的狀態。推薦大家要是有什么小工具,選擇一下 MAUI 試試水也不錯

本文代碼放在github?和?gitee?歡迎訪問

可以通過如下方式獲取本文的源代碼,先創建一個空文件夾,接著使用命令行 cd 命令進入此空文件夾,在命令行里面輸入以下代碼,即可獲取到本文的代碼

git initgit remote add origin https://gitee.com/lindexi/lindexi_gd.gitgit pull origin 2da0315302ae504f50c4c3baa47fe3f45d0cdc26

以上使用的是 gitee 的源,如果 gitee 不能訪問,請替換為 github 的源

git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git

獲取代碼之后,進入 HejawrawceaJurheakelerela 文件夾

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/286408.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/286408.shtml
英文地址,請注明出處:http://en.pswp.cn/news/286408.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C語言試題五之計算并輸出給定數組(長度為9)中每相鄰兩個元素之平均值的平方根之和

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 請編寫函數…

【三維激光掃描】實驗02:StonexSiScan新建項目、加載點云數據

文章目錄 1. 新建工程2. 打開工程3. 加載點云1. 新建工程 打開StonexSiScan點云后處理軟件,點擊【新建】按鈕。 選擇工程存放路徑,輸入工程名稱。 2. 打開工程 點擊【打開】按鈕。

eBPF 在云原生環境中的應用

端午假期&#xff0c;我翻譯了 OReilly 的報告《什么是 eBPF》&#xff0c;其中我覺得第五章「云原生環境中的 eBPF」解答了我心中的很多疑惑&#xff0c;比較不錯&#xff0c;分享給大家。下面是第五章譯文。《什么是 eBPF》中文版封面近年來&#xff0c;云原生應用已呈指數級…

使用HtmlAgilityPack抓取網頁數據

XPath路徑表達式&#xff0c;主要是對XML文檔中的節點進行搜索&#xff0c;通過XPath表達式可以對XML文檔中的節點位置進行快速定位和訪問&#xff0c;html也是也是一種類似于xml的標記語言&#xff0c;但是語法沒有那么嚴謹&#xff0c;在codeplex里有一個開源項目HtmlAgility…

C語言試題六之使字符串的前導*號不得多于n個;若多于n個,則刪除多于的*號;若少于或等于n個,則什么也不做。字符串中間和尾部的*號不刪除。

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 請編寫函數…

QT坑爹的事..

昨晚用QT寫了個網絡小程序&#xff0c;布局怎么都出不來add->widge()無效&#xff0c;原來因為在QMainWindow的基類下 需要人工添加一個 widge new QWidge() this->setCentralWidget(widget);最后在 widget->setLayout(mainLayout);才行 dialog和widge的基類 則沒有任…

企業有了程序員為什么還要用 低代碼/無代碼

一、備受“爭議”的無代碼/低代碼開發 在看這篇內容時&#xff0c;我們要知道&#xff0c;技術無時無刻不在進行發展&#xff0c;IT技術更是如此&#xff0c;快速的技術更新使得程序員在進行應用開發時效率更高&#xff1b;我記得在十多年前&#xff0c;開發一個普通的 HTML 頁…

【三維激光掃描技術】原理、方法及實驗圖文教程目錄

《三維激光掃描技術》專欄講述目前最先進、最流行的三維激光技術&#xff0c;包括三維激光掃描技術原理&#xff0c;三維測距原理&#xff0c;國內外三維掃描設備&#xff0c;點云特點&#xff0c;三維建模&#xff0c;三維激光優勢、應用領域&#xff0c;應用技術案例等。 文章…

std::thread 不 join

std::thread 構造之后 使用 detach。就可以了

求最長回文串

Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is 1000, and there exists one unique longest palindromic substring. 轉載于:https://www.cnblogs.com/yangscode/p/5017527.html

C語言試題七之將函數字符串中的前導*號全部刪除,中間和尾部的*號不刪除。

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 規定輸入字…

Dapr 1.7 之 Unix Domain socket 他來了

Unix Domain socketA UNIX socket is an inter-process communication mechanism that allows bidirectional data exchange between processes running on the same machine.Unix Domain Socket&#xff08;后面統一簡稱 UDS&#xff09;是在socket的框架上發展出一種IPC&…

實訓三(cocos2dx 3.x 打包apk)

上一篇文章《實訓二&#xff08;cocos2dx 2.x 打包apk&#xff09;》簡單的講述的利用cocos2dx 2.x引擎在windows平臺上打包apk的方法與過程&#xff0c;本文將介紹3.x版本引擎&#xff0c;如何打包apk的問題。 首先&#xff0c;Cygwin在3.x版本引擎上已經用不到了&#xff0c;…

學習SQL數據查詢,這一篇就夠了!

【任務概述】 建立數據庫的目的主要是為了對數據庫進行操作,以便能夠從中提取有用的信息,而數據查詢則是數據庫操作的核心。 擴展閱讀:《學習SQL數據更新,這一篇就夠了!》 文章目錄 一、SQL簡單查詢1. Select查詢語句2. 無條件查詢3. 單條件查詢4. 多條件查詢5. 分組查詢6…

網頁精美動效/動畫制作 按鈕鼠標懸浮動效基礎 01《炫彩網頁 iVX 無代碼動效/動畫制作》

編輯器地址&#xff1a;https://editor.ivx.cn/ 一、準備工作 進入編輯頁后&#xff0c;選擇其中一種應用類型創建應用&#xff0c;在此以相對應用作為示例&#xff1a; 創建好應用后在此選擇對應的屏幕作為示例演示&#xff0c;在此選擇電腦屏幕作為對應的大小&#xff1a…

Java并發編程 - Executor,Executors,ExecutorService, CompletionServie,Future,Callable

一、Exectuor框架簡介 Java從1.5版本開始&#xff0c;為簡化多線程并發編程&#xff0c;引入全新的并發編程包:java.util.concurrent及其并發編程框架&#xff08;Executor框架&#xff09;。 Executor框架是指java 5中引入的一系列并發庫中與executor相關的一些功能類&a…

C語言試題八之計算下列級數和,和值由函數值返回 S=1+x+x^2/2! + x^3/3!+…x^n/n!

??個人主頁:個人主頁 ??系列專欄:C語言試題200例目錄 ??推薦一款刷算法、筆試、面經、拿大公司offer神器 ?? 點擊跳轉進入網站 ?作者簡介:大家好,我是碼莎拉蒂,CSDN博客專家(全站排名Top 50),阿里云博客專家、51CTO博客專家、華為云享專家 1、題目 計算下列級…

with管理文件操作

為了避免打開文件后忘記關閉&#xff0c;可以通過管理上下文&#xff0c;即&#xff1a; with open(log,r) as f: f.write(xxxxxx)f.readlines()...................如此方式&#xff0c;當with代碼塊執行完畢時&#xff0c;內部會自動關閉并釋放文件資源。以往我們打開…

學習SQL數據更新,這一篇就夠了!

【任務描述】 數據查詢不能改變數據庫中的數據,僅僅是把數據庫中符號條件的某些信息反饋給用戶。一個數據庫若要保持數據的正確性、及時性、則要依賴于數據庫的更新功能。數據更新主要包括插入數據、修改數據和刪除數據。 擴展閱讀:《學習SQL數據查詢,這一篇就夠了!》 文章…