1

400x400 ビューボックスの中央にある 264x264 の正方形である SVG グラフィックがあり、その正方形の周囲の 68 ピクセルのパディングが画像の重要な部分です。それを WPF に表示したいと考えています。ライブラリを使用して SVG 図面を WPF DrawingImage に変換しています。ページに詰め込んでプレビューした後の出力は次のようになります。

<Page x:Class="Page1"
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
  xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
  mc:Ignorable="d" 
  d:DesignHeight="400" d:DesignWidth="400"
Title="Page1">

<Image>
    <Image.Source>
        <DrawingImage>
            <DrawingImage.Drawing>
                <DrawingGroup xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:svg="http://sharpvectors.codeplex.com/runtime/">
                    <DrawingGroup.Children>
                        <DrawingGroup>
                            <DrawingGroup.Children>
                                <DrawingGroup>
                                    <DrawingGroup.Children>
                                        <DrawingGroup>
                                            <DrawingGroup.Children>
                                                <GeometryDrawing Brush="#FFAAFFAA">
                                                    <GeometryDrawing.Pen>
                                                        <Pen Brush="#FF000000" Thickness="10" StartLineCap="Flat" EndLineCap="Flat" LineJoin="Miter" />
                                                    </GeometryDrawing.Pen>
                                                    <GeometryDrawing.Geometry>
                                                        <RectangleGeometry RadiusX="0" RadiusY="0" Rect="68,68,264,264" />
                                                    </GeometryDrawing.Geometry>
                                                </GeometryDrawing>
                                            </DrawingGroup.Children>
                                            <DrawingGroup.ClipGeometry>
                                                <RectangleGeometry Rect="0,0,400,400" />
                                            </DrawingGroup.ClipGeometry>
                                            <DrawingGroup.Transform>
                                                <TranslateTransform X="0" Y="0" />
                                            </DrawingGroup.Transform>
                                        </DrawingGroup>
                                    </DrawingGroup.Children>
                                </DrawingGroup>
                            </DrawingGroup.Children>
                            <DrawingGroup.ClipGeometry>
                                <RectangleGeometry Rect="0,0,400,400" />
                            </DrawingGroup.ClipGeometry>
                        </DrawingGroup>
                    </DrawingGroup.Children>
                </DrawingGroup>
            </DrawingImage.Drawing>
        </DrawingImage>
    </Image.Source>
</Image>
</Page>

結果の画像は、私が望むように周囲に空きスペースを残すのではなく、コンテナを完全に埋める正方形です。WPF でそのスペースを切り取るのではなく保持するにはどうすればよいですか?

4

1 に答える 1

0

を使用するDrawingImageと、レンダリング時に空のスペースが無視/トリミングされますImage。この投稿では、同じ問題について説明しています: GeometryDrawing がクリップされた座標で Canvas に表示されるのはなぜですか?

緑の四角形の背後にある透明な 400x400 の四角形として空のスペースを描画することで、目的を達成できます。

...
<DrawingGroup>
    <DrawingGroup.Children>

        <!-- Added transparent "spacer": -->
        <GeometryDrawing Brush="Transparent">
            <GeometryDrawing.Geometry>
                <RectangleGeometry RadiusX="0" RadiusY="0" Rect="0,0,400,400" />
            </GeometryDrawing.Geometry>
        </GeometryDrawing>

        <!-- This was here before: -->
        <GeometryDrawing Brush="#FFAAFFAA">
            <GeometryDrawing.Pen>
                <Pen Brush="#FF000000" Thickness="10" 
                     StartLineCap="Flat" EndLineCap="Flat" LineJoin="Miter" />
            </GeometryDrawing.Pen>
            <GeometryDrawing.Geometry>
                <RectangleGeometry RadiusX="0" RadiusY="0" Rect="68,68,264,264" />
            </GeometryDrawing.Geometry>
        </GeometryDrawing>
        ...
于 2013-09-25T20:29:47.037 に答える