WPF繪製簡單常用的Path

来源:http://www.cnblogs.com/tsliwei/archive/2016/06/22/5609035.html
-Advertisement-
Play Games

寫代碼出身的我們經常需要使用一些簡單 但是不是規則圖形的Path 但限於美工功底有限 不知道怎麼去畫 下麵我告訴大家一些簡單的小技巧 用代碼來畫Path 個人還是比較喜歡用代碼 因為數值控制的更精細 MSDN告訴我們,Path可以用這些形狀繪製: ArcSegment 類 表示兩點之間的一條橢圓弧。 ...


寫代碼出身的我們經常需要使用一些簡單 但是不是規則圖形的Path 但限於美工功底有限 不知道怎麼去畫

下麵我告訴大家一些簡單的小技巧 用代碼來畫Path 個人還是比較喜歡用代碼 因為數值控制的更精細

 

MSDN告訴我們,Path可以用這些形狀繪製:

ArcSegment 類 表示兩點之間的一條橢圓弧。

BezierSegment 類 表示在兩個點之間繪製的一條三次貝塞爾曲線。

LineSegment 類 在PathFigure中的兩個點之間創建一條直線。

PolyBezierSegment 類 表示一條或多條三次方貝塞爾曲線。

PolyLineSegment 類 表示由PointCollection定義的線段集合,每個Point指定線段的終點。

PolyQuadraticBezierSegment 類 表示一系列二次貝塞爾線段。

QuadraticBezierSegment 類 在PathFigure的兩點之間創建一條二次貝塞爾曲線。

 

說了這麼多,好複雜呀,我們可以挑最簡單的來用:

LineSegment 畫直線,PolyLineSegment 畫折線,ArcSegment 畫圓弧

其實有了這三個類,我們可以畫絕大多數簡單常用的形狀了,下麵我舉兩個例子

 

 

這個形狀寬和高都是100,其中矩形寬100高90,三角寬10高10居中

對於這樣有棱角的圖形,我們只需要找到他所有的頂點就行了

 

然後順時針依次連起來,用PolyLineSegment折線來表示就行了

1 <Path Stroke="Red" StrokeThickness="1">
2             <Path.Data>
3                 <PathGeometry>
4                     <PathFigure StartPoint="0,0">
5                         <PolyLineSegment Points="100,0 100,90 55,90 50,100 45,90 0,90 0,0"></PolyLineSegment>
6                     </PathFigure>
7                 </PathGeometry>
8             </Path.Data>
9         </Path>
View Code

 

來看這個帶有圓角的圖形,4個圓弧的半徑是5,其他屬性和上圖一樣.我們需要將它拆分,拆分成8個部分,4個圓弧和4個邊,因為左上角圓弧的關係,起點設置成(5,0),每一部分的起點,都是上一部分的終點:

  1. 上邊的直線:終點(95,0)
  2. 右上角的圓弧:終點(100,5),Size(5,5) 因為圓弧表示的是橢圓的圓弧,Size就是Size(寬,高),當寬和高都一樣設置為5時,就指的是半徑為5的圓的圓弧了
  3. 右邊的直線:終點(100,85)
  4. 右下角的圓弧:終點(95,90),Size(5,5)
  5. 下邊的折線:點的集合(55,90 50,100 45,90 5,90) 由於我們是順時針來的,下邊點的集合是從右到左依次來的
  6. 左下角圓弧:終點(0,85),Size(5,5)
  7. 左邊的直線:終點(0,5)
  8. 左上角的圓弧:終點(5,0) 與起點重合

 1 <Path Stroke="Red" StrokeThickness="1">
 2             <Path.Data>
 3                 <PathGeometry>
 4                     <PathFigure StartPoint="5,0">
 5                         <LineSegment Point="95,0"></LineSegment>
 6                         <!--SweepDirection獲取或設置一個值,該值指定是以 Clockwise 方向還是以 Counterclockwise 方向繪製弧-->
 7                         <!--你試下另一個值,看下效果就知道怎麼回事了-->
 8                         <ArcSegment Point="100,5" Size="5,5" SweepDirection="Clockwise"></ArcSegment>
 9                         <LineSegment Point="100,85"></LineSegment>
