Линейная градиентная кисть Fade WPF
У меня есть кисть, цвета фона заголовка. Мне нравится, как выглядит кисть, но хотелось бы, чтобы она стала прозрачной в нижней трети. Есть идеи, как это сделать?
<LinearGradientBrush
x:Key="HeaderBackgroundBrush"
EndPoint=".5,1"
StartPoint="1,0">
<GradientStop Color="#006699" Offset="1"/>
<GradientStop Color="#80A8CC" Offset="0.5"/>
</LinearGradientBrush>
3 ответов
Я не уверен, что вы можете сделать это, работая только на уровне кисти, однако можно применить OpacityMask
к вашему контролю:
<LinearGradientBrush
x:Key="HeaderBackgroundOpacityMask"
StartPoint="0,0"
EndPoint="0,1">
<GradientStop Color="#FFFFFFFF" Offset="0"/>
<GradientStop Color="#FFFFFFFF" Offset="0.667"/>
<GradientStop Color="#00FFFFFF" Offset="1"/>
</LinearGradientBrush>
...
<Border Background="{StaticResource HeaderBackgroundBrush}"
OpacityMask="{StaticResource HeaderBackgroundOpacityMask}">
просто укажите цвета как ARGB (включая alpha), как это: #AARRGGBB. Затем дайте вашей последней остановке градиента Альфа-значение 0 (полностью прозрачное; в вашем случае #0080A8CC). HTH.
Если вы хотите сделать это на C#, используйте следующий код. Это даст вам светло-розовый / лосось до полностью прозрачной кисти. Измените #FF и #00, чтобы получить другой градиент прозрачности.
var startColour = (SolidColorBrush)new BrushConverter().ConvertFrom("#FFff99a8");
var endColour = (SolidColorBrush)new BrushConverter().ConvertFrom("#00ff99a8");
_dirtyColourBackground = new LinearGradientBrush(startColour.Color, endColour.Color,new Point(0,0),new Point(1,0));