Enum SheetColorHighlightEnum

SheetColorHighlightEnum enumeration

シートカラー設定可能色 PS のレイヤー一覧にあるレイヤーのUI装飾色です

public enum SheetColorHighlightEnum : short

名前価値説明
NoColor0色が指定されていません。
Red1赤い色.
Orange2オレンジ色.
Yellow3黄色。
Green4緑色。
Blue5青い色.
Violet6紫の色.
Gray7灰色。

次の例は、Aspose.PSD (シート カラー設定) でシート カラー ハイライトを変更する方法を示しています。

[C#]

string sourceFilePath = "AllLclrResourceColors.psd";
string outputFilePath = "AllLclrResourceColorsReversed.psd";

// ファイルでは、レイヤーのハイライトの色はこの順序になっています
SheetColorHighlightEnum[] sheetColorsArr = new SheetColorHighlightEnum[] {
    SheetColorHighlightEnum.Red,
    SheetColorHighlightEnum.Orange,
    SheetColorHighlightEnum.Yellow,
    SheetColorHighlightEnum.Green,
    SheetColorHighlightEnum.Blue,
    SheetColorHighlightEnum.Violet,
    SheetColorHighlightEnum.Gray,
    SheetColorHighlightEnum.NoColor
};

// Layer Sheet Color は、レイヤを視覚的に強調するために使用されます。 
// たとえば、PSD のいくつかのレイヤーを更新してから、注目を集めたいレイヤーを色で強調表示できます。
using (PsdImage img = (PsdImage)Image.Load(sourceFilePath))
{
    CheckSheetColorsAndRerverse(sheetColorsArr, img);
    img.Save(outputFilePath, new PsdOptions());
}

using (PsdImage img = (PsdImage)Image.Load(outputFilePath))
{
    // 色を反転する必要があります
    Array.Reverse(sheetColorsArr);
    CheckSheetColorsAndRerverse(sheetColorsArr, img);
}

void CheckSheetColorsAndRerverse(SheetColorHighlightEnum[] sheetColors, PsdImage img)
{
    int layersCount = img.Layers.Length;
    for (int layerIndex = 0; layerIndex < layersCount; layerIndex++)
    {
        Layer layer = img.Layers[layerIndex];
        LayerResource[] resources = layer.Resources;
        foreach (LayerResource layerResource in resources)
        {
            // lcrl リソースは常に psd ファイル リソース リストに表示されます。
            LclrResource resource = layerResource as LclrResource;
            if (resource != null)
            {
                if (resource.Color != sheetColors[layerIndex])
                {
                    throw new Exception("Sheet Color has been read wrong");
                }

                // スタイルシートの色を反転。レイヤーカラーハイライトの設定。
                resource.Color = sheetColors[layersCount - layerIndex - 1];
                break;
            }
        }
    }
}

関連項目