有关如何将XAML矢量图像作为窗口背景的任何建议吗?有很多代码用jpg显示,但我更喜欢基于矢量的图像。
将它作为一种资源也是一种奖励,但我对最佳方法感到难过。
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<Viewbox x:Key="Background2" Stretch="Fill">
<Canvas >
<!-- Ebene 1/<Path> -->
<Path Fill="#ff000000" Data="F1 M 841.890,595.275 L 0.000,595.275 L 0.000,0.000 L 841.890,0.000 L 841.890,595.275 Z"/>
<!-- Ebene 1/<Path> -->
<Path Data="F1 M 265.910,218.277 C 265.910,169.332 223.865,129.655 172.000,129.655 C 120.135,129.655 78.090,169.332 78.090,218.277 C 78.090,267.222 120.135,306.898 172.000,306.898 C 223.865,306.898 265.910,267.222 265.910,218.277 Z">
<Path.Fill>
<RadialGradientBrush MappingMode="Absolute" GradientOrigin="172.733,217.234" Center="172.733,217.234" RadiusX="81.912" RadiusY="81.912">
<RadialGradientBrush.GradientStops>
<GradientStop Offset="0.00" Color="#ff0d4976"/>
<GradientStop Offset="0.41" Color="#ff06243b"/>
<GradientStop Offset="1.00" Color="#ff000000"/>
</RadialGradientBrush.GradientStops>
<RadialGradientBrush.Transform>
<MatrixTransform Matrix="1.146,0.000,0.000,1.082,-26.038,-16.750" />
</RadialGradientBrush.Transform>
</RadialGradientBrush>
</Path.Fill>
</Path>
</Canvas>
</Viewbox>
</ResourceDictionary>
如果您删除Viewbox,上面的资源代码可以正常工作。窗口的代码是: -
<Window x:Class="Window2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window2" Height="700" Width="800">
<Window.Resources>
<ResourceDictionary Source="Resources/Dictionary2.xaml" />
</Window.Resources>
<Grid>
<StaticResource ResourceKey="Background2"/>
</Grid>
</Window>
答案 0 :(得分:5)
试试这个
<Window.Resources>
<Canvas x:Key="Background2">
<!-- Ebene 1/<Path> -->
<Path Fill="#ff000000" Data="F1 M 841.890,595.275 L 0.000,595.275 L 0.000,0.000 L 841.890,0.000 L 841.890,595.275 Z"/>
<!-- Ebene 1/<Path> -->
<Path Data="F1 M 265.910,218.277 C 265.910,169.332 223.865,129.655 172.000,129.655 C 120.135,129.655 78.090,169.332 78.090,218.277 C 78.090,267.222 120.135,306.898 172.000,306.898 C 223.865,306.898 265.910,267.222 265.910,218.277 Z">
<Path.Fill>
<RadialGradientBrush MappingMode="Absolute"
GradientOrigin="172.733,217.234"
Center="172.733,217.234"
RadiusX="81.912" RadiusY="81.912">
<RadialGradientBrush.GradientStops>
<GradientStop Offset="0.00" Color="#ff0d4976"/>
<GradientStop Offset="0.41" Color="#ff06243b"/>
<GradientStop Offset="1.00" Color="#ff000000"/>
</RadialGradientBrush.GradientStops>
<RadialGradientBrush.Transform>
<MatrixTransform
Matrix="1.146,0.000,0.000,1.082,-26.038,-16.750" />
</RadialGradientBrush.Transform>
</RadialGradientBrush>
</Path.Fill>
</Path>
</Canvas>
</Window.Resources>
<Grid >
<Grid.Background>
<VisualBrush Stretch="Fill" Visual="{StaticResource Background2}" />
</Grid.Background>
</Grid>
如果绝对必要,您只需进行一些更改即可将资源移至资源字典中。
答案 1 :(得分:1)
许多工具(包括Illustrator)允许您以不同的格式导出XAML图像。您理想的目标是ResourceDictionary
,其中包含Canvas
或Grid
面板,其中包含您的矢量图像。然后,您可以在Window.Resources
中引用字典,只需将图片面板(Canvas
或Grid
)添加到顶级窗口面板。
所以你的图像.XAML文件需要看起来像这样:
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<Canvas x:Name="MyXamlImage">
...
</Canvas>
</ResourceDictionary>
然后在你的Window
中你应该有类似的东西:
<Window x:Class="YourNamespace.YourWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="YourWindow" Height="300" Width="300">
<Window.Resources>
<ResourceDictionary Source="MyResourceDictionary.xaml">
</Window.Resources>
<Grid>
<StaticResource ResourceKey="MyXamlImage"/>
...
</Grid>
</Window>