Class PlLdResource

PlLdResource class

Definiert die PlLdResource-Klasse, die Informationen über eine platzierte Ebene in der PSD-Datei enthält. Wird verwendet, um intelligente Objektebenen in den Adobe® Photoshop®-Bildern zu unterstützen. Sie wurde in Adobe® Photoshop® CS3 durch SoLdResource ersetzt

public class PlLdResource : PlacedResource

Eigenschaften

NameBeschreibung
virtual AntiAliasPolicy { get; set; }Ruft die Anti-Alias-Richtlinie der platzierten Ebene im PSD-Bild ab oder legt sie fest.
Bottom { get; set; }Ruft die untere Position der platzierten Ebene im PSD-Bild ab oder legt sie fest.
Bounds { get; set; }Ruft die Grenzen der platzierten Ebene in der PSD-Datei ab oder legt sie fest.
HorizontalMeshPoints { get; set; }Holt oder setzt die horizontalen Gitterpunkte der platzierten Ebene in der PSD-Datei.
HorizontalMeshPointUnit { get; set; }Ruft die Maßeinheit der horizontalen Netzpunkte ab oder legt sie fest.
IsCustom { get; set; }Ruft einen Wert ab oder legt einen Wert fest, der angibt, ob dieser Instanz-Warp-Stil benutzerdefiniert ist. Wenn wahr, enthält er Mesh-Punkte. Wenn auf „false“ gesetzt, werden Mesh-Punkte gelöscht.
virtual Items { get; set; }Ruft die Warp-Elemente ab oder legt sie fest.
override Key { get; }Ruft den PlLd-Ressourcenschlüssel ab.
Left { get; set; }Ruft die linke Position der platzierten Ebene in der PSD-Datei ab oder legt sie fest.
override Length { get; }Ruft die PlLd-Ressourcenlänge in Bytes ab.
virtual PageNumber { get; set; }Ruft die Seitenzahl der platzierten Ebene in der PSD-Datei ab oder setzt sie.
Perspective { get; set; }Ruft den Perspektivenwert der platzierten Ebene in der PSD-Datei ab oder legt ihn fest.
PerspectiveOther { get; set; }Holt oder setzt den Perspective Other-Wert der platzierten Ebene in der PSD-Datei.
virtual PlacedLayerType { get; set; }Ruft den Typ der platzierten Ebene in der PSD-Datei ab oder legt ihn fest.
override PsdVersion { get; }Ruft die minimale PSD-Version ab, die für die PlLd-Ressource erforderlich ist. 0 zeigt keine Einschränkungen an.
Right { get; set; }Ruft die richtige Position der platzierten Ebene in der PSD-Datei ab oder legt sie fest.
override Signature { get; }Ruft die PlLd-Ressourcensignatur ab.
Top { get; set; }Ruft die oberste Position der platzierten Ebene im PSD-Bild ab oder legt sie fest.
virtual TotalPages { get; set; }Ruft die Gesamtseitenzahl der platzierten Ebene in der PSD-Datei ab oder legt sie fest.
virtual TransformMatrix { get; set; }Ruft die Transformationsmatrix der platzierten Ebene in der PSD-Datei ab oder legt sie fest.
virtual UniqueId { get; set; }Ruft die globale eindeutige Kennung der platzierten Ebene im PSD-Bild ab oder legt sie fest.
UOrder { get; set; }Ruft den U-Ordnungswert der platzierten Ebene in der PSD-Datei ab oder legt ihn fest.
Value { get; set; }Ruft den Warp-Wert der platzierten Ebene im PSD-Bild ab oder legt ihn fest.
Version { get; }Ruft die Version der platzierten Ebene in der PSD-Datei ab, normalerweise 3.
VerticalMeshPoints { get; set; }Holt oder setzt die horizontalen Gitterpunkte der platzierten Ebene in der PSD-Datei.
VerticalMeshPointUnit { get; set; }Ruft die Maßeinheit der vertikalen Gitterpunkte ab oder legt sie fest.
VOrder { get; set; }Ruft den Wert der V-Ordnung der platzierten Ebene in der PSD-Datei ab oder legt ihn fest.

Methoden

NameBeschreibung
override Save(StreamContainer, int)Speichert die PlLD-Ressource im angegebenen Stream-Container.
override ToString()Gibt a zurückString die diese Instanz darstellt.

Felder

NameBeschreibung
const TypeToolKeyDer Typ-Tool-Info-Schlüssel.

Beispiele

Der folgende Code demonstriert die Unterstützung der PlLdResource-Ressource.

