mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
13934d9866
- Bug 1184996 (Part 1) - Create decoders with a DecoderFactory. r=tn (dacf21ed2) - Bug 1184996 (Part 2) - Clean up RasterImage's decoding API. r=tn (c127af0b3) - Bug 1184996 (Part 3) - Replace all remaining references to 'size decodes' with 'metadata decodes'. r=tn (3744e5df4) - Bug 1184996 (Part 4) - Forbid instantiation of decoders except via DecoderFactory. r=tn (588d56d84) - No bug - Remove extra printf left over from bug 1127618. r=smaug (b02f7bfe1) - Bug 1187386 (Part 1) - Make most decoder state private. r=tn (328dbc605) - Bug 1187386 (Part 2) - Rework decoder code to avoid calling Decode::GetImage(). r=tn (9a94096f9) - Bug 1187386 (Part 3) - Don't destroy Decoder::mImage if Decoder::mImage is null. r=tn (cbb6738cd) - Bug 1187386 (Part 4) - Make imgFrame::SetOptimizable() callable from off-main-thread. r=tn (f03478b28) - Bug 1187386 (Part 5) - Merge Decoder::SetSizeOnImage() into ImageMetadata::SetOnImage(). r=tn (8afb5d4a3) - Bug 1033090 - Truncate a large URI in the user message about it. r=seth (7bd4b447b) - Bug 1187386 (Part 6) - Merge Decoder::Finish() and RasterImage::OnDecodingComplete() into RasterImage::FinalizeDecoder(). r=tn (f342dd5db) - Bug 1181863 (Part 1) - Add support for reading from nsIInputStreams directly to SourceBuffer. r=tn (74748dad9) - Bug 1181863 (Part 2) - Add ImageOps::DecodeToSurface() to allow image decoding without involving any main-thread-only objects. r=tn (25b86eb50) - Bug 1181863 (Part 3) - Add tests for DecodeToSurface(). r=tn (9506eb2f6) - Bug 1181863 - Part 4: Fix the build bustage (aee05bdc9) - Bug 1187546 - Make it possible to ask image decoders to only decode the first frame. r=tn (1beeeefb6) - Bug 1191100 - Remove XPIDL signature comments in .cpp files. r=ehsan (ee75fe3b5)
126 lines
4.5 KiB
C++
126 lines
4.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 "mozilla/Maybe.h"
|
|
#include "mozilla/gfx/2D.h"
|
|
#include "nsCOMPtr.h"
|
|
|
|
class nsACString;
|
|
|
|
namespace mozilla {
|
|
namespace image {
|
|
|
|
class Decoder;
|
|
class RasterImage;
|
|
class SourceBuffer;
|
|
|
|
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 of type @aType. The decoder will send
|
|
* notifications to @aImage.
|
|
*
|
|
* XXX(seth): @aIsRedecode, @aImageIsTransient, and @aImageIsLocked should
|
|
* really be part of @aFlags. This requires changes to the way that decoder
|
|
* flags work, though. See bug 1185800.
|
|
*
|
|
* @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 aFlags Flags specifying what type of output the decoder should
|
|
* produce; see GetDecodeFlags() in RasterImage.h.
|
|
* @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).
|
|
* @param aIsRedecode Specify 'true' if this image has been decoded before.
|
|
* @param aImageIsTransient Specify 'true' if this image is transient.
|
|
* @param aImageIsLocked Specify 'true' if this image is locked for the
|
|
* lifetime of this decoder, and should be unlocked
|
|
* when the decoder finishes.
|
|
*/
|
|
static already_AddRefed<Decoder>
|
|
CreateDecoder(DecoderType aType,
|
|
RasterImage* aImage,
|
|
SourceBuffer* aSourceBuffer,
|
|
const Maybe<gfx::IntSize>& aTargetSize,
|
|
uint32_t aFlags,
|
|
int aSampleSize,
|
|
const gfx::IntSize& aResolution,
|
|
bool aIsRedecode,
|
|
bool aImageIsTransient,
|
|
bool aImageIsLocked);
|
|
|
|
/**
|
|
* 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);
|
|
|
|
static already_AddRefed<Decoder>
|
|
CreateAnonymousDecoder(DecoderType aType,
|
|
SourceBuffer* aSourceBuffer,
|
|
uint32_t aFlags);
|
|
|
|
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
|