Como recortar uma fonte de bitmap
Este tópico demonstra como obter uma parte retangular de um IWICBitmapSource usando um componente IWICBitmapClipper .
Para recortar uma fonte de bitmap
Crie um objeto IWICImagingFactory para criar objetos WIC (Componente de Imagem do Windows).
// Create WIC factory hr = CoCreateInstance( CLSID_WICImagingFactory, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&m_pIWICFactory) );
Use o método CreateDecoderFromFilename para criar um IWICBitmapDecoder de um arquivo de imagem.
HRESULT hr = S_OK; IWICBitmapDecoder *pIDecoder = NULL; IWICBitmapFrameDecode *pIDecoderFrame = NULL; hr = m_pIWICFactory->CreateDecoderFromFilename( L"turtle.jpg", // Image to be decoded NULL, // Do not prefer a particular vendor GENERIC_READ, // Desired read access to the file WICDecodeMetadataCacheOnDemand, // Cache metadata when needed &pIDecoder // Pointer to the decoder );
Obtenha o primeiro IWICBitmapFrameDecode da imagem.
// Retrieve the first bitmap frame. if (SUCCEEDED(hr)) { hr = pIDecoder->GetFrame(0, &pIDecoderFrame); }
O formato de arquivo JPEG dá suporte apenas a um único quadro. Como o arquivo neste exemplo é um arquivo JPEG, o primeiro quadro (
0
) é usado. Para formatos de imagem que têm vários quadros, consulte Como recuperar os quadros de uma imagem para acessar cada quadro da imagem.Crie o IWICBitmapClipper a ser usado para o recorte de imagem.
IWICBitmapClipper *pIClipper = NULL; if (SUCCEEDED(hr)) { hr = m_pIWICFactory->CreateBitmapClipper(&pIClipper); }
Inicialize o objeto clipper com os dados de imagem dentro do retângulo fornecido do quadro de bitmap.
// Create the clipping rectangle. WICRect rcClip = { 0, 0, uiWidth/2, uiHeight/2 }; // Initialize the clipper with the given rectangle of the frame's image data. if (SUCCEEDED(hr)) { hr = pIClipper->Initialize(pIDecoderFrame, &rcClip); }
Desenhe ou processe a imagem recortada.
A ilustração a seguir demonstra o recorte de imagens. A imagem original à esquerda é de 200 x 130 pixels. A imagem à direita é a imagem original recortada em um retângulo definido como
{20,20,100,100}
.
Consulte Também