data:image/s3,"s3://crabby-images/24d71/24d71389244e4c618b7b38daea63fb672b27901a" alt="clock"
September 6, 2018 09:06 by
Peter
The Clip property of an element (defined in the UIElement class) is used to clip a region and represents the geometry that defines the content of an element.
data:image/s3,"s3://crabby-images/67b1e/67b1ec222c4d632caed4bd04b1dc0e2594dac61f" alt=""
The Clip property takes a Geometry type that can be a line, rectangle, ellipse, or group geometry.
The following XAML code snippet uses an Image object to display an image.
<Image Source="Waterfall.jpg"
Width="300" Height="300">
The output looks like this
data:image/s3,"s3://crabby-images/3c73e/3c73ec1e4ed58f58ea5f552ab34dabd3905008e2" alt=""
The XAML code in Listing 1 sets the Image.Clip property to an EllipseGeometry and sets the RadiusX, RadiusY, and Center properties of the geometry.
<Image Source="Waterfall.jpg"
Width="300" Height="300">
<Image.Clip>
<EllipseGeometry
RadiusX="100"
RadiusY="100"
Center="200,150"/>
</Image.Clip>
</Image>
The new output looks like this,
data:image/s3,"s3://crabby-images/35a98/35a98e988f9b1d52f8a37e419f1a586e1daa9de8" alt=""
Figure 2. A clipped image
Since the Clip property is defined in the UIElement, it can be applied to any element. For example, the following code generates a rectangle looks like Figure 3.
<Rectangle Width="300" Height="200"
Stroke="Black" StrokeThickness="4"
Fill="Yellow">
<Rectangle.Clip>
<EllipseGeometry
RadiusX="150"
RadiusY="100"
Center="150,100"/>
</Rectangle.Clip>
</Rectangle>
data:image/s3,"s3://crabby-images/a2620/a26202e15e320433b2a9ab8b7dea6a557c51f417" alt=""
Now we can apply clipping on the rectangle and the new output looks like Figure 4 with the following code.
<Rectangle Width="300" Height="200"
Stroke="Black" StrokeThickness="4"
Fill="Yellow">
<Rectangle.Clip>
<EllipseGeometry
RadiusX="150"
RadiusY="100"
Center="150,100"/>
</Rectangle.Clip>
</Rectangle>
data:image/s3,"s3://crabby-images/f16c4/f16c4aa70f076d8c0077862a33c721a1449cb5aa" alt=""