[C#]

void AssertAreEqual(object actual, object expected)
{
    var areEqual = object.Equals(actual, expected);
    if (!areEqual && actual is Array && expected is Array)
    {
        var actualArray = (Array)actual;
        var expectedArray = (Array)actual;
        if (actualArray.Length == expectedArray.Length)
        {
            for (int i = 0; i < actualArray.Length; i++)
            {
                if (!object.Equals(actualArray.GetValue(i), expectedArray.GetValue(i)))
                {
                    break;
                }
            }

            areEqual = true;
        }
    }

    if (!areEqual)
    {
        throw new FormatException(
            string.Format("Actual value {0} are not equal to expected {1}.", actual, expected));
    }
}

var sourceFilePath = "LayeredSmartObjects8bit2.psd";
var outputFilePath = "LayeredSmartObjects8bit2_output.psd";
var expectedValues = new object[]
{
    new object[]
    {
        true,
        "76f05a3b-7523-5e42-a1bb-27f4735bffa0",
        1,
        1,
        0x10,
        PlacedLayerType.Raster,
        new double[8]
        {
            29.937922786050663,
            95.419959734187131,
            126.85445817782261,
            1.0540625423957124,
            172.20861031651307,
            47.634102808208553,
            75.292074924741144,
            142
        },
        0d,
        0d,
        0d,
        0d,
        0d,
        149d,
        310d,
        4,
        4,
        UnitTypes.Pixels,
        new double[16]
        {
            0.0d, 103.33333333333333d, 206.66666666666666d, 310.0d,
            0.0d, 103.33333333333333d, 206.66666666666666d, 310.0d,
            0.0d, 103.33333333333333d, 206.66666666666666d, 310.0d,
            0.0d, 103.33333333333333d, 206.66666666666666d, 310.0d
        },
        UnitTypes.Pixels,
        new double[16]
        {
            0.0d, 0.0d, 0.0d, 0.0d,
            49.666666666666664d, 49.666666666666664d, 49.666666666666664d, 49.666666666666664d,
            99.333333333333329d, 99.333333333333329d, 99.333333333333329d, 99.333333333333329d,
            149, 149, 149, 149,
        },
    },
    new object[]
    {
        true,
        "cf0477a8-8f92-ac4f-9462-f78e26234851",
        1,
        1,
        0x10,
        PlacedLayerType.Raster,
        new double[8]
        {
            37.900314592235681,
            -0.32118219433001371,
            185.94210608826535,
            57.7076819802063,
            153.32047433609358,
            140.9311755779743,
            5.2786828400639294,
            82.902311403437977,
        },
        0d,
        0d,
        0d,
        0d,
        0d,
        721d,
        1280d,
        4,
        4,
        UnitTypes.Pixels,
        new double[16]
        {
            0.0, 426.66666666666663, 853.33333333333326, 1280,
            0.0, 426.66666666666663, 853.33333333333326, 1280,
            0.0, 426.66666666666663, 853.33333333333326, 1280,
            0.0, 426.66666666666663, 853.33333333333326, 1280,
        },
        UnitTypes.Pixels,
        new double[16]
        {
            0.0, 0.0, 0.0, 0.0,
            240.33333333333331, 240.33333333333331, 240.33333333333331, 240.33333333333331,
            480.66666666666663, 480.66666666666663, 480.66666666666663, 480.66666666666663,
            721, 721, 721, 721,
        },
        0,
        0
    }
};

using (PsdImage image = (PsdImage)Image.Load(sourceFilePath))
{
    PlLdResource resource = null;
    int index = 0;
    foreach (Layer imageLayer in image.Layers)
    {
        foreach (var imageResource in imageLayer.Resources)
        {
            resource = imageResource as PlLdResource;
            if (resource != null)
            {
                var expectedValue = (object[])expectedValues[index++];
                AssertAreEqual(expectedValue[0], resource.IsCustom);
                AssertAreEqual(expectedValue[1], resource.UniqueId.ToString());
                AssertAreEqual(expectedValue[2], resource.PageNumber);
                AssertAreEqual(expectedValue[3], resource.TotalPages);
                AssertAreEqual(expectedValue[4], resource.AntiAliasPolicy);
                AssertAreEqual(expectedValue[5], resource.PlacedLayerType);
                AssertAreEqual(8, resource.TransformMatrix.Length);
                AssertAreEqual((double[])expectedValue[6], resource.TransformMatrix);
                AssertAreEqual(expectedValue[7], resource.Value);
                AssertAreEqual(expectedValue[8], resource.Perspective);
                AssertAreEqual(expectedValue[9], resource.PerspectiveOther);
                AssertAreEqual(expectedValue[10], resource.Top);
                AssertAreEqual(expectedValue[11], resource.Left);
                AssertAreEqual(expectedValue[12], resource.Bottom);
                AssertAreEqual(expectedValue[13], resource.Right);
                AssertAreEqual(expectedValue[14], resource.UOrder);
                AssertAreEqual(expectedValue[15], resource.VOrder);
                if (resource.IsCustom)
                {
                    AssertAreEqual(expectedValue[16], resource.HorizontalMeshPointUnit);
                    AssertAreEqual((double[])expectedValue[17], resource.HorizontalMeshPoints);
                    AssertAreEqual(expectedValue[18], resource.VerticalMeshPointUnit);
                    AssertAreEqual((double[])expectedValue[19], resource.VerticalMeshPoints);
                    var temp = resource.VerticalMeshPoints;
                    resource.VerticalMeshPoints = resource.HorizontalMeshPoints;
                    resource.HorizontalMeshPoints = temp;
                }
                
                resource.PageNumber = 2;
                resource.TotalPages = 3;
                resource.AntiAliasPolicy = 30;
                resource.Value = 1.23456789;
                resource.Perspective = 0.123456789;
                resource.PerspectiveOther = 0.987654321;
                resource.Top = -126;
                resource.Left = -215;
                resource.Bottom = 248;
                resource.Right = 145;

                // Seien Sie vorsichtig mit einigen Parametern: Das Bild kann von Adobe® Photoshop® unlesbar werden
                ////resource.UOrder = 6;
                ////resource.VOrder = 9;

                // Ändern Sie dies nicht, sonst können Sie die freie Transformation nicht verwenden
                // oder ändern Sie das unterstreichende Smart-Objekt in den Vektortyp
                ////resource.PlacedLayerType = PlacedLayerType.Vector;

                // Es sollte eine gültige PlLdResource mit dieser eindeutigen ID geben
                ////resource.UniqueId = new Guid("98765432-10fe-cba0-1234-56789abcdef0");

                break;
            }
        }
    }

    AssertAreEqual(true, resource != null);
    image.Save(outputFilePath, new PsdOptions(image));
}

Siehe auch