Partilhar via


Efeito de desfoque direcional

O efeito de desfoque direcional é semelhante ao desfoque gaussiano, exceto que você pode distorcer o desfoque em uma direção específica. Você pode usar esse efeito para fazer uma imagem parecer que ela está em movimento ou enfatizar uma imagem animada.

O CLSID para esse efeito é CLSID_D2D1DirectionalBlur.

Imagem de exemplo

Antes
a imagem antes do efeito.
After (após)
a imagem após a transformação.
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();

Propriedades de efeito

Nome de exibição e enumeração de índice Descrição
StandardDeviation
D2D1_DIRECTIONALBLUR_PROP_STANDARD_DEVIATION
A quantidade de desfoque a ser aplicada à imagem. Você pode calcular o raio de desfoque do kernel multiplicando o desvio padrão por 3. As unidades do desvio padrão e do raio de desfoque são DIPs. Um valor de 0 DIPs desabilita esse efeito. O tipo é FLOAT.
O valor padrão é 3,0f.
Ângulo
D2D1_DIRECTIONALBLUR_PROP_ANGLE
O ângulo do desfoque em relação ao eixo x, na direção no sentido anti-horário. As unidades são especificadas em graus.
O kernel de desfoque é gerado pela primeira vez usando o mesmo processo que para o efeito de desfoque gaussiano . Os valores de kernel são transformados de acordo com o ângulo de desfoque.
O tipo é FLOAT.
O valor padrão é 0,0f.
Otimização
D2D1_DIRECTIONALBLUR_PROP_OPTIMIZATION
O modo de otimização. Consulte Modos de otimização para obter mais informações.
O tipo é D2D1_DIRECTIONALBLUR_OPTIMIZATION.
O valor padrão é D2D1_DIRECTIONALBLUR_OPTIMIZATION_BALANCED.
BorderMode
D2D1_DIRECTIONALBLUR_PROP_BORDER_MODE
O modo usado para calcular a borda da imagem, suave ou dura. Consulte Modos de borda para obter mais informações.
O tipo é D2D1_BORDER_MODE.
O valor padrão é D2D1_BORDER_MODE_SOFT.

Modos de otimização

Nome Descrição
D2D1_DIRECTIONALBLUR_OPTIMIZATION_SPEED Aplica otimizações internas, como pré-dimensionamento em raios relativamente pequenos. Usa filtragem linear.
D2D1_DIRECTIONALBLUR_OPTIMIZATION_BALANCED Usa os mesmos limites de otimização que o modo De velocidade, mas usa filtragem trilinear.
D2D1_DIRECTIONALBLUR_OPTIMIZATION_QUALITY Usa apenas otimizações internas com raios de desfoque grandes, em que as aproximações são menos propensas a serem visíveis. Usa a filtragem trilinear.

Modos de borda

Nome Descrição
D2D1_BORDER_MODE_SOFT O efeito preenche a imagem com pixels pretos transparentes, pois aplica o kernel de desfoque, resultando em uma borda macia.
D2D1_BORDER_MODE_HARD O efeito prende a saída ao tamanho da imagem de entrada. Quando o efeito aplica o kernel de desfoque, ele estende a imagem de entrada com uma transformação de borda do tipo espelho para amostras fora dos limites de entrada.

Bitmap de saída

O tamanho do bitmap de saída aumenta com base no desvio padrão, no ângulo do efeito e no modo de borda. Se o modo de borda estiver definido como D2D1_BORDER_MODE_SOFT o tamanho do bitmap de saída aumentará pelo tamanho do kernel de desfoque, representado em pixels. Essas equações podem ser usadas para calcular o tamanho do bitmap de saída.

Requisito Valor
Crescimento de Bitmap de Saída X StandardDeviation (DIPs) * 6 * ((DPI do usuário) / 96) * cos(Angle))
Crescimento de bitmap de saída Y StandardDeviation (DIPs) * 6 * ((DPI do usuário) / 96) * sin(Angle))

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows 8 e Atualização de Plataforma para Windows 7 [aplicativos da área de trabalho | Aplicativos da Windows Store]
Servidor mínimo com suporte Windows 8 e Atualização de Plataforma para Windows 7 [aplicativos da área de trabalho | Aplicativos da Windows Store]
Cabeçalho d2d1effects.h
Biblioteca d2d1.lib, dxguid.lib

ID2D1Effect