forked from mirrors/gecko-dev
		
	 17bc76bcc6
			
		
	
	
		17bc76bcc6
		
	
	
	
	
		
			
			MozReview-Commit-ID: 1RyJBjP9W9Q --HG-- extra : transplant_source : %09S%C1%15%5D%0F%8D%AD%D5h%912y%CB%D2%A1%DF%00%7B%AE
		
			
				
	
	
		
			99 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
 | |
| /* vim:set ts=2 sw=2 sts=2 et cindent: */
 | |
| /* This Source Code Form is subject to the terms of the Mozilla Public
 | |
|  * License, v. 2.0. If a copy of the MPL was not distributed with this
 | |
|  * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
 | |
| 
 | |
| #ifndef mozilla_dom_ImageBitmapUtils_h
 | |
| #define mozilla_dom_ImageBitmapUtils_h
 | |
| 
 | |
| #include "mozilla/UniquePtr.h"
 | |
| #include "nsTArrayForwardDeclare.h"
 | |
| 
 | |
| namespace mozilla {
 | |
| 
 | |
| namespace layers {
 | |
| class Image;
 | |
| struct PlanarYCbCrData;
 | |
| }
 | |
| 
 | |
| namespace dom {
 | |
| 
 | |
| struct ChannelPixelLayout;
 | |
| template<typename> class Sequence;
 | |
| 
 | |
| typedef nsTArray<ChannelPixelLayout> ImagePixelLayout;
 | |
| 
 | |
| /*
 | |
|  * This function creates an ImagePixelLayout object which describes the
 | |
|  * default layout of the given ImageBitmapFormat with the given width, height
 | |
|  * and stride.
 | |
|  */
 | |
| UniquePtr<ImagePixelLayout>
 | |
| CreateDefaultPixelLayout(ImageBitmapFormat aFormat,
 | |
|                          uint32_t aWidth, uint32_t aHeight, uint32_t aStride);
 | |
| 
 | |
| /*
 | |
|  * This function extracts information from the aImage parameter to customize
 | |
|  * the ImagePixelLayout object, that is, this function creates a customized
 | |
|  * ImagePixelLayout object which exactly describes the pixel layout of the
 | |
|  * given aImage.
 | |
|  */
 | |
| UniquePtr<ImagePixelLayout>
 | |
| CreatePixelLayoutFromPlanarYCbCrData(const layers::PlanarYCbCrData* aData);
 | |
| 
 | |
| /*
 | |
|  * Get the number of channels of the given ImageBitmapFormat.
 | |
|  */
 | |
| uint8_t
 | |
| GetChannelCountOfImageFormat(ImageBitmapFormat aFormat);
 | |
| 
 | |
| /*
 | |
|  * Get the needed buffer size to store the image data in the given
 | |
|  * ImageBitmapFormat with the given width and height.
 | |
|  */
 | |
| uint32_t
 | |
| CalculateImageBufferSize(ImageBitmapFormat aFormat,
 | |
|                          uint32_t aWidth, uint32_t aHeight);
 | |
| 
 | |
| /*
 | |
|  * This function always copies the image data in _aSrcBuffer_ into _aDstBuffer_
 | |
|  * and it also performs color conversion if the _aSrcFormat_ and the
 | |
|  * _aDstFormat_ are different.
 | |
|  *
 | |
|  * The source image is stored in the _aSrcBuffer_ and the corresponding pixel
 | |
|  * layout is described by the _aSrcLayout_.
 | |
|  *
 | |
|  * The copied and converted image will be stored in the _aDstBuffer_, which
 | |
|  * should be allocated with enough size before invoking this function and the
 | |
|  * needed size could be found by the CalculateImageBufferSize() method.
 | |
|  *
 | |
|  * The returned ImagePixelLayout object describes the pixel layout of the result
 | |
|  * image and will be null if on failure.
 | |
|  */
 | |
| UniquePtr<ImagePixelLayout>
 | |
| CopyAndConvertImageData(ImageBitmapFormat aSrcFormat,
 | |
|                         const uint8_t* aSrcBuffer,
 | |
|                         const ImagePixelLayout* aSrcLayout,
 | |
|                         ImageBitmapFormat aDstFormat,
 | |
|                         uint8_t* aDstBuffer);
 | |
| 
 | |
| /*
 | |
|  * This function tries to find the best ImageBitmapFormat, from the aCandiates,
 | |
|  * which can be converted from the aSrcFormat. The algorithm now merely returns
 | |
|  * the FIRST one, from the aCandidates, which can be converted from the
 | |
|  * aSrcFormat.
 | |
|  *
 | |
|  * TODO: The algorithm should be updated after we implement optimizations for
 | |
|  *       different platforms (different kinds of layers::Image), considering
 | |
|  *       that some conversion might be cheaper through hardware.
 | |
|  */
 | |
| ImageBitmapFormat
 | |
| FindBestMatchingFromat(ImageBitmapFormat aSrcFormat,
 | |
|                        const Sequence<ImageBitmapFormat>& aCandidates);
 | |
| 
 | |
| } // namespace dom
 | |
| } // namespace mozilla
 | |
| 
 | |
| 
 | |
| #endif // mozilla_dom_ImageBitmapUtils_h
 |