UWP 手繪視頻創作工具技術分享系列 - 點陣圖的繪製

来源:http://www.cnblogs.com/shaomeng/archive/2017/10/16/7668523.html
-Advertisement-
Play Games

前面我們針對 SVG 的解析和繪製做了介紹,SVG 是圖片的一種形式,而另一種很重要的圖片是:點陣圖,包括 png、jpeg、bmp 等格式。點陣圖的基本規則是,組成的基本元素是像素點,由寬度 * 高度個像素組成,每個像素存儲了一個點的顏色和位置信息,顏色信息可以是 ARGB、RGBA、BGR 或 YU ...


前面我們針對 SVG 的解析和繪製做了介紹,SVG 是圖片的一種形式,而另一種很重要的圖片是:點陣圖,包括 png、jpeg、bmp 等格式。點陣圖的基本規則是,組成的基本元素是像素點,由寬度 * 高度個像素組成,每個像素存儲了一個點的顏色和位置信息,顏色信息可以是 ARGB、RGBA、BGR 或 YUV 等組成。在手繪視頻中,點陣圖也是一種很重要的表現形式,因為我們在網上下載的圖片,或者自己拍攝的照片,都是點陣圖形式,我們可以用它來做成相冊類型的視頻等等。下麵看一個用戶使用來畫Pro製作的視頻中的截圖,用戶製作的是一個旅游方面的視頻,每個景點的圖片都是點陣圖,人物也有一部分點陣圖,這就是點陣圖在手繪視頻中的一種表現形式:

 

下麵來詳細介紹一下點陣圖在手繪視頻中的普通繪製方式:

一般來講,如果對於點陣圖的處理會簡單粗暴一些,就是採用一種預設的方式,而不是圖片信息包含的路徑數據(因為點陣圖本身沒有路徑數據),來繪製點陣圖,比如從點陣圖的左上角開始,按照固定的間隔繪製直至點陣圖的右下角完畢。繪製過程效果如下圖:

  

我們看到上面一張 png 點陣圖的繪製過程,從左上角開始,以某個角度的傾斜完成左到右的畫筆描繪,而以另一個相近的角度完成從右到左的畫筆繪製,最終到完成整個點陣圖的繪製。而這整個過程的處理流程和示意圖如下:

其中,初始化圖片資源和動畫路徑數據,分別用到 CanvasBitmap 和 CanvasGeometry;而轉換繪製動畫路徑的點集使用 CanvasGeometry.ComputePointOnPath(float distance),最終得到的 distance 就是繪製的總長度;而繪製過程使用的是 CompositeEffect。

以上是所謂簡單粗暴的處理方式,作為一個 bige 高的專業工具,怎麼可能沒有專業的處理方式呢,往下看:

在應用內,我們提供了兩種方式來獲取點陣圖的路徑數據,一種是利用 OpenCV 獲取圖片的物體邊緣數據,另一種是讓用戶自己定義想以怎樣的路徑描繪點陣圖。

第一種很容易理解,首先膜拜一下 OpenCV,電腦視覺方面的神器,我們這裡使用的就是 OpenCV 的邊緣檢測方法,它和圖像平滑演算法相反,是一種“高通濾波器”,去檢測圖像中像素跨度很大的點組成的邊緣,例如物體景觀的深度不連續,多面體錶面方向的不連續,光照和陰影的臨界,物體錶面材質不一致的臨界等,使用的方法有 Sobel,Laplacian 和 Canny,我們使用的是 Canny,效果如下圖:

  

點陣圖按照檢測到的邊緣路徑一點點描繪出來,只有路徑划過的地方纔顯示點陣圖,這樣就有了路徑描繪的視覺感受。其實這也是畫師在素材製作中一種很常見的方式,在 PS 中處理靜態圖片的特效,處理完成後保存導入到 AI 中,在靜態圖片上面描畫透明路徑,描繪完成後保存成 SVG 文件。這就是一種比較特殊的 SVG,包含了一張點陣圖作為底圖,而透明路徑的作用,是在路徑描繪時,顯示路徑對應位置的點陣圖像素。

