2015-07-23 08:39:48 +03:00
|
|
|
/* -*- 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
|
|
|
|
|
2015-08-15 03:56:44 +03:00
|
|
|
#include "DecoderFlags.h"
|
|
|
|
#include "mozilla/Attributes.h"
|
2015-07-23 08:39:48 +03:00
|
|
|
#include "mozilla/Maybe.h"
|
2016-06-27 07:50:43 +03:00
|
|
|
#include "mozilla/NotNull.h"
|
2015-07-23 08:39:48 +03:00
|
|
|
#include "mozilla/gfx/2D.h"
|
|
|
|
#include "nsCOMPtr.h"
|
2015-08-15 03:56:44 +03:00
|
|
|
#include "SurfaceFlags.h"
|
2015-07-23 08:39:48 +03:00
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace image {
|
|
|
|
|
|
|
|
class Decoder;
|
2016-06-26 10:09:24 +03:00
|
|
|
class IDecodingTask;
|
2016-07-03 06:20:55 +03:00
|
|
|
class nsICODecoder;
|
2015-07-23 08:39:48 +03:00
|
|
|
class RasterImage;
|
|
|
|
class SourceBuffer;
|
|
|
|
|
2015-08-15 03:56:44 +03:00
|
|
|
/**
|
|
|
|
* The type of decoder; this is usually determined from a MIME type using
|
|
|
|
* DecoderFactory::GetDecoderType().
|
|
|
|
*/
|
2015-07-23 08:39:48 +03:00
|
|
|
enum class DecoderType
|
|
|
|
{
|
|
|
|
PNG,
|
|
|
|
GIF,
|
|
|
|
JPEG,
|
|
|
|
BMP,
|
|
|
|
ICO,
|
|
|
|
ICON,
|
|
|
|
UNKNOWN
|
|
|
|
};
|
|
|
|
|
|
|
|
class DecoderFactory
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// @return the type of decoder which is appropriate for @aMimeType.
|
|
|
|
static DecoderType GetDecoderType(const char* aMimeType);
|
|
|
|
|
|
|
|
/**
|
2015-08-14 10:37:13 +03:00
|
|
|
* 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.
|
2015-07-23 08:39:48 +03:00
|
|
|
*
|
|
|
|
* @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.
|
2016-06-27 08:05:58 +03:00
|
|
|
* @param aIntrinsicSize The intrinsic size of the image, normally obtained
|
|
|
|
* during the metadata decode.
|
2015-07-23 08:39:48 +03:00
|
|
|
* @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.
|
2015-08-15 03:56:44 +03:00
|
|
|
* @param aDecoderFlags Flags specifying the behavior of this decoder.
|
|
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
|
|
* should produce.
|
2015-07-31 17:29:03 +03:00
|
|
|
* @param aSampleSize The sample size requested using #-moz-samplesize (or 0
|
|
|
|
* if none).
|
2015-07-23 08:39:48 +03:00
|
|
|
*/
|
2016-06-26 10:09:24 +03:00
|
|
|
static already_AddRefed<IDecodingTask>
|
2015-07-23 08:39:48 +03:00
|
|
|
CreateDecoder(DecoderType aType,
|
2016-06-27 07:50:43 +03:00
|
|
|
NotNull<RasterImage*> aImage,
|
|
|
|
NotNull<SourceBuffer*> aSourceBuffer,
|
2016-06-27 08:05:58 +03:00
|
|
|
const gfx::IntSize& aIntrinsicSize,
|
2015-07-23 08:39:48 +03:00
|
|
|
const Maybe<gfx::IntSize>& aTargetSize,
|
2015-08-15 03:56:44 +03:00
|
|
|
DecoderFlags aDecoderFlags,
|
|
|
|
SurfaceFlags aSurfaceFlags,
|
2015-10-01 03:00:52 +03:00
|
|
|
int aSampleSize);
|
2015-08-14 10:37:13 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2016-06-27 08:05:58 +03:00
|
|
|
* @param aIntrinsicSize The intrinsic size of the image, normally obtained
|
|
|
|
* during the metadata decode.
|
2015-08-15 03:56:44 +03:00
|
|
|
* @param aDecoderFlags Flags specifying the behavior of this decoder.
|
|
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
|
|
* should produce.
|
2015-08-14 10:37:13 +03:00
|
|
|
*/
|
2016-06-26 10:09:24 +03:00
|
|
|
static already_AddRefed<IDecodingTask>
|
2015-08-14 10:37:13 +03:00
|
|
|
CreateAnimationDecoder(DecoderType aType,
|
2016-06-27 07:50:43 +03:00
|
|
|
NotNull<RasterImage*> aImage,
|
|
|
|
NotNull<SourceBuffer*> aSourceBuffer,
|
2016-06-27 08:05:58 +03:00
|
|
|
const gfx::IntSize& aIntrinsicSize,
|
2015-08-15 03:56:44 +03:00
|
|
|
DecoderFlags aDecoderFlags,
|
2015-10-01 03:00:52 +03:00
|
|
|
SurfaceFlags aSurfaceFlags);
|
2015-07-23 08:39:48 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2015-07-31 17:29:03 +03:00
|
|
|
* @param aSampleSize The sample size requested using #-moz-samplesize (or 0
|
|
|
|
* if none).
|
2015-07-23 08:39:48 +03:00
|
|
|
*/
|
2016-06-26 10:09:24 +03:00
|
|
|
static already_AddRefed<IDecodingTask>
|
2015-07-23 08:39:48 +03:00
|
|
|
CreateMetadataDecoder(DecoderType aType,
|
2016-06-27 07:50:43 +03:00
|
|
|
NotNull<RasterImage*> aImage,
|
|
|
|
NotNull<SourceBuffer*> aSourceBuffer,
|
2015-10-01 03:00:52 +03:00
|
|
|
int aSampleSize);
|
2015-07-23 08:39:48 +03:00
|
|
|
|
2016-07-03 06:20:55 +03:00
|
|
|
/**
|
|
|
|
* Creates and initializes a decoder for an ICO resource, which may be either
|
|
|
|
* a BMP or PNG image.
|
|
|
|
*
|
|
|
|
* @param aType Which type of decoder to create. This must be either BMP or
|
|
|
|
* PNG.
|
|
|
|
* @param aSourceBuffer The SourceBuffer which the decoder will read its data
|
|
|
|
* from.
|
|
|
|
* @param aICODecoder The ICO decoder which is controlling this resource
|
|
|
|
* decoder. @aICODecoder's settings will be copied to the
|
|
|
|
* resource decoder, so the two decoders will have the
|
|
|
|
* same decoder flags, surface flags, target size, and
|
|
|
|
* other parameters.
|
|
|
|
* @param aDataOffset If @aType is BMP, specifies the offset at which data
|
|
|
|
* begins in the BMP resource. Must be Some() if and only
|
|
|
|
* if @aType is BMP.
|
|
|
|
*/
|
|
|
|
static already_AddRefed<Decoder>
|
|
|
|
CreateDecoderForICOResource(DecoderType aType,
|
|
|
|
NotNull<SourceBuffer*> aSourceBuffer,
|
|
|
|
NotNull<nsICODecoder*> aICODecoder,
|
|
|
|
const Maybe<uint32_t>& aDataOffset = Nothing());
|
|
|
|
|
2015-08-12 20:41:05 +03:00
|
|
|
/**
|
|
|
|
* 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.
|
2016-05-27 22:59:19 +03:00
|
|
|
* @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.
|
2015-08-15 03:56:44 +03:00
|
|
|
* @param aSurfaceFlags Flags specifying the type of output this decoder
|
|
|
|
* should produce.
|
2015-08-12 20:41:05 +03:00
|
|
|
*/
|
2015-08-01 04:10:31 +03:00
|
|
|
static already_AddRefed<Decoder>
|
|
|
|
CreateAnonymousDecoder(DecoderType aType,
|
2016-06-27 07:50:43 +03:00
|
|
|
NotNull<SourceBuffer*> aSourceBuffer,
|
2016-05-27 22:59:19 +03:00
|
|
|
const Maybe<gfx::IntSize>& aTargetSize,
|
2015-08-15 03:56:44 +03:00
|
|
|
SurfaceFlags aSurfaceFlags);
|
2015-08-01 04:10:31 +03:00
|
|
|
|
2015-08-12 20:41:05 +03:00
|
|
|
/**
|
|
|
|
* 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,
|
2016-06-27 07:50:43 +03:00
|
|
|
NotNull<SourceBuffer*> aSourceBuffer);
|
2015-08-12 20:41:05 +03:00
|
|
|
|
2015-07-23 08:39:48 +03:00
|
|
|
private:
|
|
|
|
virtual ~DecoderFactory() = 0;
|
2015-07-23 08:39:56 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* An internal method which allocates a new decoder of the requested @aType.
|
|
|
|
*/
|
|
|
|
static already_AddRefed<Decoder> GetDecoder(DecoderType aType,
|
|
|
|
RasterImage* aImage,
|
|
|
|
bool aIsRedecode);
|
2015-07-23 08:39:48 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace image
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif // mozilla_image_DecoderFactory_h
|