Class SmartFilter
コンテンツ
[
隠れる
]SmartFilter class
スマートフィルターの基本ロジックを処理するクラス.
public abstract class SmartFilter : ICloneable
コンストラクター
名前 | 説明 |
---|---|
SmartFilter() | の新しいインスタンスを初期化しますSmartFilter class. |
プロパティ
名前 | 説明 |
---|---|
BlendMode { get; set; } | ブレンド モードを取得または設定します。 |
abstract FilterId { get; } | スマート フィルター タイプ識別子を取得します。 |
IsEnabled { get; set; } | スマート フィルターの有効な状態を取得または設定します。 |
abstract Name { get; } | スマートフィルター名を取得します. |
Opacity { get; set; } | スマート フィルターの不透明度の値を取得または設定します。 |
SourceDescriptor { get; } | スマート フィルター データを含むソース記述子構造。 |
メソッド
名前 | 説明 |
---|---|
Apply(RasterImage) | 現在のフィルターを入力に適用しますRasterImage image. |
ApplyToMask(Layer) | 現在のフィルターを入力に適用しますLayer マスクデータ. |
Clone() | 型の現在のインスタンスのメンバー単位のクローンを作成します。 |
例
この例は、スマート フィルター インターフェイスのサポートを示しています。
[C#]
string sourceFilte = "r2_SmartFilters.psd";
string outputPsd = "out_r2_SmartFilters.psd";
void AssertAreEqual(object expected, object actual)
{
if (!object.Equals(expected, actual))
{
throw new Exception("Objects are not equal.");
}
}
using (var image = (PsdImage)Image.Load(sourceFilte))
{
SmartObjectLayer smartObj = (SmartObjectLayer)image.Layers[1];
// スマート フィルターを編集します
GaussianBlurSmartFilter gaussianBlur = (GaussianBlurSmartFilter)smartObj.SmartFilters.Filters[0];
// フィルタ値をチェック
AssertAreEqual(3.1, gaussianBlur.Radius);
AssertAreEqual(BlendMode.Dissolve, gaussianBlur.BlendMode);
AssertAreEqual(90d, gaussianBlur.Opacity);
AssertAreEqual(true, gaussianBlur.IsEnabled);
// フィルター値を更新します
gaussianBlur.Radius = 1;
gaussianBlur.BlendMode = BlendMode.Divide;
gaussianBlur.Opacity = 75;
gaussianBlur.IsEnabled = false;
AddNoiseSmartFilter addNoise = (AddNoiseSmartFilter)smartObj.SmartFilters.Filters[1];
addNoise.Distribution = NoiseDistribution.Uniform;
// 新しいフィルタ項目を追加
var filters = new List<SmartFilter>(smartObj.SmartFilters.Filters);
filters.Add(new GaussianBlurSmartFilter());
filters.Add(new AddNoiseSmartFilter());
smartObj.SmartFilters.Filters = filters.ToArray();
// 変更を適用
smartObj.SmartFilters.UpdateResourceValues();
// フィルタを適用
smartObj.SmartFilters.Filters[0].Apply(image.Layers[2]);
smartObj.SmartFilters.Filters[4].ApplyToMask(image.Layers[2]);
image.Save(outputPsd);
}
using (var image = (PsdImage)Image.Load(outputPsd))
{
SmartObjectLayer smartObj = (SmartObjectLayer)image.Layers[1];
GaussianBlurSmartFilter gaussianBlur = (GaussianBlurSmartFilter)smartObj.SmartFilters.Filters[0];
// フィルタ値をチェック
AssertAreEqual(1d, gaussianBlur.Radius);
AssertAreEqual(BlendMode.Divide, gaussianBlur.BlendMode);
AssertAreEqual(75d, gaussianBlur.Opacity);
AssertAreEqual(false, gaussianBlur.IsEnabled);
AssertAreEqual(true, smartObj.SmartFilters.Filters[5] is GaussianBlurSmartFilter);
AssertAreEqual(true, smartObj.SmartFilters.Filters[6] is AddNoiseSmartFilter);
}