Class GradientFillSettings
Contenu
[
Cacher
]GradientFillSettings class
Paramètres d’effet de remplissage dégradé.
public class GradientFillSettings : BaseFillSettings, IGradientFillSettings
Constructeurs
Nom | La description |
---|---|
GradientFillSettings() | Initialise une nouvelle instance duGradientFillSettings classe. |
Propriétés
Nom | La description |
---|---|
AlignWithLayer { get; set; } | Obtient ou définit une valeur indiquant si [aligner avec le calque]. |
Angle { get; set; } | Obtient ou définit l’angle. |
Color { get; set; } | Obtient ou définit la couleur. |
ColorPoints { get; set; } | Obtient ou définit les points de couleur. |
Dither { get; set; } | Obtient ou définit une valeur indiquant si cetteGradientFillSettings est le tramage. |
override FillType { get; } | Le type de remplissage |
GradientName { get; set; } | Obtient ou définit le nom du dégradé. |
GradientType { get; set; } | Obtient ou définit le type de dégradé. |
HorizontalOffset { get; set; } | Obtient ou définit le décalage horizontal en pourcentage. |
Reverse { get; set; } | Obtient ou définit une valeur indiquant si cetteGradientFillSettings est inversé. |
Scale { get; set; } | Obtient ou définit l’échelle. |
TransparencyPoints { get; set; } | Obtient ou définit les points de transparence. |
VerticalOffset { get; set; } | Obtient ou définit le décalage vertical en pourcentage. |
Méthodes
Nom | La description |
---|---|
AddColorPoint() | Ajoute le point de couleur. |
AddTransparencyPoint() | Ajoute le point de couleur. |
RemoveColorPoint(IGradientColorPoint) | Supprime le point de couleur. |
RemoveTransparencyPoint(IGradientTransparencyPoint) | Supprime le point de transparence. |
static GenerateLfx2ResourceNodes() | Génère les nœuds de ressources LFX2. |
Exemples
Le code suivant illustre la prise en charge du calque d’effet de trait avec le type de remplissage - Dégradé.
[C#]
void AssertIsTrue(bool condition, string message)
{
if (!condition)
{
throw new FormatException(message);
}
}
void AssertAreEqual(object expected, object actual, string message = null)
{
if (!object.Equals(expected, actual))
{
throw new FormatException(message ?? "Objects are not equal.");
}
}
string sourceFileName = "Stroke.psd";
string exportPath = "StrokeGradientChanged.psd";
var loadOptions = new PsdLoadOptions()
{
LoadEffectsResource = true
};
using (var im = (PsdImage)Image.Load(sourceFileName, loadOptions))
{
var gradientStroke = (StrokeEffect)im.Layers[2].BlendingOptions.Effects[0];
AssertAreEqual(BlendMode.Normal, gradientStroke.BlendMode);
AssertAreEqual((byte)255, gradientStroke.Opacity);
AssertAreEqual(true, gradientStroke.IsVisible);
var fillSettings = (GradientFillSettings)gradientStroke.FillSettings;
AssertAreEqual(Color.Black, fillSettings.Color);
AssertAreEqual(FillType.Gradient, fillSettings.FillType);
AssertAreEqual(true, fillSettings.AlignWithLayer);
AssertAreEqual(GradientType.Linear, fillSettings.GradientType);
AssertIsTrue(Math.Abs(90 - fillSettings.Angle) < 0.001, "Angle is incorrect");
AssertAreEqual(false, fillSettings.Dither);
AssertIsTrue(Math.Abs(0 - fillSettings.HorizontalOffset) < 0.001, "Horizontal offset is incorrect");
AssertIsTrue(Math.Abs(0 - fillSettings.VerticalOffset) < 0.001, "Vertical offset is incorrect");
AssertAreEqual(false, fillSettings.Reverse);
// Points de couleur
var colorPoints = fillSettings.ColorPoints;
AssertAreEqual(2, colorPoints.Length);
AssertAreEqual(Color.Black, colorPoints[0].Color);
AssertAreEqual(0, colorPoints[0].Location);
AssertAreEqual(50, colorPoints[0].MedianPointLocation);
AssertAreEqual(Color.White, colorPoints[1].Color);
AssertAreEqual(4096, colorPoints[1].Location);
AssertAreEqual(50, colorPoints[1].MedianPointLocation);
// Points de transparence
var transparencyPoints = fillSettings.TransparencyPoints;
AssertAreEqual(2, transparencyPoints.Length);
AssertAreEqual(0, transparencyPoints[0].Location);
AssertAreEqual(50, transparencyPoints[0].MedianPointLocation);
AssertAreEqual(100.00, transparencyPoints[0].Opacity);
AssertAreEqual(4096, transparencyPoints[1].Location);
AssertAreEqual(50, transparencyPoints[1].MedianPointLocation);
AssertAreEqual(100.00, transparencyPoints[1].Opacity);
// Tester l'édition
fillSettings.Color = Color.Green;
gradientStroke.Opacity = 127;
gradientStroke.BlendMode = BlendMode.Color;
fillSettings.AlignWithLayer = false;
fillSettings.GradientType = GradientType.Radial;
fillSettings.Angle = 45;
fillSettings.Dither = true;
fillSettings.HorizontalOffset = 15;
fillSettings.VerticalOffset = 11;
fillSettings.Reverse = true;
// Ajoute un nouveau point de couleur
var colorPoint = fillSettings.AddColorPoint();
colorPoint.Color = Color.Green;
colorPoint.Location = 4096;
colorPoint.MedianPointLocation = 75;
// Changer l'emplacement du point précédent
fillSettings.ColorPoints[1].Location = 1899;
// Ajoute un nouveau point de transparence
var transparencyPoint = fillSettings.AddTransparencyPoint();
transparencyPoint.Opacity = 25;
transparencyPoint.MedianPointLocation = 25;
transparencyPoint.Location = 4096;
// Changer l'emplacement du point de transparence précédent
fillSettings.TransparencyPoints[1].Location = 2411;
im.Save(exportPath);
}
// Tester le fichier après modification
using (var im = (PsdImage)Image.Load(exportPath, loadOptions))
{
var gradientStroke = (StrokeEffect)im.Layers[2].BlendingOptions.Effects[0];
AssertAreEqual(BlendMode.Color, gradientStroke.BlendMode);
AssertAreEqual((byte)127, gradientStroke.Opacity);
AssertAreEqual(true, gradientStroke.IsVisible);
var fillSettings = (GradientFillSettings)gradientStroke.FillSettings;
AssertAreEqual(Color.Green, fillSettings.Color);
AssertAreEqual(FillType.Gradient, fillSettings.FillType);
// Vérifier les points de couleur
AssertAreEqual(3, fillSettings.ColorPoints.Length);
var point = fillSettings.ColorPoints[0];
AssertAreEqual(50, point.MedianPointLocation);
AssertAreEqual(Color.Black, point.Color);
AssertAreEqual(0, point.Location);
point = fillSettings.ColorPoints[1];
AssertAreEqual(50, point.MedianPointLocation);
AssertAreEqual(Color.White, point.Color);
AssertAreEqual(1899, point.Location);
point = fillSettings.ColorPoints[2];
AssertAreEqual(75, point.MedianPointLocation);
AssertAreEqual(Color.Green, point.Color);
AssertAreEqual(4096, point.Location);
// Vérification des points transparents
AssertAreEqual(3, fillSettings.TransparencyPoints.Length);
var transparencyPoint = fillSettings.TransparencyPoints[0];
AssertAreEqual(50, transparencyPoint.MedianPointLocation);
AssertAreEqual(100.00, transparencyPoint.Opacity);
AssertAreEqual(0, transparencyPoint.Location);
transparencyPoint = fillSettings.TransparencyPoints[1];
AssertAreEqual(50, transparencyPoint.MedianPointLocation);
AssertAreEqual(100.00, transparencyPoint.Opacity);
AssertAreEqual(2411, transparencyPoint.Location);
transparencyPoint = fillSettings.TransparencyPoints[2];
AssertAreEqual(25, transparencyPoint.MedianPointLocation);
AssertAreEqual(25.00, transparencyPoint.Opacity);
AssertAreEqual(4096, transparencyPoint.Location);
}
Voir également
- class BaseFillSettings
- interface IGradientFillSettings
- espace de noms Aspose.PSD.FileFormats.Psd.Layers.FillSettings
- Assemblée Aspose.PSD