背水一戰 Windows 10 (62) - 控制項(媒體類): InkCanvas 保存和載入, 手寫識別

来源:http://www.cnblogs.com/webabcd/archive/2017/09/11/7503395.html
-Advertisement-
Play Games

背水一戰 Windows 10 之 控制項(媒體類): InkCanvas 保存和載入, InkCanvas 手寫識別 ...


[源碼下載]


背水一戰 Windows 10 (62) - 控制項(媒體類): InkCanvas 保存和載入, 手寫識別



作者:webabcd


介紹
背水一戰 Windows 10 之 控制項(媒體類)

  • InkCanvas 保存和載入
  • InkCanvas 手寫識別



示例
1、演示 InkCanvas 塗鴉板的保存和載入
Controls/MediaControl/InkCanvasDemo3.xaml

<Page
    x:Class="Windows10.Controls.MediaControl.InkCanvasDemo3"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.MediaControl"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <StackPanel Margin="10 0 10 10">

            <Border Background="White" Width="480" Height="320" Margin="5" HorizontalAlignment="Left">
                <!--
                    InkCanvas - 塗鴉板控制項
                -->
                <InkCanvas Name="inkCanvas" />
            </Border>

            <Button Name="save" Content="保存到文件" Margin="5" Click="save_Click" />
            <Button Name="load" Content="從文件讀取" Margin="5" Click="load_Click" />

        </StackPanel>
    </Grid>
</Page>

Controls/MediaControl/InkCanvasDemo3.xaml.cs

/*
 * InkCanvas - 塗鴉板控制項(繼承自 FrameworkElement, 請參見 /Controls/BaseControl/FrameworkElementDemo/)
 *     InkPresenter - 獲取 InkPresenter 對象
 *        
 * InkPresenter - 塗鴉板
 *     StrokeContainer - 返回 InkStrokeContainer 類型的對象
 *     
 * InkStrokeContainer - 用於管理塗鴉
 *     IAsyncOperationWithProgress<UInt32, UInt32> SaveAsync(IOutputStream outputStream) - 保存塗鴉數據
 *     IAsyncActionWithProgress<UInt64> LoadAsync(IInputStream inputStream) - 載入塗鴉數據
 */

using System;
using System.Collections.Generic;
using Windows.Foundation;
using Windows.Storage;
using Windows.Storage.Pickers;
using Windows.Storage.Streams;
using Windows.UI;
using Windows.UI.Core;
using Windows.UI.Input.Inking;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.MediaControl
{
    public sealed partial class InkCanvasDemo3 : Page
    {
        public InkCanvasDemo3()
        {
            this.InitializeComponent();

            inkCanvas.InkPresenter.InputDeviceTypes = CoreInputDeviceTypes.Mouse | CoreInputDeviceTypes.Pen | CoreInputDeviceTypes.Touch;

            InkDrawingAttributes drawingAttributes = inkCanvas.InkPresenter.CopyDefaultDrawingAttributes();
            drawingAttributes.IgnorePressure = true;
            drawingAttributes.Color = Colors.Red;
            drawingAttributes.Size = new Size(4, 4);
            inkCanvas.InkPresenter.UpdateDefaultDrawingAttributes(drawingAttributes);
        }

        private async void save_Click(object sender, RoutedEventArgs e)
        {
            if (inkCanvas.InkPresenter.StrokeContainer.GetStrokes().Count == 0)
                return;

            // 用於保存塗鴉數據
            IRandomAccessStream stream = new InMemoryRandomAccessStream();
            await inkCanvas.InkPresenter.StrokeContainer.SaveAsync(stream);

            // 文件保存對話框
            var picker = new FileSavePicker
            {
                SuggestedStartLocation = PickerLocationId.DocumentsLibrary
            };
            picker.FileTypeChoices.Add("ink files", new List<string>() { ".ink" });

            // 彈出文件保存對話框
            var file = await picker.PickSaveFileAsync();
            if (file == null)
                return;

            // 在調用 CompleteUpdatesAsync 之前,阻止對文件的更新
            CachedFileManager.DeferUpdates(file);

            // Stream 轉 byte[]
            DataReader reader = new DataReader(stream.GetInputStreamAt(0));
            await reader.LoadAsync((uint)stream.Size);
            byte[] bytes = new byte[stream.Size];
            reader.ReadBytes(bytes);

            // 寫入文件
            await FileIO.WriteBytesAsync(file, bytes);

            // 保存文件
            await CachedFileManager.CompleteUpdatesAsync(file);
        }

        private async void load_Click(object sender, RoutedEventArgs e)
        {
            // 文件打開對話框
            var picker = new FileOpenPicker
            {
                SuggestedStartLocation = PickerLocationId.DocumentsLibrary
            };
            picker.FileTypeFilter.Add(".ink");

            // 彈出文件打開對話框
            var pickedFile = await picker.PickSingleFileAsync();
            if (pickedFile != null)
            {
                // 讀取塗鴉數據
                IRandomAccessStreamWithContentType stream = await pickedFile.OpenReadAsync();

                // 載入指定的塗鴉數據
                await inkCanvas.InkPresenter.StrokeContainer.LoadAsync(stream);
            }
        }
    }
}


