首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WPF Canvas 画区域

WPF Canvas 画区域

作者头像
叁金
发布2018-09-04 14:53:00
1.3K0
发布2018-09-04 14:53:00
举报
文章被收录于专栏:叁金大数据叁金大数据

有时候需要实现类似于QQ截图那样的选择区域功能,这里的区域可以是一条线,圆,矩形等等

实现原理就是一个Canvas做蒙板,然后canvas的三个事件,MouseLeftButtonDown,MouseMove,MouseLeftButtonUp。非常easy!

首先,你要有个canvas

<Canvas Name="videocanvas" Height="288" Width="352" Background="Transparent" MouseMove="image_MouseMove" MouseLeftButtonDown="Mask_MouseLeftButtonDown" MouseLeftButtonUp="Mask_MouseLeftButtonUp"/>

然后实现他的事件,在之前我们先决定一下到底是什么形状的区域。

1 public static Shape CreateShape()
2 {
3     //矩形区域
4     return new System.Windows.Shapes.Rectangle() { Fill = null, Stroke = System.Windows.Media.Brushes.Red, StrokeThickness = 1 };
5     //圆形区域
6     //return new System.Windows.Shapes.Ellipse() { Fill = null, Stroke = System.Windows.Media.Brushes.Red, StrokeThickness = 1 };
7 
8 }

然后实现三个事件

bool drawFlag = false;
Shape insertShape;
System.Windows.Point startPosition;


private void Mask_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
    insertShape = CreateShape();
    if (insertShape != null)
    {
        drawFlag = true;
        Canvas board = sender as Canvas;
        board.Children.Clear();
        startPosition = e.GetPosition(board);
        insertShape.Opacity = 1;
        Canvas.SetLeft(insertShape, e.GetPosition(board).X);
        Canvas.SetTop(insertShape, e.GetPosition(board).Y);
        board.Children.Add(insertShape);
    }
}

private void image_MouseMove(object sender, MouseEventArgs e)
{
    Canvas board = sender as Canvas;
    if (drawFlag && insertShape != null)
    {
        if (e.GetPosition(board).X > startPosition.X)
        {
            insertShape.Width = e.GetPosition(board).X - startPosition.X;
            
        }
        else
        {
            insertShape.Width = startPosition.X - e.GetPosition(board).X;
            Canvas.SetLeft(insertShape, e.GetPosition(board).X);
        }
        if (e.GetPosition(board).Y > startPosition.Y)
        {
            insertShape.Height = e.GetPosition(board).Y - startPosition.Y;
        }
        else
        {
            insertShape.Height = startPosition.Y - e.GetPosition(board).Y;
            Canvas.SetTop(insertShape, e.GetPosition(board).Y);
        }
    }
}

private void Mask_MouseLeftButtonUp(object sender, MouseButtonEventArgs e)
{
    drawFlag = false;
    if (insertShape != null)
    {
        insertShape.Opacity = 1;
        System.Windows.Point p = e.GetPosition(sender as Canvas);
        Canvas.SetLeft(insertShape, e.GetPosition(board).X);
        Canvas.SetTop(insertShape, e.GetPosition(board).Y);
    }
}

本来还想做个多边形的例子,水平有限,没达到我想要的效果。研究研究再发。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-08-14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档