FireMonkey の画像効果

提供: RAD Studio
移動先: 案内検索

FireMonkey アプリケーション ガイド への移動

FireMonkey に組み込まれた ImageFX エンジンでは、GPU を使用する 50 以上の効果を提供しています。これらの効果は非ビジュアル コンポーネントとして[ツール パレット][Effects]カテゴリに含まれています。提供されている効果はどれも、フォーム デザイナまたはプログラムで Enabled フラグを設定することで、簡単に有効にしたり無効にすることができます。

ほとんどすべての効果に固有のプロパティがあり、アプリケーションに応じてカスタマイズすることができます。たとえば、どの推移効果にも Progress プロパティがありますが、これを使うと、1 番目のテクスチャから 2 番目のテクスチャへの推移における進行度(単位は %)を設定できます。指定されたプロパティは、[構造]ビューで効果を選択すると[オブジェクト インスペクタ]に表示されます。どの効果のどの数値プロパティも、アニメーションによって時間の経過とともに徐々に値を変化させることができます。画像効果はトリガによって実行することもできます。

FireMonkey の効果はシェーダ フィルタを使って構築されています。シェーダは、ピクセルを個別に、あるいは他のピクセルと連動して変更することで、各種ビジュアル効果を実現します。これらの効果はビットマップ画像データに限定されず、ユーザー インターフェイスにある任意の 2D コントロールのピクセルに適用できます。実行時または設計時に効果を使用して、アプリケーションのユーザー インターフェイスの外見を変更できます。FireMonkey の効果を適用したためにコントロールや機能が無効になることはありません。

FireMonkey 効果の適用方法の詳細は、「FireMonkey の画像効果の適用」を参照してください。

画像効果の種類

用意されている TEffect のサブクラスは、以下の表のように分類されます。このトピックの後半では、それぞれの種類についてさらに詳しく説明します。

個々のピクセルを
変更する効果
隣接するピクセルに
影響される効果
追加効果 画像全体を
変更する効果
推移効果

TInvertEffect.png TInvertEffect

TColorKeyAlphaEffect.png TColorKeyAlphaEffect

TMaskToAlphaEffect.png TMaskToAlphaEffect

TMonochromeEffect.png TMonochromeEffect

TBloomEffect.png TBloomEffect

TGloomEffect.png TGloomEffect

TContrastEffect.png TContrastEffect

THueAdjustEffect.png THueAdjustEffect

TFillRGBEffect.png TFillRGBEffect

TFillEffect.png TFillEffect

ぼかし

TBlurEffect.png TBlurEffect

TDirectionalBlurEffect.png TDirectionalBlurEffect

TBoxBlurEffect.png TBoxBlurEffect

TGaussianBlurEffect.png TGaussianBlurEffect

TRadialBlurEffect.png TRadialBlurEffect

変形

TBandedSwirlEffect.png TBandedSwirlEffect

TBandsEffect.png TBandsEffect

TMagnifyEffect.png TMagnifyEffect

TPinchEffect.png TPinchEffect

TRippleEffect.png TRippleEffect

TSmoothMagnifyEffect.png TSmoothMagnifyEffect

TSwirlEffect.png TSwirlEffect

TWaveEffect.png TWaveEffect

TWrapEffect.png TWrapEffect

TGlowEffect.png TGlowEffect

TInnerGlowEffect.png TInnerGlowEffect

TReflectionEffect.png TReflectionEffect

TShadowEffect.png TShadowEffect

TEmbossEffect.png TEmbossEffect

TPaperSketchEffect.png TPaperSketchEffect

TPencilStrokeEffect.png TPencilStrokeEffect

TPixelateEffect.png TPixelateEffect

TSepiaEffect.png TSepiaEffect

TSharpenEffect.png TSharpenEffect

TToonEffect.png TToonEffect

TBevelEffect.png TBevelEffect

TAffineTransformEffect.png TAffineTransformEffect

TCropEffect.png TCropEffect

TNormalBlendEffect.png TNormalBlendEffect

TPerspectiveTransformEffect.png TPerspectiveTransformEffect

TTilerEffect.png TTilerEffect

TBandedSwirlTransitionEffect.png TBandedSwirlTransitionEffect

TBlindTransitionEffect.png TBlindTransitionEffect

TBloodTransitionEffect.png TBloodTransitionEffect

TBlurTransitionEffect.png TBlurTransitionEffect

TBrightTransitionEffect.png TBrightTransitionEffect

TCircleTransitionEffect.png TCircleTransitionEffect

TCrumpleTransitionEffect.png TCrumpleTransitionEffect

TDissolveTransitionEffect.png TDissolveTransitionEffect

TDropTransitionEffect.png TDropTransitionEffect

TFadeTransitionEffect.png TFadeTransitionEffect

TLineTransitionEffect.png TLineTransitionEffect

TMagnifyTransitionEffect.png TMagnifyTransitionEffect

TPixelateTransitionEffect.png TPixelateTransitionEffect

TRippleTransitionEffect.png TRippleTransitionEffect

TRotateCrumpleTransitionEffect.png TRotateCrumpleTransitionEffect

TSaturateTransitionEffect.png TSaturateTransitionEffect

