如何在C#WPF窗口中添加svg / xaml文件,就像图像一样?

时间:2014-10-01 21:49:01

标签: c# wpf xaml svg

如何在C#中的WPF窗口中添加.svg文件作为图像(,png || ,jpg)?

我使用代码

<Image HorizontalAlignment="Left" Height="53" Margin="34,39,0,0"
           VerticalAlignment="Top" Width="71" 
           Source="Test.svg" Name="MyImage"/>

但是我收到了一个错误:

  

Blend不支持格式svg。

我发现我可以将.svg文件更改为.xaml文件。但我仍然不知道如何将xaml添加为图像。

根据答案,我改变了我的代码:

<Window x:Class="NIA_UI_Demo_CSharp.ShareDocumentsWin"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:svgc="http://sharpvectors.codeplex.com/svgc/"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="ShareDocumentsWin" Height="350" Width="569">

<ResourceDictionary>
    <Style x:Key="TheAwesomeXAMLimage" TargetType="ContentControl">
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="ContentControl">
                    my code
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
</ResourceDictionary>

<Grid Margin="0,0,2,3">
    <ContentControl Style="{StaticResource TheAwesomeXAMLimage}"/>
</Grid>
</Window>

但是我收到了一个错误:

  

内容设置不止一次;

2 个答案:

答案 0 :(得分:12)

据我所知,你不能直接包含svg文件。 两个选项:

  1. 使用可以在运行时处理svg文件的库:https://sharpvectors.codeplex.com/
  2. 将svg转换为xaml并将其与原生wpf对象一起使用(Path,Image ..)
  3. 我更喜欢第二个选项,所以我编写了一个工具,可以将单个svg转换为xaml,也可以批量转换一堆svg文件。工作流程是:只需将svg文件放入images-folder,调用批处理转换器,找到用新图标/图像更新的images.xaml文件(资源字典)。

    请参阅https://github.com/BerndK/SvgToXaml

答案 1 :(得分:0)

我很幸运能够在WpfSvgRenderer.CreateImageSource中使用DevExpress。不想在这里做广告,但是由于它是一个使用广泛的库,所以也许有人很高兴知道。

很遗憾,尚不支持svg中的text元素。