另外一種方式,更多的由用戶自己來操作實現,相當於把我們的應用當作 AI,用戶自己準備的靜態圖片,放到應用中進行上面所說的路徑描繪,然後直接導入到應用內作為 SVG 使用。應用的界面和操作如下:

  

上面圖1是用戶操作界面,用戶可以指定畫筆的粗細來描繪路徑,描繪完成後,會以圖2到圖3的過程來描述點陣圖。如圖1中我們指定的路徑是先畫頭像的邊框,再用粗的畫筆描繪頭像的填充,就如圖2和圖3的過程一樣。

上述的兩種處理方式,一個是由系統來檢測點陣圖的邊緣,另一個是由用戶來指定邊緣,我們計劃把兩種方式結合在一起,先由系統檢測,再由用戶補充和糾正,這樣可以減少用戶操作的難度,因為有些點陣圖的邊緣會很複雜。另外系統檢測的一個缺點就是,邊緣路徑是完全無序,沒有分組的,就是說路徑不會按照物體的區別分組繪製,也不會按照某個固定順序繪製,這都需要我們後續再去處理,根據邊緣路徑的相連屬性去分組,在根據方向上的某個順序去處理排序,當然這還是一種簡單粗暴的處理方法。更深一層的處理,應該是檢測邊緣時,識別物體分類,也就是物體是什麼?然後根據這些信息分組和按照分類去排序。這些都是我們後面要做的事情。

點陣圖的處理方式就介紹到這裡了,如果大家有好的處理方法,或者有好的想法,歡迎聯繫我,感謝!

 


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

-Advertisement-
Play Games
更多相關文章
  • 第1章 rsync 軟體介紹 1.1 什麼是rsync rsync 是一款開源的、快速的、多功能的、可實現全量及增量的本地或遠程數據同步備份的優秀工具。 http://www.samba.org/ftp/rsync/rsync.html 1.1.1 全量及增量 全量:將全部數據,進行傳輸覆蓋 增量: ...
  • 步驟 1 執行命令apt-get update。 步驟 2 執行命令apt-get install lamp-server^。 步驟 3 在安裝過程中會跳出Mysql資料庫root用戶密碼設置視窗,按要求輸入密碼:123,按Tab鍵選擇“Ok”,按回車進入下一步,如下圖所示: 步驟 4 重覆輸入密碼 ...
  • 1.cd commond a. cd usr 切換到該目錄下usr目錄 b. cd ../ 切換到上一層目錄 c.cd / 切換到系統根目錄 d. cd ~ 切換到用戶主目錄 e. cd - 切換到上一個所在目錄 2.directory commond a.create directory comm ...
  • 那我們先來看看Dockerfile文件內容,註意這個文件是沒尾碼名的。 #依賴原始的鏡像,因為我們是要創建dotnet coer鏡像,所以我就用了官方給的鏡像【microsoft/dotnet:latest】,可以使用鏡像拉取命令【docker pull microsoft/dotnet:lates ...
  • 我們可能經常會用到 Thread.Sleep 函數來使線程掛起一段時間。那麼你有沒有正確的理解這個函數的用法呢?思考下麵這兩個問題: 假設現在是 2017-4-7 12:00:00.000,如果我調用一下 Thread.Sleep(1000) ,在 2017-4-7 12:00:01.000 的時候 ...
  • richtextbox插入回車,開始是這樣寫的,在win7下運行時沒有問題: MyMessageBox.CaretPosition.InsertLineBreak(); MyMessageBox.CaretPosition = MyMessageBox.CaretPosition.GetNextIn ...
  • 一、前言 C# 簡潔、類型安全的面向對象的語言。 .NET是一種在windows平臺上編程的架構——一種API。 C#是一種從頭開始設計的用於.NET的語言,他可以利用.NET Framework及其開發環境中的所有新增功能,面向對象的編程方法。 組件對象模型 COM Component Objec ...
  • 使用郵箱驗證修改密碼,在這裡我是使用163免費郵進行測試 前臺代碼 後臺代碼 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...