10                         <ArcSegment Point="95,90" Size="5,5" SweepDirection="Clockwise"></ArcSegment>
11                         <PolyLineSegment Points="55,90 50,100 45,90 5,90"></PolyLineSegment>
12                         <ArcSegment Point="0,85" Size="5,5" SweepDirection="Clockwise"></ArcSegment>
13                         <LineSegment Point="0,5"></LineSegment>
14                         <ArcSegment Point="5,0" Size="5,5" SweepDirection="Clockwise"></ArcSegment>
15                     </PathFigure>
16                 </PathGeometry>
17             </Path.Data>
18         </Path>
View Code

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近學習了elf文件的格式,重點關註了動態鏈接過程中的使用到的section 第一步程式在載入時,會把解釋器程式加入到.interp段。可以解決動態庫和可執行文件的載入。 一般來講程式的載入方式是懶啟動,Lazy;除非指定了LD_BIND_NOW環境變數非0,那麼在程式啟動時就會把外部符號地址全部加 ...
  • 在這個練習中,我們來學習如何把我們想要的東西寫到文件中。我們在這個練習中還是使用File類中的方法來完成寫文件的操作。 在這個練習中我們要用C#創建一個純文本文件ex11.txt 放到c盤的Exercise11目錄下。通常c盤下是沒有Exercise11目錄的,請先建立這個目錄。我們的C#程式會讓用 ...
  • 1. 為什麼使用正則表達式? 典型的搜索和替換操作要求您提供與預期的搜索結果匹配的確切文本。雖然這種技術對於對靜態文本執行簡單搜索和替換任務可能已經足夠了,但它缺乏靈活性,若採用這種方法搜索動態文本,即使不是不可能,至少也會變得很困難。通過使用正則表達式,可以: ※ 測試字元串內的模式。 例如,可以 ...
  • WebApi框架,可分為三層:托管層、消息處理程式托管層、控制器處理層。 一、托管層: 即Host,是WebAPI宿主,如:控制台,Windows服務等。 寄宿方式。 1、定製托管。 2、自托管。 3、Web托管 Owin寄宿 ,如Katana, 在一個Owin相容的伺服器上建立一個WebApi層, ...
  • MD5簡介: MD5的全稱是Message-Digest Algorithm 5,在90年代初由MIT的電腦科學實驗室和RSA Data Security Inc發明,經MD2、MD3和MD4發展而來。MD5將任意長度的“位元組串”變換成一個128bit的大整數,並且它是一個不可逆的字元串變換演算法。 ...
  • ASP.NET支持以下驗證控制項 RequiredFieldValidator(非空驗證) 確保用戶沒有跳過輸入控制項。RequiredFieldValidator控制項可以與文本框綁定在一起,以便強制用戶對文本框進行輸入。使用選擇控制項,例如,對於下拉框控制項和單選按鈕,RequiredFieldValid ...
  • 分類:C#、VS2015 創建日期:2016-06-23 使用教材:(十二五國家級規劃教材)《C#程式設計及應用教程》(第3版) 一、要點 該例子屬於高級技術中的基本用法。對於初學者來說這是難點(難在還沒有學習第13章WPF相關的繪圖技術),因此,這裡的關鍵是理解設計思路,而不是一開始就陷於細節的實... ...
  • 晚上無聊寫了個二叉樹(圖)的廣度和深度遍歷演算法,演算法本身很簡單,但是如何做到通用呢,一下代碼是我的設計,請大家幫忙看看有什麼問題,我自己感覺有問題就是不知道具體什麼問題 單元測試代碼: [TestClass] public class BreadthVisitorTest { [TestMethod ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...