RenderSvgContent.cs
// 
// このコードは、DioDocs for Imaging のサンプルの一部として提供されています。
// © MESCIUS inc. All rights reserved.
// 
using System;
using System.IO;
using System.Drawing;
using System.Collections.Generic;
using System.Linq;
using System.Numerics;
using GrapeCity.Documents.Drawing;
using GrapeCity.Documents.Text;
using GrapeCity.Documents.Imaging;
using GrapeCity.Documents.Svg;
using GCTEXT = GrapeCity.Documents.Text;
using GCDRAW = GrapeCity.Documents.Drawing;
using DsImagingWeb.Demos.Common;

namespace DsImagingWeb.Demos
{
    // このサンプルでは、SVG ビューポート内で位置がずれて配置される場合がある
    // 実際の SVG コンテンツを測定し、描画する方法を示します。
    // ページ左側では、ビューポート内に正しくレイアウトされる想定どおりに
    // SVG を描画しています。ビューポートの周囲にはグレーの枠線を、
    // SVG コンテンツの周囲にはマゼンタ色の枠線を描画しています。
    // ページ右側では、最終的な画像内の特定位置に SVG コンテンツのみを配置し、
    // その周囲にパープル色の枠線を描画しています。
    //
    // この簡単なサンプルでは、SVG 画像のサイズを測定し、描画する方法を示します。
    // サンプルで使用している SVG アートは、freesvg.orgから提供されたものです。
    public class RenderSvgContent
    {
        public GcBitmap GenerateImage(Size pixelSize, float dpi, bool opaque, string[] sampleParams = null)
        {
            // SVGを読み込みます。
            var svgPath = Path.Combine("Resources", "SvgMisc", "Smiling-Girl-offset.svg");
            using var svg = GcSvgDocument.FromFile(svgPath);

            var bmp = new GcBitmap(pixelSize.Width, pixelSize.Height, opaque, dpi, dpi);
            using var g = bmp.CreateGraphics(Color.White);
            var pt0 = new PointF(g.Resolution, g.Resolution);

            // ビューポート内のSVGレイアウトで指定された通りに、SVGコンテンツを描画します。
            var rcViewport = new RectangleF(pt0, svg.GetIntrinsicSize(SvgLengthUnits.Pixels));
            // 'pt' を基準としたコンテンツのサイズと位置を測定します。
            var rcContent0 = g.MeasureSvg(svg, pt0);
            // SVG、ビューポート、およびコンテンツの境界線を描画します。
            g.DrawSvg(svg, pt0);
            g.DrawRectangle(rcViewport, Color.DarkGray);
            g.DrawRectangle(rcContent0, Color.Magenta);

            // ビットマップの右側(※コード上は pt1.X が中央のため)に、
            // コンテンツの左上隅をビットマップ上の特定のポイント(水平方向の中央、上から1インチ)に
            // 合わせて、SVGコンテンツのみを描画します。
            var pt1 = new PointF(pixelSize.Width / 2, g.Resolution);
            // GcGraphics.MeasureSvg() の代わりとして GcSvgDocument.Measure() があります。
            // ここでは説明のために使用していますが、これらのメソッドは計算負荷が高いため、
            // 実際のアプリでは上記の GcGraphics.MeasureSvg() の結果を再利用することをお勧めします。
            var rcContent1 = svg.Measure(PointF.Empty, dpi);
            g.DrawSvg(svg, new PointF(pt1.X - rcContent1.X, pt1.Y - rcContent1.Y));
            // 境界線を追加します。
            g.DrawRectangle(new RectangleF(pt1, rcContent1.Size), Color.Purple);

            // 画像ファイルを保存します。
            return bmp;
        }
    }
}