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
- class PathResource
- class TiffFrame
- namensraum Aspose.Imaging.FileFormats.Tiff
- Montage Aspose.Imaging