<StackPanel xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/interactivedesigner/2006" mc:Ignorable="d" x:Class="PaintDrawExamples.DynamicClipping" Width="640" Height="480"> <StackPanel.Resources> <Storyboard x:Key="OnLoaded"/> </StackPanel.Resources> <StackPanel.Triggers> <EventTrigger RoutedEvent="FrameworkElement.Loaded"> <BeginStoryboard x:Name="OnLoaded_BeginStoryboard" Storyboard="{DynamicResource OnLoaded}"/> </EventTrigger> </StackPanel.Triggers> <Canvas Height="100" x:Name="Canvas" Width="436"> <Canvas.Clip> <PathGeometry> <PathFigure StartPoint="1,5" IsClosed="True" IsFilled="True"> <BezierSegment IsSmoothJoin="True" Point1="2,2" Point2="26,1" Point3="24,127" IsStroked="True"/> <BezierSegment IsSmoothJoin="True" Point1="1,1" Point2="14,9" Point3="19,5" IsStroked="True"/> <BezierSegment IsSmoothJoin="True" Point1="14,11" Point2="18,-22.5" Point3="24,-2" IsStroked="True"/> <BezierSegment IsSmoothJoin="True" Point1="26,-200" Point2="29,1" Point3="300,5" IsStroked="True"/> </PathFigure> </PathGeometry> </Canvas.Clip> <Rectangle d:LayoutOverrides="Height" Stroke="{x:Null}" Fill="Red" Width="436" Height="100" x:Name="Rectangle" Canvas.Left="0" Canvas.Top="0"/> <Label Background="Black" x:Name="Label" Content="This is my clipped space." Canvas.Left="46" Canvas.Top="26" d:IsHidden="True"/> </Canvas> </StackPanel> //File:Window.xaml.cs using System; using System.IO; using System.Net; using System.Windows; using System.Windows.Input; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Media; using System.Windows.Media.Animation; using System.Windows.Navigation; namespace PaintDrawExamples { public partial class DynamicClipping { public DynamicClipping() { this.InitializeComponent(); this.Canvas.VerticalAlignment = VerticalAlignment.Center; this.Canvas.HorizontalAlignment = HorizontalAlignment.Center; CompositionTarget.Rendering += CompositionTarget_Rendering; } private void CompositionTarget_Rendering(object sender, EventArgs e) { Point mousePos = Mouse.GetPosition(this.Canvas); Geometry clippingRegion = this.Canvas.Clip; TranslateTransform newPos = new TranslateTransform(); newPos.X = mousePos.X - (this.Canvas.Width / 2); newPos.Y = mousePos.Y - (this.Canvas.Height / 2); clippingRegion.Transform = newPos; } } }