2、演示 InkCanvas 塗鴉板的手寫識別
Controls/MediaControl/InkCanvasDemo4.xaml

<Page
    x:Class="Windows10.Controls.MediaControl.InkCanvasDemo4"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.MediaControl"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <StackPanel Margin="10 0 10 10">

            <Border Background="White" Width="480" Height="320" Margin="5" HorizontalAlignment="Left">
                <!--
                    InkCanvas - 塗鴉板控制項
                -->
                <InkCanvas Name="inkCanvas" />
            </Border>

            <Button Name="recognize" Content="手寫識別" Margin="5" Click="recognize_Click" />

            <TextBlock Name="lblMsg" Margin="5" />

        </StackPanel>
    </Grid>
</Page>

Controls/MediaControl/InkCanvasDemo4.xaml.cs

/*
 * InkCanvas - 塗鴉板控制項(繼承自 FrameworkElement, 請參見 /Controls/BaseControl/FrameworkElementDemo/)
 *     InkPresenter - 獲取 InkPresenter 對象
 *        
 * InkRecognizerContainer - 用於管理手寫識別
 *     GetRecognizers() - 獲取 InkRecognizer 對象集合
 *     SetDefaultRecognizer(InkRecognizer recognizer) - 將指定的 InkRecognizer 設置為預設的手寫識別器
 *     RecognizeAsync(InkStrokeContainer strokeCollection, InkRecognitionTarget recognitionTarget) - 識別,返回 InkRecognitionResult 對象集合
 *         InkStrokeContainer strokeCollection - 需要識別的 InkStrokeContainer 對象
 *         InkRecognitionTarget recognitionTarget - 需要識別的目標
 *             All - 識別全部塗鴉數據
 *             Selected - 識別被選中的塗鴉數據
 *             Recent - 識別 InkStroke 的 Recognized 為 false 的塗鴉數據
 *             
 * InkRecognizer - 手寫識別器
 *     Name - 手寫識別器的名字(只讀)
 * 
 * InkRecognitionResult - 手寫識別結果
 *     BoundingRect - 獲取用於識別的塗鴉的 Rect 區域
 *     GetStrokes() - 獲取用於識別的 InkStroke 對象集合
 *     GetTextCandidates() - 獲取識別結果,這是一個候選結果列表
 * 
 * InkPresenter - 塗鴉板
 *     StrokeContainer - 返回 InkStrokeContainer 類型的對象
 *     
 * InkStrokeContainer - 用於管理塗鴉
 *     UpdateRecognitionResults(IReadOnlyList<InkRecognitionResult> recognitionResults) - 將指定的識別結果通知給 InkStrokeContainer(此時 InkStrokeContainer 中被識別的 InkStroke 的 Recognized 將被標記為 true)
 *         如果使用的是 InkRecognitionTarget.All 則 InkStrokeContainer 中的所有的 InkStroke 的 Recognized 將被標記為 true
 *         如果使用的是 InkRecognitionTarget.Selected 則 InkStrokeContainer 中的被選中的 InkStroke 的 Recognized 將被標記為 true
 *     GetRecognitionResults() - 返回之前通過 UpdateRecognitionResults 方法設置的數據
 *     
 * InkStroke - 塗鴉對象(這是一次的塗鴉對象,即滑鼠按下後移動然後再抬起後所繪製出的塗鴉)
 *     Recognized - 此 InkStroke 是否被識別了
 *     Selected - 此 InkStroke 是否被選中了
 */

