mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
f1d1e16669
- Bug 1188569: Drop unneeded MOZ_WARN_UNUSED_RESULT from from LookupBestMatch in SurfaceCache.cpp. r=seth (5e74e0028c) - Bug 1192356 (Part 1) - Take advantage of mozilla::Tie() in SurfaceCache.cpp. r=dholbert (e4908c725d) - Bug 1192356 (Part 2) - Take advantage of mozilla::Tie() in RasterImage.cpp. r=tn (1204189b73) - Bug 1185800 - Add DecoderFlags and SurfaceFlags enum classes and use them instead of imgIContainer flags in all decoder-related code. r=tn (3abdab11f6) - Bug 1196066 (Part 3) - Rewrite nsICODecoder to use StreamingLexer. r=tn (e2ba590c9d) - Bug 1196066 (Part 4) - Enable the ICOMultiChunk test, which now passes. r=tn (9e02611959) - Bug 1124084 - Flip on downscale-during-decode everywhere. r=tn (bd9deff966) - Bug 1160801 - Treat invalid GIF disposal methods as DisposalMethod::NOT_SPECIFIED. r=jrmuizel (e26feaf8fb) - Bug 1201796 (Part 1) - Treat ICOs with wrong widths and heights as corrupt. r=tn (322ba20808) - Bug 1201796 (Part 2) - Add GetFrameAtSize() to support downscale-during-decode for GetFrame() use cases. r=tn (92f5d3a0a7) - Bug 1194906 - Replace 'NS_ENSURE_TRUE(BadImage(..))' warnings with more useful messages. r=tn (cc3b368673) - Bug 1201796 (Part 3) - Enable downscale-during-decode for imgITools::EncodeScaledImage(). r=tn (e2cdb5b520) - Bug 1194472 - Correctly fetch compositor backend in WebGLContext. r=jgilbert (0092052dfc) - Bug 1161913 - Part 1 - Add invalidation state for CaptureStream to Canvas and Contexts. r=mt (0377d6bbe7) - Bug 1168075 - Fix CanvasCaptureMediaStream build fail for bluetooth2. r=pehrsons (53c67c0056) - Bug 1176363 - Part 1: Make a raw copy of each Canvas::CaptureStream frame. r=mattwoodrow (a5df5793d6) - Bug 1194575 - Rename RecoverFromLossOfFrames() to RecoverFromInvalidFrames() to better reflect its role. r=tn (baa6455e79) - Bug 1146663 (Part 1) - Remove HQ scaling, which is now dead code. r=tn (efaddadea0) - Bug 1146663 (Part 2) - Remove the concept of lifetimes from the SurfaceCache. r=dholbert (ab9862d7ee) - Bug 1146663 (Part 3) - Make it impossible to deoptimize imgFrames. r=tn (19e2f1b370) - Bug 1201763 - Add downscale-during-decode support for the ICON decoder. r=tn (33a2b95e5c) - Bug 1194058 (Part 1) - Add Deinterlacer to allow Downscaler to work with interlaced images. r=tn (f7c57b7a8e) - Bug 1194058 (Part 2) - Add downscale-during-decode support for the GIF decoder. r=tn (85622f9d55) - Bug 1201796 (Part 4) - Add downscale-during-decode support for the ICO decoder. r=tn (d09d18b0d9) - Bug 1146663 (Part 4) - Make all RasterImages support downscale-during-decode. r=tn (264642a895) - Bug 1146663 (Part 5) - Require that all image decoders support downscale-during-decode. r=tn (79ad99885d) - Bug 1206836 - When downscaling ICOs, downscale the AND mask as well. r=tn a=KWierso (08ec3d092b) - missing bit of Bug 1138293 - Use malloc/free/realloc/calloc (eb8e5e1b9c) - missing bit of Bug 1146663 (Part 3) - Make it impossible to deoptimize imgFrames. (233befe48f) - Bug 1208935 - Move Deinterlacer to a standalone file. r=seth (b50322abc286)
171 lines
6.5 KiB
C++
171 lines
6.5 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
*
|
|
* 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_image_DecoderFactory_h
|
|
#define mozilla_image_DecoderFactory_h
|
|
|
|
#include "DecoderFlags.h"
|
|
#include "mozilla/Attributes.h"
|
|
#include "mozilla/Maybe.h"
|
|
#include "mozilla/gfx/2D.h"
|
|
#include "nsCOMPtr.h"
|
|
#include "SurfaceFlags.h"
|
|
|
|
class nsACString;
|
|
|
|
namespace mozilla {
|
|
namespace image {
|
|
|
|
class Decoder;
|
|
class RasterImage;
|
|
class SourceBuffer;
|
|
|
|
/**
|
|
* The type of decoder; this is usually determined from a MIME type using
|
|
* DecoderFactory::GetDecoderType().
|
|
*/
|
|
enum class DecoderType
|
|
{
|
|
PNG,
|
|
GIF,
|
|
JPEG,
|
|
BMP,
|
|
ICO,
|
|
ICON,
|
|
WEBP,
|
|
JXR,
|
|
UNKNOWN
|
|
};
|
|
|
|
class DecoderFactory
|
|
{
|
|
public:
|
|
/// @return the type of decoder which is appropriate for @aMimeType.
|
|
static DecoderType GetDecoderType(const char* aMimeType);
|
|
|
|
/**
|
|
* Creates and initializes a decoder for non-animated images of type @aType.
|
|
* (If the image *is* animated, only the first frame will be decoded.) The
|
|
* decoder will send notifications to @aImage.
|
|
*
|
|
* @param aType Which type of decoder to create - JPEG, PNG, etc.
|
|
* @param aImage The image will own the decoder and which should receive
|
|
* notifications as decoding progresses.
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
* from.
|
|
* @param aTargetSize If not Nothing(), the target size which the image should
|
|
* be scaled to during decoding. It's an error to specify
|
|
* a target size for a decoder type which doesn't support
|
|
* downscale-during-decode.
|
|
* @param aDecoderFlags Flags specifying the behavior of this decoder.
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
* should produce.
|
|
* @param aSampleSize The sample size requested using #-moz-samplesize (or 0
|
|
* if none).
|
|
* @param aResolution The resolution requested using #-moz-resolution (or an
|
|
* empty rect if none).
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateDecoder(DecoderType aType,
|
|
RasterImage* aImage,
|
|
SourceBuffer* aSourceBuffer,
|
|
const Maybe<gfx::IntSize>& aTargetSize,
|
|
DecoderFlags aDecoderFlags,
|
|
SurfaceFlags aSurfaceFlags,
|
|
int aSampleSize,
|
|
const gfx::IntSize& aResolution);
|
|
|
|
/**
|
|
* Creates and initializes a decoder for animated images of type @aType.
|
|
* The decoder will send notifications to @aImage.
|
|
*
|
|
* @param aType Which type of decoder to create - JPEG, PNG, etc.
|
|
* @param aImage The image will own the decoder and which should receive
|
|
* notifications as decoding progresses.
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
* from.
|
|
* @param aDecoderFlags Flags specifying the behavior of this decoder.
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
* should produce.
|
|
* @param aResolution The resolution requested using #-moz-resolution (or an
|
|
* empty rect if none).
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateAnimationDecoder(DecoderType aType,
|
|
RasterImage* aImage,
|
|
SourceBuffer* aSourceBuffer,
|
|
DecoderFlags aDecoderFlags,
|
|
SurfaceFlags aSurfaceFlags,
|
|
const gfx::IntSize& aResolution);
|
|
|
|
/**
|
|
* Creates and initializes a metadata decoder of type @aType. This decoder
|
|
* will only decode the image's header, extracting metadata like the size of
|
|
* the image. No actual image data will be decoded and no surfaces will be
|
|
* allocated. The decoder will send notifications to @aImage.
|
|
*
|
|
* @param aType Which type of decoder to create - JPEG, PNG, etc.
|
|
* @param aImage The image will own the decoder and which should receive
|
|
* notifications as decoding progresses.
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
* from.
|
|
* @param aSampleSize The sample size requested using #-moz-samplesize (or 0
|
|
* if none).
|
|
* @param aResolution The resolution requested using #-moz-resolution (or an
|
|
* empty rect if none).
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateMetadataDecoder(DecoderType aType,
|
|
RasterImage* aImage,
|
|
SourceBuffer* aSourceBuffer,
|
|
int aSampleSize,
|
|
const gfx::IntSize& aResolution);
|
|
|
|
/**
|
|
* Creates and initializes an anonymous decoder (one which isn't associated
|
|
* with an Image object). Only the first frame of the image will be decoded.
|
|
*
|
|
* @param aType Which type of decoder to create - JPEG, PNG, etc.
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
* from.
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
* should produce.
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateAnonymousDecoder(DecoderType aType,
|
|
SourceBuffer* aSourceBuffer,
|
|
SurfaceFlags aSurfaceFlags);
|
|
|
|
/**
|
|
* Creates and initializes an anonymous metadata decoder (one which isn't
|
|
* associated with an Image object). This decoder will only decode the image's
|
|
* header, extracting metadata like the size of the image. No actual image
|
|
* data will be decoded and no surfaces will be allocated.
|
|
*
|
|
* @param aType Which type of decoder to create - JPEG, PNG, etc.
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
* from.
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateAnonymousMetadataDecoder(DecoderType aType,
|
|
SourceBuffer* aSourceBuffer);
|
|
|
|
private:
|
|
virtual ~DecoderFactory() = 0;
|
|
|
|
/**
|
|
* An internal method which allocates a new decoder of the requested @aType.
|
|
*/
|
|
static already_AddRefed<Decoder> GetDecoder(DecoderType aType,
|
|
RasterImage* aImage,
|
|
bool aIsRedecode);
|
|
};
|
|
|
|
} // namespace image
|
|
} // namespace mozilla
|
|
|
|
#endif // mozilla_image_DecoderFactory_h
|