麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > C# > 正文

WPF InkCanvas繪制矩形和橢圓

2019-10-29 19:41:17
字體:
供稿:網(wǎng)友

前面說到了InkCanvas的基本操作,這里用一個(gè)實(shí)例來說明具體應(yīng)用:繪制矩形和橢圓。

效果圖

WPF,InkCanvas,矩形,橢圓

xaml代碼

<Window x:Class="WPF_InkCanvas.ROI_InkCanvas"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"    xmlns:local="clr-namespace:WPF_InkCanvas"    mc:Ignorable="d"  <Grid>    <Grid.RowDefinitions>      <RowDefinition/>      <RowDefinition Height="auto"/>    </Grid.RowDefinitions>    <Image Name="imgMeasure" HorizontalAlignment="Center" Stretch="Uniform"/>    <InkCanvas Name="inkCanvasMeasure" EditingMode="None" Background="Transparent" Strokes="{Binding InkStrokes, Mode=TwoWay}" HorizontalAlignment="Center"           Width="{Binding ElementName=imgMeasure, Path=ActualWidth}" Height="{Binding ElementName=imgMeasure, Path=ActualHeight}"          MouseDown="InkCanvasMeasure_MouseDown" MouseMove="InkCanvasMeasure_MouseMove">      <Label Content="{Binding MeaInfo}" Background="Transparent" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="10"           FontSize="18" Foreground="Red" IsHitTestVisible="False"/>    </InkCanvas>    <StackPanel Grid.Row="1" Orientation="Horizontal">      <Button Content="OpenFile" Margin="5" HorizontalAlignment="Left" FontSize="20" Click="OpenFile_Click"/>      <ToggleButton Name="btnSquare" Content="Draw Square" Margin="5" HorizontalAlignment="Left" FontSize="20" Click="DrawSquare_Click"/>      <ToggleButton Name="btnEllipse" Content="Draw Ellipse" Margin="5" HorizontalAlignment="Left" FontSize="20" Click="DrawEllipse_Click"/>    </StackPanel>  </Grid></Window>

后臺(tái)代碼

