Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/309.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用矢量图像作为图像源。WPF,C#_C#_Wpf_Svg_Vector_Imagesource - Fatal编程技术网

使用矢量图像作为图像源。WPF,C#

使用矢量图像作为图像源。WPF,C#,c#,wpf,svg,vector,imagesource,C#,Wpf,Svg,Vector,Imagesource,我正在做一个包含大量图片的项目。问题是,正如标题所说,我必须先将所有矢量图像转换为png,然后才能将它们用作图像源 我在illustrator中创建了矢量图像。我在.ai项目文件中有它们,如何从这里开始 我的目标是能够做到这一点: <Image Width="70" Height="70" Source="MyVectorImage"/> 您可以使用DrawingImage作为图像的源。DrawingImage使用几何图形(即矢量图形)而不是位图 <Image>

我正在做一个包含大量图片的项目。问题是,正如标题所说,我必须先将所有矢量图像转换为png,然后才能将它们用作图像源

我在illustrator中创建了矢量图像。我在.ai项目文件中有它们,如何从这里开始

我的目标是能够做到这一点:

<Image Width="70" Height="70" Source="MyVectorImage"/>

您可以使用
DrawingImage
作为图像的源。DrawingImage使用几何图形(即矢量图形)而不是位图

<Image>
    <Image.Source>
        <DrawingImage>
            <DrawingImage.Drawing>
                <GeometryDrawing>
                    <GeometryDrawing.Pen>
                        <Pen Thickness="2" Brush="Black"/>
                    </GeometryDrawing.Pen>
                    <GeometryDrawing.Geometry>
                        <RectangleGeometry Rect="100,100,100,100"/>
                    </GeometryDrawing.Geometry>
                </GeometryDrawing>
            </DrawingImage.Drawing>
        </DrawingImage>
    </Image.Source>
</Image>


当然,您也可以将Source属性绑定到ImageSource类型的视图模型属性,该属性包含您将从原始矢量数据创建的DrawingImage。

如果您希望将
ImageSource
从几何体路径图像获取到cs文件,您可以将
drawingImage
放入资源文件:
Icons.xaml

<DrawingImage x:Key="hazelnut">
    <DrawingImage.Drawing>
        <DrawingGroup>
            <GeometryDrawing Brush="Black">
                <GeometryDrawing.Geometry>
                    <GeometryGroup>
                        <PathGeometry Figures="M 16.6309,18.6563C 17.1309,8.15625 29.8809,14.1563 29.8809,14.1563C 30.8809,11.1563 34.1308,11.4063 34.1308,11.4063C 33.5,12 34.6309,13.1563 34.6309,13.1563C 32.1309,13.1562 31.1309,14.9062 31.1309,14.9062C 41.1309,23.9062 32.6309,27.9063 32.6309,27.9062C 24.6309,24.9063 21.1309,22.1562 16.6309,18.6563 Z M 16.6309,19.9063C 21.6309,24.1563 25.1309,26.1562 31.6309,28.6562C 31.6309,28.6562 26.3809,39.1562 18.3809,36.1563C 18.3809,36.1563 18,38 16.3809,36.9063C 15,36 16.3809,34.9063 16.3809,34.9063C 16.3809,34.9063 10.1309,30.9062 16.6309,19.9063 Z ">
                            <PathGeometry.Transform>
                                <TransformGroup>
                                    <ScaleTransform
                                        CenterX="23"
                                        CenterY="20"
                                        ScaleX="0.45"
                                        ScaleY="0.45" />
                                </TransformGroup>
                            </PathGeometry.Transform>
                        </PathGeometry>
                    </GeometryGroup>
                </GeometryDrawing.Geometry>
            </GeometryDrawing>
        </DrawingGroup>
    </DrawingImage.Drawing>
</DrawingImage>
并在cs文件中使用它,如:

    ImageSource image = ResourcePathToImageSource("hazelnut");


    private ImageSource ResourcePathToImageSource(string resourcesName)
    {
        return (DrawingImage)Application.Current.TryFindResource(resourcesName);
    }

如何将源属性绑定到ImageSource类型的视图模型属性?如何获取.ai文件的几何图形?请在web上搜索MVVM和WPF数据绑定。创建视图模型类时,请添加ImageSource类型的属性。在视图模型类中,将矢量数据转换为适当的灰度,并将其指定给DrawingImage的几何体属性。然后从属性getter返回DrawingImage。当然,使用Path元素并将其数据属性绑定到几何体可能更简单。
    ImageSource image = ResourcePathToImageSource("hazelnut");


    private ImageSource ResourcePathToImageSource(string resourcesName)
    {
        return (DrawingImage)Application.Current.TryFindResource(resourcesName);
    }