国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

WPF 在image控件用鼠標拖拽出矩形的實現方法

2019-10-29 21:01:38
字體:
來源:轉載
供稿:網友

今天有小伙伴問我一個問題,在image控件用鼠標拖拽出矩形,本文告訴大家如何使用鼠標畫出矩形

做出來的效果先請大家看一下

WPF,image控件,鼠標拖,矩形

最簡單的方法是在 Down 的時候記錄按下的點,在 移動的時候重新計算所在的寬度

WPF,image控件,鼠標拖,矩形

先在界面使用一個圖片和一個矩形

<Grid x:Name="Grid">    <Image Source="TIM截圖20180811150831.png"></Image>    <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center">歡迎訪問我博客 http://lindexi.oschina.io </TextBlock>    <Rectangle x:Name="Rectangle" StrokeThickness="2" Stroke="Black" HorizontalAlignment="Left" VerticalAlignment="Top"></Rectangle>  </Grid>

需要注意,圖片的位置需要修改為自己需要的圖片

這里的 Rectangle 需要做一些設置,主要 HorizontalAlignment 和 VerticalAlignment 必須設置為左上角

現在打開 cs 代碼,在按下和移動修改矩形

MouseDown += MainWindow_MouseDown;      MouseMove += MainWindow_MouseMove;      MouseUp += MainWindow_MouseUp;

需要兩個字段來記錄當前是否按下和第一次按下所在的坐標

剛才給 Grid 的命名就是為了拿到相對 Grid 的坐標

private void MainWindow_MouseDown(object sender, MouseButtonEventArgs e)    {      _started = true;      _downPoint = e.GetPosition(Grid);    }    private bool _started;    private Point _downPoint;

在鼠標按下時拿到按下的坐標,通過這個坐標就可以計算出矩形所在的位置

private void MainWindow_MouseUp(object sender, MouseButtonEventArgs e)    {      _started = false;    }    private void MainWindow_MouseMove(object sender, MouseEventArgs e)    {      if (_started)      {        var point = e.GetPosition(Grid);        var rect = new Rect(_downPoint, point);        Rectangle.Margin = new Thickness(rect.Left, rect.Top, 0, 0);        Rectangle.Width = rect.Width;        Rectangle.Height = rect.Height;      }    }

代碼就是這么簡單,通過修改 Margin 的方法修改矩形

如果對于高手,我建議使用 RenderTransform 的方式而不是使用 Margin 這里使用這個方法只是看起來簡單

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌恰县| 五指山市| 布尔津县| 娱乐| 万荣县| 清水县| 鹤山市| 黑河市| 乐平市| 北流市| 万宁市| 安塞县| 呈贡县| 扎囊县| 宜昌市| 奉化市| 永丰县| 德惠市| 海林市| 清镇市| 嫩江县| 松滋市| 营山县| 大化| 东至县| 辰溪县| 长汀县| 苍梧县| 白水县| 镇原县| 平遥县| 屏东县| 大悟县| 修武县| 广安市| 深水埗区| 亚东县| 赤水市| 凤山县| 越西县| 岳池县|