TShapeTransitionEffect.png TShapeTransitionEffect

TSlideTransitionEffect.png TSlideTransitionEffect

TSwipeTransitionEffect.png TSwipeTransitionEffect

TSwirlTransitionEffect.png TSwirlTransitionEffect

TWaterTransitionEffect.png TWaterTransitionEffect

TWaveTransitionEffect.png TWaveTransitionEffect

TWiggleTransitionEffect.png TWiggleTransitionEffect


個々のピクセルを変更する効果

この種類の効果では、主に色を変更します。各ピクセルの色は、個別に処理できます。以下の表では、この種類の効果の一部を示します:

効果 結果 説明 効果 結果 説明

なし

InputBitmap.png

効果は適用されません。

TMonochromeEffect

Monochrome.png

グレースケール変換。

TInvertEffect

Invert.png

各ピクセルの色を反転させます。

TContrastEffect

Contrast.png

コントラストを調整します。

THueAdjustEffect

HueAdjust.png

色相を調整します。

塗りつぶし効果

TFillRGBEffect または

TFillEffect

Fill.png

色で塗りつぶします。その際、アルファを維持するか完全に上書きします。

隣接するピクセルに影響される効果

この種類の効果を適用するときには、隣接するピクセルを使ってピクセルの新しい値を定義するアルゴリズムが使われます。以下の表では、この種類の効果の一部を示します。

ぼかし効果

効果 結果 説明 効果 結果 説明

なし

InputBitmap.png

効果は適用されません。

TGaussianBlurEffect

GaussianBlur.png

ガウス型ぼかし

TBoxBlurEffect

BoxBlur.png

ボックス型ぼかし

TDirectionalBlurEffect

DirectionalBlur.png

指向型ぼかし

TRadialBlurEffect

RadialBlur.png

放射型ぼかし

TBlurEffect

StackBlur.png

スタック型ぼかし

さまざまな変形

効果 結果 説明 効果 結果 説明

なし

InputBitmap.png

効果は適用されません。

渦巻き効果

TSwirlEffect および

TBandedSwirlEffect

Swirl.png

BandedSwirl.png

入力画像を渦巻き状にします。

TWaveEffect

Wave.png

波のパターンを適用します。

TEmbossEffect

Emboss.png

入力画像の輪郭を描きます。

TPixelateEffect

Pixelate.png

入力画像の詳細を単純化します。

TMagnifyEffect

Magnify.png

拡大鏡の効果です。

画像全体を変更する効果

この種類の効果を適用すると、入力画像に対して幾何学的な変更が行われます。以下の表では、この種類の効果の一部を示します。

効果 結果 説明 効果 結果 説明

なし

InputBitmap.png

効果は適用されません。

TCropEffect

Crop.png

入力画像を切り抜きます。

TAffineTransformEffect

Rotating.png

入力画像を回転および拡大/縮小します。

TPerspectiveTransformEffect

Perspective3D.png

3D の遠近感

TNormalBlendEffect

NormalBlend.png

2 つの画像を重ね合わせます。オーバーレイに透明な部分がある場合に有効です。

TTilerEffect

Tiler.png

入力画像をタイル状に配置します。

追加効果

この種類の効果では、元の画像に新しい要素を追加することで画像を変化させます。要素を画像の縁に追加することも、画像全体に追加することもできます。以下の表では、この種類の効果の一部を示します。

効果 不透明な画像 透明な領域がある画像 説明

なし

InputBitmap.png

FireMonkey logo NoEffects.PNG

効果は適用されません。

TGlowEffect

Glow.png

FireMonkey logo TGlowEffect.PNG

帯状のグロー効果を追加します。

|TInnerGlowEffect

InnerGlow.png

FireMonkey logo TInnerGlowEffect.PNG

不透明な領域の内側に帯状のグロー効果を追加します。

TShadowEffect

Shadow.png

FireMonkey logo TShadowEffect.PNG

不透明な領域に影を追加します。

TReflectionEffect

Reflection.png

FireMonkey logo TReflectionEffect.PNG

画像全体に反射を追加します。

TBevelEffect

Bevel.png

FireMonkey logo TBevelEffect.PNG

画像全体にべベル効果を追加します。

推移効果

FireMonkey には、単純なフェードから手が込んだ帯渦巻きまで、推移元のピクセルが推移先のビットマップ画像へ徐々に変換されるという画像推移効果が 20 以上も含まれています。変換の進行は確定的であり、任意のパーセント値に設定できます。このパーセント値をアニメーション化して、時間の経過とともに推移させることができます。推移の進行をアニメーション化する方法は、「画像効果のプロパティにアニメーション効果を適用する」を参照してください。

以下の表では、一部のアニメーション推移を示します。

推移 結果 推移 結果

TBandedSwirlTransitionEffect

BandedSwirlTransition.gif

TCircleTransitionEffect

CircleTransition.gif

TFadeTransitionEffect

FadeTransition1.gif

TMagnifyTransitionEffect

MagnifyTransition.gif

FireMonkey の画像サンプル プログラム

ShaderFilters サンプル プログラムのデモでは、追加効果および基本のスタック型ぼかしを除く、数多くの FireMonkey 画像効果を示しています。

関連項目

サンプル