/ / Ustaw granicę dla VisualBrush w WPF - c #, wpf, region, visualbrush, hatchstyle

Ustaw granicę dla VisualBrush w WPF - c #, wpf, region, visualbrush, hatchstyle

Jest niebieski prostokąt wypełniony niestandardowym VisualBrush (lewy obraz). Przez prostokąt przechodzi linia. Jak przycinać pędzel, aby uzyskać kształt na odpowiednim obrazie.

wprowadź opis obrazu tutaj

Odpowiedzi:

0 dla odpowiedzi № 1

Spójrz na LinearGradientBrush. Chcesz użyć czegoś takiego do niestandardowego VisualBrush.

    <Rectangle Width="100" Height="200">
<Rectangle.Fill>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="Blue" Offset="0"/>
<GradientStop Color="Blue" Offset="0.405"/>
<GradientStop Color="Black" Offset="0.405"/>
<GradientStop Color="Black" Offset="0.722"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>

Nie wiem, jaki jest twój niestandardowy pędzel, ale jeśli pozwolisz mu działać podobnie do pędzla gradientowego.

Inną opcją jest faktyczne posiadanie dwóch prostokątów z separatorem pomiędzy nimi i każdy ma oddzielną szczotkę gradientową. Wtedy czerwona linia będzie w rzeczywistości kolorem tła Separator.

    <DockPanel Width="100" Height="200">
<Rectangle DockPanel.Dock="Top" Height="100" Margin="0">
<Rectangle.Fill>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="Black" Offset="1"/>
<GradientStop Color="White"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>
<Separator Height="2" DockPanel.Dock="Top" Background="Red" Margin="0"></Separator>
<Rectangle Margin="0" Fill="Black"/>
</DockPanel>