using Microsoft.Win32;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows;using System.Windows.Controls;using System.Windows.Data;using System.Windows.Documents;using System.Windows.Ink;using System.Windows.Input;using System.Windows.Media;using System.Windows.Media.Imaging;using System.Windows.Shapes; namespace WPF_InkCanvas{  /// <summary>  /// ROI_InkCanvas.xaml 的交互邏輯  /// </summary>  public partial class ROI_InkCanvas : Window  {    private ViewModel viewModel;    private System.Windows.Point iniP;    public ROI_InkCanvas()    {      InitializeComponent();       DrawingAttributes drawingAttributes = new DrawingAttributes      {        Color = Colors.Red,        Width = 2,        Height = 2,        StylusTip = StylusTip.Rectangle,        //FitToCurve = true,        IsHighlighter = false,        IgnorePressure = true,       };      inkCanvasMeasure.DefaultDrawingAttributes = drawingAttributes;       viewModel = new ViewModel      {        MeaInfo = "測試······",        InkStrokes = new StrokeCollection(),      };       DataContext = viewModel;    }     private void OpenFile_Click(object sender, RoutedEventArgs e)    {      OpenFileDialog openDialog = new OpenFileDialog      {        Filter = "Image Files (*.jpg)|*.jpg|Image Files (*.png)|*.png|Image Files (*.bmp)|*.bmp",      };      if (openDialog.ShowDialog() == true)      {        BitmapImage image = new BitmapImage();        image.BeginInit();        image.UriSource = new Uri(openDialog.FileName, UriKind.RelativeOrAbsolute);        image.EndInit();        imgMeasure.Source = image;      }    }     private void DrawSquare_Click(object sender, RoutedEventArgs e)    {      if (btnSquare.IsChecked == true)      {        btnEllipse.IsChecked = false;      }    }      private void DrawEllipse_Click(object sender, RoutedEventArgs e)    {      if (btnEllipse.IsChecked == true)      {        btnSquare.IsChecked = false;      }    }     private List<System.Windows.Point> GenerateEclipseGeometry(System.Windows.Point st, System.Windows.Point ed)    {      double a = 0.5 * (ed.X - st.X);      double b = 0.5 * (ed.Y - st.Y);      List<System.Windows.Point> pointList = new List<System.Windows.Point>();      for (double r = 0; r <= 2 * Math.PI; r = r + 0.01)      {        pointList.Add(new System.Windows.Point(0.5 * (st.X + ed.X) + a * Math.Cos(r), 0.5 * (st.Y + ed.Y) + b * Math.Sin(r)));      }      return pointList;    }    private void InkCanvasMeasure_MouseDown(object sender, MouseButtonEventArgs e)    {      if (e.LeftButton == MouseButtonState.Pressed)      {        iniP = e.GetPosition(inkCanvasMeasure);      }    }     private void InkCanvasMeasure_MouseMove(object sender, MouseEventArgs e)    {      if (e.LeftButton == MouseButtonState.Pressed)      {        // Draw square        if (btnSquare.IsChecked == true)        {          System.Windows.Point endP = e.GetPosition(inkCanvasMeasure);          List<System.Windows.Point> pointList = new List<System.Windows.Point>          {            new System.Windows.Point(iniP.X, iniP.Y),            new System.Windows.Point(iniP.X, endP.Y),            new System.Windows.Point(endP.X, endP.Y),            new System.Windows.Point(endP.X, iniP.Y),            new System.Windows.Point(iniP.X, iniP.Y),          };          StylusPointCollection point = new StylusPointCollection(pointList);          Stroke stroke = new Stroke(point)          {            DrawingAttributes = inkCanvasMeasure.DefaultDrawingAttributes.Clone()          };          viewModel.InkStrokes.Clear();          viewModel.InkStrokes.Add(stroke);        }        // Draw Eclipse        else if (btnEllipse.IsChecked == true)        {          System.Windows.Point endP = e.GetPosition(inkCanvasMeasure);          List<System.Windows.Point> pointList = GenerateEclipseGeometry(iniP, endP);          StylusPointCollection point = new StylusPointCollection(pointList);          Stroke stroke = new Stroke(point)          {            DrawingAttributes = inkCanvasMeasure.DefaultDrawingAttributes.Clone()          };          viewModel.InkStrokes.Clear();          viewModel.InkStrokes.Add(stroke);        }      }    }  }}

ViewModel.cs代碼

using System;using System.Collections.Generic;using System.ComponentModel;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows.Ink; namespace WPF_InkCanvas{  class ViewModel : INotifyPropertyChanged  {    public event PropertyChangedEventHandler PropertyChanged;     protected virtual void OnPropertyChanged(string propertyName = null)    {      if (PropertyChanged != null)        PropertyChanged.Invoke(this, new PropertyChangedEventArgs(propertyName));    }     private string meaInfo;    public string MeaInfo    {      get => meaInfo;      set      {        meaInfo = value;        OnPropertyChanged("MeaInfo");      }    }     private StrokeCollection inkStrokes;    public StrokeCollection InkStrokes    {      get { return inkStrokes; }      set      {        inkStrokes = value;        OnPropertyChanged("InkStrokes");      }    }  }}

補(bǔ)充說明:為什么要注釋掉畫筆屬性//FitToCurve = true,可以自行體會(huì)下不注釋會(huì)是個(gè)什么效果;將InkCanvas的Strokes綁定到變量有好處,在別的窗口也能獲取到這個(gè)對(duì)象的哦,因?yàn)樗窃趘iewModel里的,傳viewModel參數(shù)就可以了;橢圓繪制完成后設(shè)置InkCanvas的EdittingMode為Select就可以修改大小和形狀。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到c#教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 日本在线播放一区二区三区 | 国产一级毛片国产 | 国产精品二区高清在线 | 最新中文字幕日本 | 91成人在线免费视频 | 91九色国产视频 | 成人免费乱码大片a毛片视频网站 | 国产毛片视频 | 免费国产在线精品 | 日本欧美中文字幕 | 中国精品久久 | 中文欧美日韩 | 激情视频导航 | 亚洲最黄视频 | 国产精品视频2021 | 99国产精品白浆在线观看免费 | 久久久www成人免费毛片 | 欧美一级免费在线观看 | 少妇一级淫片免费放正片 | 7777网站| 精品国产一区二区在线 | 狠狠干网站 | 中国漂亮护士一级a毛片 | 久久国产精品久久久久久久久久 | 久久亚洲精品久久国产一区二区 | 久久国产精品二国产精品中国洋人 | 国产一区视频观看 | 午夜精品小视频 | 91精品国产乱码久久久久 | 久久宗合色 | 一区二区三区国产在线 | 精品一区在线视频 | 欧美天堂一区 | 久久精品国产亚洲7777小说 | 亚洲特黄a级毛片在线播放 久久久入口 | 日韩理论电影网 | 欧美成人二区 | 久久青草热 | 国产精品自在线拍 | 午夜视频亚洲 | 色综合视频|