Condividi tramite


Effetto sfocatura direzionale

L'effetto sfocatura direzionale è simile a sfocatura gaussiana, ad eccezione del fatto che è possibile asimmetriare la sfocatura in una particolare direzione. Puoi usare questo effetto per rendere un'immagine come se fosse in movimento o per evidenziare un'immagine animata.

Il CLSID per questo effetto è CLSID_D2D1DirectionalBlur.

Immagine di esempio

Prima
l'immagine prima dell'effetto.
Dopo
'immagine dopo la trasformazione.
ComPtr<ID2D1Effect> directionalBlurEffect;
m_d2dContext->CreateEffect(CLSID_D2D1DirectionalBlur, &directionalBlurEffect);

directionalBlurEffect->SetInput(0, bitmap);
directionalBlurEffect->SetValue(D2D1_DIRECTIONALBLUR_PROP_STANDARD_DEVIATION, 7.0f);

m_d2dContext->BeginDraw();
m_d2dContext->DrawImage(directionalBlurEffect.Get());
m_d2dContext->EndDraw();

Proprietà dell'effetto

Enumerazione del nome visualizzato e dell'indice Descrizione
StandardDeviation
D2D1_DIRECTIONALBLUR_PROP_STANDARD_DEVIATION
Quantità di sfocatura da applicare all'immagine. È possibile calcolare il raggio di sfocatura del kernel moltiplicando la deviazione standard per 3. Le unità sia della deviazione standard che del raggio di sfocatura sono DIP. Il valore 0 DIP disabilita questo effetto. Il tipo è FLOAT.
Il valore predefinito è 3,0f.
Angolo
D2D1_DIRECTIONALBLUR_PROP_ANGLE
Angolo della sfocatura rispetto all'asse x, nella direzione antiorario. Le unità sono specificate in gradi.
Il kernel di sfocatura viene generato per la prima volta usando lo stesso processo del effetto di sfocatura gaussiano. I valori del kernel vengono quindi trasformati in base all'angolo di sfocatura.
Il tipo è FLOAT.
Il valore predefinito è 0,0f.
Ottimizzazione
D2D1_DIRECTIONALBLUR_PROP_OPTIMIZATION
Modalità di ottimizzazione. Per altre informazioni, vedi modalità di ottimizzazione.
Il tipo è D2D1_DIRECTIONALBLUR_OPTIMIZATION.
Il valore predefinito è D2D1_DIRECTIONALBLUR_OPTIMIZATION_BALANCED.
BorderMode
D2D1_DIRECTIONALBLUR_PROP_BORDER_MODE
Modalità utilizzata per calcolare il bordo dell'immagine, morbido o rigido. Per altre informazioni, vedi modalità bordo.
Il tipo è D2D1_BORDER_MODE.
Il valore predefinito è D2D1_BORDER_MODE_SOFT.

Modalità di ottimizzazione

Nome Descrizione
D2D1_DIRECTIONALBLUR_OPTIMIZATION_SPEED Applica ottimizzazioni interne, ad esempio il pre-ridimensionamento a raggi relativamente piccoli. Usa il filtro lineare.
D2D1_DIRECTIONALBLUR_OPTIMIZATION_BALANCED Usa le stesse soglie di ottimizzazione della modalità Velocità, ma usa il filtro trilineare.
D2D1_DIRECTIONALBLUR_OPTIMIZATION_QUALITY Usa solo ottimizzazioni interne con raggi di sfocatura di grandi dimensioni, in cui le approssimazioni hanno meno probabilità di essere visibili. Usa il filtro trilineare.

Modalità bordo

Nome Descrizione
D2D1_BORDER_MODE_SOFT L'effetto riempie l'immagine con pixel neri trasparenti quando applica il kernel di sfocatura, causando un bordo morbido.
D2D1_BORDER_MODE_HARD L'effetto blocca l'output alle dimensioni dell'immagine di input. Quando l'effetto applica il kernel di sfocatura, estende l'immagine di input con una trasformazione bordo di tipo mirror per campioni esterni ai limiti di input.

Bitmap di output

Le dimensioni della bitmap di output aumentano in base alla deviazione standard, all'angolo dell'effetto e alla modalità bordo. Se la modalità bordo è impostata su D2D1_BORDER_MODE_SOFT le dimensioni della bitmap di output aumentano in base alle dimensioni del kernel di sfocatura, rappresentate in pixel. Queste equazioni possono essere usate per calcolare le dimensioni della bitmap di output.

Requisito Valore
Output Bitmap Growth X StandardDeviation (DIP) * 6 * ((User DPI) / 96) * cos(Angle))
Output Bitmap Growth Y StandardDeviation (DIP) * 6 * ((User DPI) / 96) * sin(Angle))

Fabbisogno

Requisito Valore
Client minimo supportato Windows 8 e Aggiornamento della piattaforma per Windows 7 [app desktop | App di Windows Store]
Server minimo supportato Windows 8 e Aggiornamento della piattaforma per Windows 7 [app desktop | App di Windows Store]
Intestazione d2d1effects.h
Biblioteca d2d1.lib, dxguid.lib

ID2D1Effect