zoukankan      html  css  js  c++  java
  • WPF 元素裁剪 Clip 属性

    本文介绍如何在 WPF 使用 Clip 裁剪元素

    在 WPF 的 UIElement 提供了 Clip 属性,这个属性默认是空,但是如果设置了这个属性就会对元素进行裁剪

    这个属性是一个 Geometry 属性,设置的值表示裁剪之后剩下的部分,如写一个简单的类继承 UIElement 然后对他进行裁剪

        class SisdecereYipuVayderyecallMawqere : UIElement
        {
            /// <inheritdoc />
            public SisdecereYipuVayderyecallMawqere()
            {
            }
    
            /// <inheritdoc />
            protected override void OnRender(DrawingContext drawingContext)
            {
                drawingContext.DrawRectangle(Brushes.Black,null,new Rect(10,10,100,100));
            }
        }
    

    现在这个类会在 10,10 的坐标画出大小是 100 的矩形

    对他裁剪,设置裁剪的是矩形裁剪

            public SisdecereYipuVayderyecallMawqere()
            {
                Clip = new RectangleGeometry(new Rect(30, 30, 50, 50));
            }
    

    从图片很难看出来不同,只是可以看到两个矩形,第一个矩形比较大

    对他进行圆形裁剪

            public SisdecereYipuVayderyecallMawqere()
            {
                Clip = new EllipseGeometry(new Point(30, 30), 10, 10);
            }
    

    可以看到显示的是圆形

    因为设置 Clip 属性是一个裁剪的窗口,只有在裁剪区域之内才可以显示

    因为 Geometry 是可以做到不连续的,所以可以做出部分的透明,如裁剪两个矩形

            public SisdecereYipuVayderyecallMawqere()
            {
                Geometry geometry = new RectangleGeometry(new Rect(10,10,10,10));
                geometry = Geometry.Combine(geometry, new RectangleGeometry(new Rect(30, 30, 10, 10)),
                    GeometryCombineMode.Union, null);
    
                Clip = geometry;
            }
    

    WPF 通过 DrawingContext DrawImage 绘制图片

    知识共享许可协议
    本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系

  • 相关阅读:
    读理,妙句秒人秒事,二记
    读理,妙句秒人秒事,一记
    (原)DirectX11 深度测试(有点另类)
    游戏编程书籍推荐
    android入门-环境搭建
    Spring||Interview
    JSR-133内存模型手册
    JVM执行引擎
    HIbernate总结
    虚拟机类加载机制
  • 原文地址:https://www.cnblogs.com/lindexi/p/12086959.html
Copyright © 2011-2022 走看看