PathResources

TiffFrame.PathResources property

Ruft die Pfadressourcen ab oder legt sie fest.

public List<PathResource> PathResources { get; set; }

Eigentumswert

Die Pfadressourcen.

Beispiele

Übertragen Sie Beschneidungspfade während des Exports von TIFF- zu PSD-Bildern.

[C#]

using (var image = Image.Load("Sample.tif"))
{
    image.Save("SampleWithPaths.psd", new PsdOptions());
}

Das folgende Beispiel zeigt, wie Pfade aus einem TIFF-Bild abgerufen und ihre Namen in der Konsole angezeigt werden.

[C#]

using (var image = (TiffImage)Image.Load("Sample.tif"))
{
    foreach (var path in image.ActiveFrame.PathResources)
    {
        Console.WriteLine(path.Name);
    }
}

Das folgende Beispiel zeigt, wie Sie bereits vorhandene Beschneidungspfade ändern können. Sie können beispielsweise nur einen Beschneidungspfad im Bild beibehalten.

[C#]

using (var image = (TiffImage)Image.Load("Sample.tif"))
{
    var paths = image.ActiveFrame.PathResources;
    image.ActiveFrame.PathResources = paths.Take(1).ToList();
    image.Save();
}

Das folgende Beispiel zeigt, wie ein Beschneidungspfad in einem TIFF-Bild erstellt wird. Dazu müssen Sie eine Instanz der PathResource-Klasse erstellen. Der folgende Code zeigt, wie Sie einen leeren Pfad in einem TIFF-Bild erstellen können.

[C#]

var options = new TiffOptions(TiffExpectedFormat.Default);
var frame = new TiffFrame(options, 800, 600);

using (var image = new TiffImage(frame))
{
    image.ActiveFrame.PathResources = new List<PathResource>
    {
        new PathResource
        {
            BlockId = 2000,
            Name = "My Clipping Path",
            Records = new List<VectorPathRecord>()
        }
    };

    image.Save("ImageWithEmptyPath.tiff");
}

Beschneidungspfad manuell erstellen.

[C#]

static void Main()
{
    using (var image = (TiffImage)Image.Load("Sample.tif"))
    {
        image.ActiveFrame.PathResources = new List<PathResource> { new PathResource
        {
            BlockId = 2000,                                                          // Block-ID gemäß Photoshop-Spezifikation
            Name = "My Clipping Path",                                               // Pfadname
            Records = CreateRecords(0.2f, 0.2f, 0.8f, 0.2f, 0.8f, 0.8f, 0.2f, 0.8f)  // Pfaddatensätze mit Koordinaten erstellen
        }};

        image.Save("ImageWithPath.tif");
    }
}

private static List<VectorPathRecord> CreateRecords(params float[] coordinates)
{
    var records = CreateBezierRecords(coordinates);                                  // Bezier-Datensätze mit Koordinaten erstellen

    records.Insert(0, new LengthRecord                                               // LengthRecord gemäß Photoshop-Spezifikation erforderlich
    {
        IsOpen = false,                                                              // Erstellen wir einen geschlossenen Pfad
        RecordCount = (ushort)records.Count                                          // Anzahl der Datensätze im Pfad
    });

    return records;
}

private static List<VectorPathRecord> CreateBezierRecords(float[] coordinates)
{
    return CoordinatesToPoints(coordinates)
        .Select(CreateBezierRecord)
        .ToList();
}

private static IEnumerable<PointF> CoordinatesToPoints(float[] coordinates)
{
    for (var index = 0; index < coordinates.Length; index += 2)
        yield return new PointF(coordinates[index], coordinates[index + 1]);
}

private static VectorPathRecord CreateBezierRecord(PointF point)
{
    return new BezierKnotRecord { PathPoints = new[] { point, point, point } };
}

Siehe auch