Работа със слоеве

Създаване на група слоеве

Група от слоеве се състои от един или повече слоеве и помага за организиране на подобни или свързани слоеве. С помощта на Aspose.PSD за .NET можете да създадете група слоеве. За целта е добавен нов метод AddLayerGroup в класа PsdImage за добавяне на групата слоеве.

Стъпките за създаване на групи слоеве са толкова прости, както следва:

  • Създайте инстанция на изображение, използвайки класа PsdImage с посочената ширина, височина и опции за изображението.
  • Създайте LayerGroup с посоченото име на групата и индекса.
  • Създайте инстанция на класа Layer и присвоете изображението на PSD на него.
  • Добавете създадения слой към групата от слоеве, използвайки метода AddLayer, който е достъпен от класа LayerGroup.
  • Запазете резултатите.

Следният откъс код ви показва как да създадете група слоеве.

// For complete examples and data files, please go to https://github.com/aspose-psd/Aspose.PSD-for-.NET
string inputFile = dataDir + "ButtonTemp.psd";
var createOptions = new PsdOptions();
createOptions.Source = new FileCreateSource(inputFile, false);
createOptions.Palette = new PsdColorPalette(new Color[] { Color.Green });
using (var psdImage = (PsdImage)Image.Create(createOptions, 500, 500))
{
LayerGroup group1 = psdImage.AddLayerGroup("Group 1", 0, true);
Layer layer1 = new Layer(psdImage);
layer1.Name = "Layer 1";
group1.AddLayer(layer1);
LayerGroup group2 = group1.AddLayerGroup("Group 2", 1);
Layer layer2 = new Layer(psdImage);
layer2.Name = "Layer 2";
group2.AddLayer(layer2);
Layer layer3 = new Layer(psdImage);
layer3.Name = "Layer 3";
group2.AddLayer(layer3);
Layer layer4 = new Layer(psdImage);
layer4.Name = "Layer 4";
group1.AddLayer(layer4);
psdImage.Save(dataDir + "LayerGroups_out.psd");
}

Преименуване на слой

Можете да използвате каквото име искате, но типичната практика е да използвате общо описание на обекта или елемента, който се намира върху този слой. Този материал демонстрира как можете да промените името на слоя, използвайки Aspose.PSD за .NET. За целта е добавено ново свойство DisplayName в класа Layer, за да се покаже правилно име на слоя. Забелязано е, че когато Photoshop запазва име на слой с помощта на свойството Name, тогава корейските знаци се съхраняват като байт 63'?' в ASCII. Затова, ако искате да покажете името на слоя правилно, използвайте свойството DisplayName, защото свойството Name не поддържа корейски знаци.

Следният примерен код показва как можете да преименувате слой.

// For complete examples and data files, please go to https://github.com/aspose-psd/Aspose.PSD-for-.NET
// The path to the documents directory.
string dataDir = RunExamples.GetDataDir_PSD();
// make changes in layer names and save it
using (var image = (PsdImage)Image.Load(dataDir + "Korean_layers.psd"))
{
for (int i = 0; i < image.Layers.Length; i++)
{
var layer = image.Layers[i];
// set new value into DisplayName property
layer.DisplayName += "_changed";
}
image.Save(dataDir + "Korean_layers_output.psd");
}

Поддръжка на свързани слоеве

Свързването на слоеве е като групиране на слоевете. Ако свържете два или повече слоя, ще може да направите определени промени по и двата свързани слоя. Например, ако приложите трансформации към един слой, те ще се приложат към всички останали свързани слоеве. Този материал демонстрира как можете да получите и отвържете свързаните слоеве, използвайки Aspose.PSD.

// For complete examples and data files, please go to https://github.com/aspose-psd/Aspose.PSD-for-.NET
{
Layer[] layers = psd.Layers;
// link all layers in one linked group
short layersLinkGroupId = psd.LinkedLayersManager.LinkLayers(layers);
// gets id for one layer
short linkGroupId = psd.LinkedLayersManager.GetLinkGroupId(layers[0]);
if (layersLinkGroupId != linkGroupId)
{
throw new Exception("layersLinkGroupId and linkGroupId are not equal.");
}
// gets all linked layers by link group id.
Layer[] linkedLayers = psd.LinkedLayersManager.GetLayersByLinkGroupId(linkGroupId);
// unlink each layer from group
foreach (var linkedLayer in linkedLayers)
{
psd.LinkedLayersManager.UnlinkLayer(linkedLayer);
}
// retrieves NULL for a link group ID that has no layers in the group.
linkedLayers = psd.LinkedLayersManager.GetLayersByLinkGroupId(linkGroupId);
if (linkedLayers != null)
{
throw new Exception("The linkedLayers field is not NULL.");
}
psd.Save(dataDir + "LinkedLayerexample_output.psd");
}