using System;
using System.Collections.Generic;
using System.Diagnostics;
using Windows.Foundation;
using Windows.UI;
using Windows.UI.Core;
using Windows.UI.Input.Inking;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.MediaControl
{
    public sealed partial class InkCanvasDemo4 : Page
    {
        public InkCanvasDemo4()
        {
            this.InitializeComponent();

            inkCanvas.InkPresenter.InputDeviceTypes = CoreInputDeviceTypes.Mouse | CoreInputDeviceTypes.Pen | CoreInputDeviceTypes.Touch;

            InkDrawingAttributes drawingAttributes = inkCanvas.InkPresenter.CopyDefaultDrawingAttributes();
            drawingAttributes.IgnorePressure = true;
            drawingAttributes.Color = Colors.Red;
            drawingAttributes.Size = new Size(4, 4);
            inkCanvas.InkPresenter.UpdateDefaultDrawingAttributes(drawingAttributes);
        }

        private async void recognize_Click(object sender, RoutedEventArgs e)
        {
            if (inkCanvas.InkPresenter.StrokeContainer.GetStrokes().Count == 0)
                return;

            InkRecognizerContainer container = new InkRecognizerContainer();

            lblMsg.Text = "手寫識別器: ";
            lblMsg.Text += Environment.NewLine;
            // 獲取當前支持的手寫識別器列表,如果有多個的話可以通過 SetDefaultRecognizer 方法來指定預設的手寫識別器
            IReadOnlyList<InkRecognizer> recognizers = container.GetRecognizers();
            foreach (InkRecognizer ir in recognizers)
            {
                lblMsg.Text += ir.Name;
                lblMsg.Text += Environment.NewLine;
            }

            lblMsg.Text += Environment.NewLine;
            lblMsg.Text += "識別結果: ";
            lblMsg.Text += Environment.NewLine;
            IReadOnlyList<InkRecognitionResult> result = await container.RecognizeAsync(inkCanvas.InkPresenter.StrokeContainer, InkRecognitionTarget.All);
            foreach (string textCandidate in result[0].GetTextCandidates())
            {
                lblMsg.Text += textCandidate;
                lblMsg.Text += Environment.NewLine;
            }

            // 將識別結果通知給 InkStrokeContainer
            inkCanvas.InkPresenter.StrokeContainer.UpdateRecognitionResults(result);

            // 識別結果通知給 InkStrokeContainer 後,被識別的 InkStroke 的 Recognized 將被標記為 true
            // 如果在識別的時候使用的是 InkRecognitionTarget.All 則所有的 InkStroke 的 Recognized 將被標記為 true
            // 如果在識別的時候使用的是 InkRecognitionTarget.Selected 則被選中的 InkStroke 的 Recognized 將被標記為 true
            IReadOnlyList<InkStroke> strokes = inkCanvas.InkPresenter.StrokeContainer.GetStrokes();
            foreach (InkStroke stroke in strokes)
            {
                Debug.WriteLine("stroke.Recognized: " + stroke.Recognized);
            }

            // 這個獲取到的就是之前通過 InkStrokeContainer 方式設置的數據
            result = inkCanvas.InkPresenter.StrokeContainer.GetRecognitionResults();
        }
    }
}



OK
[源碼下載]


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

-Advertisement-
Play Games
更多相關文章
  • 第一部分Mem行: total 記憶體總數: 1002M used 已經使用的記憶體數: 769M free 空閑的記憶體數: 232M shared 當前已經廢棄不用,總是0 buffers Buffer 緩存記憶體數: 62M cached Page 緩存記憶體數:421M 關係:total(1002M) ...
  • 一、應用練習 1.需求練習 編寫登陸介面 要求: 讓用戶輸入用戶名密碼 認證成功後顯示歡迎信息 輸錯三次後退出程式 #!/usr/bin/env python #coding:utf-8 time=0 data={ 'zhangsan':{'ps':'zs123'}, 'lisi':{'ps':'l ...
  • 多路復用的適用場合 • 當客戶處理多個描述符時(例如同時處理互動式輸入和網路套介面),必須使用I/O復用。 • 如果一個TCP伺服器既要處理監聽套介面,又要處理已連接套介面,一般也要用到I/O復用。 • 如果一個伺服器即要處理TCP,又要處理UDP,一般要使用I/O復用。 • 如果一個伺服器要處理多 ...
  • protected void ByteToString_Click(object sender, EventArgs e) { string content = this.txtContent.Text.ToString(); if (string.IsNullOrEmpty(content)) { ...
  • 環境: Windows 10,Visual Studio 2017 centos 7,nginx,supervisor,dotnet core 1.1 問題: 在 Linux 配置 supervisor 時,如下命令運行項目會出現各種路徑問題,可能涉及一個 work dir 的概念;Windows ...
  • 平時還是比較喜歡看書的。。但有時候遇到問題還是經常感到腦袋一蒙。。智商果然是硬傷。。 同事發現了個問題,代碼如下: 在使用HttpClient的GetAsync請求後阻塞查詢.Result“死鎖了”,我們知道GetAsync內部也是一個後臺線程在執行,直到獲取到結果時會調用Task中的SetResu ...
  • ViewComponent 1、View 組件介紹 在ASP.NET CORE MVC中,View組件有點類似於partial views,但是他們更強大,View組件不能使用model binding,當你調用它的時候僅僅依賴與你提供的數據一個View組件特點: .呈現一大塊而不是一個整體的響應。 ...
  • 創建StringHelper類 首先資料庫里的資料是加密了的。 創建將指定的字元串加密為MD5密文方法 public static string ToMD5(string source) { StringBuilder sb = new StringBuilder(); MD5 md5 = MD5. ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...