Så här skalas en bitmapkälla
Det här avsnittet visar hur du skalar en IWICBitmapSource- med hjälp av komponenten IWICBitmapScaler.
Skala en bitmappskälla
Skapa ett IWICImagingFactory- objekt för att skapa WIC-objekt (Windows Imaging Component).
// Create WIC factory hr = CoCreateInstance( CLSID_WICImagingFactory, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&m_pIWICFactory) );
Använd metoden CreateDecoderFromFilename för att skapa en IWICBitmapDecoder från en bildfil.
HRESULT hr = S_OK; IWICBitmapDecoder *pIDecoder = NULL; IWICBitmapFrameDecode *pIDecoderFrame = NULL; IWICBitmapScaler *pIScaler = 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 );
Hämta den första IWICBitmapFrameDecode- av avbildningen.
// Retrieve the first bitmap frame. if (SUCCEEDED(hr)) { hr = pIDecoder->GetFrame(0, &pIDecoderFrame); }
JPEG-filformatet stöder endast en enda ram. Eftersom filen i det här exemplet är en JPEG-fil används den första ramen (
0
). Information om bildformat som har flera bildrutor finns i Hämta bildramar för åtkomst till varje bildruta.Skapa IWICBitmapScaler- som ska användas för bildskalning.
// Create the scaler. if (SUCCEEDED(hr)) { hr = m_pIWICFactory->CreateBitmapScaler(&pIScaler); }
Initiera skalningsobjektet med bilddata för bitmappsramen till hälften av storleken.
// Initialize the scaler to half the size of the original source. if (SUCCEEDED(hr)) { hr = pIScaler->Initialize( pIDecoderFrame, // Bitmap source to scale. uiWidth/2, // Scale width to half of original. uiHeight/2, // Scale height to half of original. WICBitmapInterpolationModeFant); // Use Fant mode interpolation. }
Rita eller bearbeta den skalbara bitmappskällan.
Följande bild visar skalning av avbildningar. Den ursprungliga bilden till vänster är 200 x 130 bildpunkter. Bilden till höger är den ursprungliga bilden skalad till hälften av storleken.
Se även