2012-01-06 23:49:06 +01:00
|
|
|
// Copyright 2011 Google Inc. All Rights Reserved.
|
2011-02-19 08:33:46 +01:00
|
|
|
//
|
|
|
|
// This code is licensed under the same terms as WebM:
|
|
|
|
// Software License Agreement: http://www.webmproject.org/license/software/
|
|
|
|
// Additional IP Rights Grant: http://www.webmproject.org/license/additional/
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// WebP encoder: main interface
|
|
|
|
//
|
|
|
|
// Author: Skal (pascal.massimino@gmail.com)
|
|
|
|
|
|
|
|
#ifndef WEBP_WEBP_ENCODE_H_
|
|
|
|
#define WEBP_WEBP_ENCODE_H_
|
|
|
|
|
2011-05-03 02:19:00 +02:00
|
|
|
#include "./types.h"
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2011-12-01 11:24:50 +01:00
|
|
|
#define WEBP_ENCODER_ABI_VERSION 0x0003
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2011-03-25 00:17:10 +01:00
|
|
|
// Return the encoder's version number, packed in hexadecimal using 8bits for
|
|
|
|
// each of major/minor/revision. E.g: v2.5.7 is 0x020507.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPGetEncoderVersion(void);
|
2011-03-25 00:17:10 +01:00
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
// One-stop-shop call! No questions asked:
|
|
|
|
|
|
|
|
// Returns the size of the compressed data (pointed to by *output), or 0 if
|
|
|
|
// an error occurred. The compressed data must be released by the caller
|
|
|
|
// using the call 'free(*output)'.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(size_t) WebPEncodeRGB(const uint8_t* rgb,
|
|
|
|
int width, int height, int stride,
|
|
|
|
float quality_factor, uint8_t** output);
|
|
|
|
WEBP_EXTERN(size_t) WebPEncodeBGR(const uint8_t* bgr,
|
|
|
|
int width, int height, int stride,
|
|
|
|
float quality_factor, uint8_t** output);
|
|
|
|
WEBP_EXTERN(size_t) WebPEncodeRGBA(const uint8_t* rgba,
|
|
|
|
int width, int height, int stride,
|
|
|
|
float quality_factor, uint8_t** output);
|
|
|
|
WEBP_EXTERN(size_t) WebPEncodeBGRA(const uint8_t* bgra,
|
|
|
|
int width, int height, int stride,
|
|
|
|
float quality_factor, uint8_t** output);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
// Coding parameters
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
float quality; // between 0 (smallest file) and 100 (biggest)
|
|
|
|
int target_size; // if non-zero, set the desired target size in bytes.
|
|
|
|
// Takes precedence over the 'compression' parameter.
|
|
|
|
float target_PSNR; // if non-zero, specifies the minimal distortion to
|
|
|
|
// try to achieve. Takes precedence over target_size.
|
|
|
|
int method; // quality/speed trade-off (0=fast, 6=slower-better)
|
|
|
|
int segments; // maximum number of segments to use, in [1..4]
|
|
|
|
int sns_strength; // Spatial Noise Shaping. 0=off, 100=maximum.
|
|
|
|
int filter_strength; // range: [0 = off .. 100 = strongest]
|
|
|
|
int filter_sharpness; // range: [0 = off .. 7 = least sharp]
|
|
|
|
int filter_type; // filtering type: 0 = simple, 1 = strong
|
|
|
|
// (only used if filter_strength > 0 or autofilter > 0)
|
|
|
|
int autofilter; // Auto adjust filter's strength [0 = off, 1 = on]
|
|
|
|
int pass; // number of entropy-analysis passes (in [1..10]).
|
|
|
|
|
|
|
|
int show_compressed; // if true, export the compressed picture back.
|
|
|
|
// In-loop filtering is not applied.
|
|
|
|
int preprocessing; // preprocessing filter (0=none, 1=segment-smooth)
|
|
|
|
int partitions; // log2(number of token partitions) in [0..3]
|
|
|
|
// Default is set to 0 for easier progressive decoding.
|
2011-08-24 00:58:22 +02:00
|
|
|
int partition_limit; // quality degradation allowed to fit the 512k limit on
|
|
|
|
// prediction modes coding (0=no degradation, 100=full)
|
2011-12-01 07:44:15 +01:00
|
|
|
int alpha_compression; // Algorithm for encoding the alpha plane (0 = none,
|
2011-12-01 11:24:50 +01:00
|
|
|
// 1 = backward reference counts encoded with
|
2011-12-01 22:05:31 +01:00
|
|
|
// arithmetic encoder). Default is 1.
|
2012-01-05 08:34:30 +01:00
|
|
|
int alpha_filtering; // Predictive filtering method for alpha plane.
|
2012-01-09 04:27:21 +01:00
|
|
|
// 0: none, 1: fast, 2: best. Default if 1.
|
2011-12-01 07:44:15 +01:00
|
|
|
int alpha_quality; // Between 0 (smallest size) and 100 (lossless).
|
|
|
|
// Default is 100.
|
2012-03-28 13:07:42 +02:00
|
|
|
int lossless; // Lossless encoding (0=lossy(default), 1=lossless).
|
2011-02-19 08:33:46 +01:00
|
|
|
} WebPConfig;
|
|
|
|
|
|
|
|
// Enumerate some predefined settings for WebPConfig, depending on the type
|
|
|
|
// of source picture. These presets are used when calling WebPConfigPreset().
|
|
|
|
typedef enum {
|
|
|
|
WEBP_PRESET_DEFAULT = 0, // default preset.
|
|
|
|
WEBP_PRESET_PICTURE, // digital picture, like portrait, inner shot
|
|
|
|
WEBP_PRESET_PHOTO, // outdoor photograph, with natural lighting
|
|
|
|
WEBP_PRESET_DRAWING, // hand or line drawing, with high-contrast details
|
|
|
|
WEBP_PRESET_ICON, // small-sized colorful images
|
|
|
|
WEBP_PRESET_TEXT // text-like
|
|
|
|
} WebPPreset;
|
|
|
|
|
|
|
|
// Internal, version-checked, entry point
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPConfigInitInternal(
|
|
|
|
WebPConfig* const, WebPPreset, float, int);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
// Should always be called, to initialize a fresh WebPConfig structure before
|
|
|
|
// modification. Returns 0 in case of version mismatch. WebPConfigInit() must
|
|
|
|
// have succeeded before using the 'config' object.
|
2011-11-05 03:44:57 +01:00
|
|
|
static WEBP_INLINE int WebPConfigInit(WebPConfig* const config) {
|
2011-02-19 08:33:46 +01:00
|
|
|
return WebPConfigInitInternal(config, WEBP_PRESET_DEFAULT, 75.f,
|
|
|
|
WEBP_ENCODER_ABI_VERSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
// This function will initialize the configuration according to a predefined
|
|
|
|
// set of parameters (referred to by 'preset') and a given quality factor.
|
|
|
|
// This function can be called as a replacement to WebPConfigInit(). Will
|
|
|
|
// return 0 in case of error.
|
2011-11-05 03:44:57 +01:00
|
|
|
static WEBP_INLINE int WebPConfigPreset(WebPConfig* const config,
|
|
|
|
WebPPreset preset, float quality) {
|
2011-02-19 08:33:46 +01:00
|
|
|
return WebPConfigInitInternal(config, preset, quality,
|
|
|
|
WEBP_ENCODER_ABI_VERSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns 1 if all parameters are in valid range and the configuration is OK.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPValidateConfig(const WebPConfig* const config);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
// Input / Output
|
|
|
|
|
|
|
|
typedef struct WebPPicture WebPPicture; // main structure for I/O
|
|
|
|
|
2011-07-16 03:58:56 +02:00
|
|
|
// non-essential structure for storing auxiliary statistics
|
2011-02-19 08:33:46 +01:00
|
|
|
typedef struct {
|
|
|
|
float PSNR[4]; // peak-signal-to-noise ratio for Y/U/V/All
|
|
|
|
int coded_size; // final size
|
|
|
|
int block_count[3]; // number of intra4/intra16/skipped macroblocks
|
2011-07-16 03:58:56 +02:00
|
|
|
int header_bytes[2]; // approximate number of bytes spent for header
|
2011-02-19 08:33:46 +01:00
|
|
|
// and mode-partition #0
|
2011-07-16 03:58:56 +02:00
|
|
|
int residual_bytes[3][4]; // approximate number of bytes spent for
|
2011-02-19 08:33:46 +01:00
|
|
|
// DC/AC/uv coefficients for each (0..3) segments.
|
|
|
|
int segment_size[4]; // number of macroblocks in each segments
|
|
|
|
int segment_quant[4]; // quantizer values for each segments
|
|
|
|
int segment_level[4]; // filtering strength for each segments [0..63]
|
EXPERIMENTAL: add support for alpha channel
This is a (minor) bitstream change: if the 'color_space' bit is set to '1'
(which is normally an undefined/invalid behaviour), we add extra data at the
end of partition #0 (so-called 'extensions')
Namely, we add the size of the extension data as 3 bytes (little-endian),
followed by a set of bits telling which extensions we're incorporating.
The data then _preceeds_ this trailing tags.
This is all experimental, and you'll need to have
'#define WEBP_EXPERIMENTAL_FEATURES' in webp/types.h to enable this code
(at your own risk! :))
Still, this hack produces almost-valid WebP file for decoders that don't
check this color_space bit. In particular, previous 'dwebp' (and for instance
Chrome) will recognize this files and decode them, but without the alpha
of course. Other decoder will just see random extra stuff at the end of
partition #0.
To experiment with the alpha-channel, you need to compile on Unix platform
and use PNGs for input/output.
If 'alpha.png' is a source with alpha channel, then you can try (on Unix):
cwebp alpha.png -o alpha.webp
dwebp alpha.webp -o test.png
cwebp now has a '-noalpha' flag to ignore any alpha information from the
source, if present.
More hacking and experimenting welcome!
Change-Id: I3c7b1fd8411c9e7a9f77690e898479ad85c52f3e
2011-04-26 01:58:04 +02:00
|
|
|
|
|
|
|
int alpha_data_size; // size of the transparency data
|
2011-05-03 02:19:00 +02:00
|
|
|
int layer_data_size; // size of the enhancement layer data
|
2011-12-01 11:24:50 +01:00
|
|
|
|
|
|
|
void* user_data; // this field is free to be set to any value and
|
|
|
|
// used during callbacks (like progress-report e.g.).
|
2011-02-19 08:33:46 +01:00
|
|
|
} WebPAuxStats;
|
|
|
|
|
|
|
|
// Signature for output function. Should return 1 if writing was successful.
|
|
|
|
// data/data_size is the segment of data to write, and 'picture' is for
|
|
|
|
// reference (and so one can make use of picture->custom_ptr).
|
|
|
|
typedef int (*WebPWriterFunction)(const uint8_t* data, size_t data_size,
|
|
|
|
const WebPPicture* const picture);
|
|
|
|
|
2011-12-01 11:24:50 +01:00
|
|
|
// Progress hook, called from time to time to report progress. It can return 0
|
|
|
|
// to request an abort of the encoding process, or 1 otherwise if all is OK.
|
|
|
|
typedef int (*WebPProgressHook)(int percent, const WebPPicture* const picture);
|
|
|
|
|
2011-05-03 02:19:00 +02:00
|
|
|
typedef enum {
|
|
|
|
// chroma sampling
|
|
|
|
WEBP_YUV420 = 0, // 4:2:0
|
|
|
|
WEBP_YUV422 = 1, // 4:2:2
|
|
|
|
WEBP_YUV444 = 2, // 4:4:4
|
|
|
|
WEBP_YUV400 = 3, // grayscale
|
|
|
|
WEBP_CSP_UV_MASK = 3, // bit-mask to get the UV sampling factors
|
|
|
|
// alpha channel variants
|
|
|
|
WEBP_YUV420A = 4,
|
|
|
|
WEBP_YUV422A = 5,
|
|
|
|
WEBP_YUV444A = 6,
|
|
|
|
WEBP_YUV400A = 7, // grayscale + alpha
|
|
|
|
WEBP_CSP_ALPHA_BIT = 4 // bit that is set if alpha is present
|
|
|
|
} WebPEncCSP;
|
|
|
|
|
2011-06-02 15:55:03 +02:00
|
|
|
// Encoding error conditions.
|
|
|
|
typedef enum {
|
|
|
|
VP8_ENC_OK = 0,
|
|
|
|
VP8_ENC_ERROR_OUT_OF_MEMORY, // memory error allocating objects
|
|
|
|
VP8_ENC_ERROR_BITSTREAM_OUT_OF_MEMORY, // memory error while flushing bits
|
|
|
|
VP8_ENC_ERROR_NULL_PARAMETER, // a pointer parameter is NULL
|
|
|
|
VP8_ENC_ERROR_INVALID_CONFIGURATION, // configuration is invalid
|
|
|
|
VP8_ENC_ERROR_BAD_DIMENSION, // picture has invalid width/height
|
2011-06-28 16:02:56 +02:00
|
|
|
VP8_ENC_ERROR_PARTITION0_OVERFLOW, // partition is bigger than 512k
|
|
|
|
VP8_ENC_ERROR_PARTITION_OVERFLOW, // partition is bigger than 16M
|
2011-06-02 15:55:03 +02:00
|
|
|
VP8_ENC_ERROR_BAD_WRITE, // error while flushing bytes
|
2011-06-28 16:02:56 +02:00
|
|
|
VP8_ENC_ERROR_FILE_TOO_BIG, // file is bigger than 4G
|
2011-12-01 11:24:50 +01:00
|
|
|
VP8_ENC_ERROR_USER_ABORT, // abort request by user
|
|
|
|
VP8_ENC_ERROR_LAST // list terminator. always last.
|
2011-06-02 15:55:03 +02:00
|
|
|
} WebPEncodingError;
|
|
|
|
|
2011-09-12 21:27:21 +02:00
|
|
|
// maximum width/height allowed (inclusive), in pixels
|
|
|
|
#define WEBP_MAX_DIMENSION 16383
|
|
|
|
|
2011-02-19 08:33:46 +01:00
|
|
|
struct WebPPicture {
|
|
|
|
// input
|
2011-05-03 02:19:00 +02:00
|
|
|
WebPEncCSP colorspace; // colorspace: should be YUV420 for now (=Y'CbCr).
|
2011-09-12 21:27:21 +02:00
|
|
|
int width, height; // dimensions (less or equal to WEBP_MAX_DIMENSION)
|
2011-02-19 08:33:46 +01:00
|
|
|
uint8_t *y, *u, *v; // pointers to luma/chroma planes.
|
|
|
|
int y_stride, uv_stride; // luma/chroma strides.
|
2012-03-28 13:07:42 +02:00
|
|
|
uint8_t* a; // pointer to the alpha plane
|
2011-04-26 16:23:57 +02:00
|
|
|
int a_stride; // stride of the alpha plane
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
// output
|
|
|
|
WebPWriterFunction writer; // can be NULL
|
|
|
|
void* custom_ptr; // can be used by the writer.
|
|
|
|
|
|
|
|
// map for extra information
|
|
|
|
int extra_info_type; // 1: intra type, 2: segment, 3: quant
|
|
|
|
// 4: intra-16 prediction mode,
|
|
|
|
// 5: chroma prediction mode,
|
|
|
|
// 6: bit cost, 7: distortion
|
|
|
|
uint8_t* extra_info; // if not NULL, points to an array of size
|
|
|
|
// ((width + 15) / 16) * ((height + 15) / 16) that
|
|
|
|
// will be filled with a macroblock map, depending
|
|
|
|
// on extra_info_type.
|
|
|
|
|
|
|
|
// where to store statistics, if not NULL:
|
|
|
|
WebPAuxStats* stats;
|
2011-05-03 02:19:00 +02:00
|
|
|
|
|
|
|
// original samples (for non-YUV420 modes)
|
|
|
|
uint8_t *u0, *v0;
|
|
|
|
int uv0_stride;
|
2011-06-02 15:55:03 +02:00
|
|
|
|
|
|
|
WebPEncodingError error_code; // error code in case of problem.
|
2011-12-01 11:24:50 +01:00
|
|
|
|
|
|
|
WebPProgressHook progress_hook; // if not NULL, called while encoding.
|
2012-03-28 13:07:42 +02:00
|
|
|
|
|
|
|
int use_argb_input; // Flag for encoder to read argb pixels as input.
|
|
|
|
uint32_t* argb; // Pointer to argb (32 bit) plane.
|
|
|
|
int argb_stride; // This is stride in pixels units, not bytes.
|
2011-02-19 08:33:46 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
// Internal, version-checked, entry point
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureInitInternal(WebPPicture* const, int);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
// Should always be called, to initialize the structure. Returns 0 in case of
|
|
|
|
// version mismatch. WebPPictureInit() must have succeeded before using the
|
|
|
|
// 'picture' object.
|
2011-11-05 03:44:57 +01:00
|
|
|
static WEBP_INLINE int WebPPictureInit(WebPPicture* const picture) {
|
2011-02-19 08:33:46 +01:00
|
|
|
return WebPPictureInitInternal(picture, WEBP_ENCODER_ABI_VERSION);
|
|
|
|
}
|
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
// WebPPicture utils
|
|
|
|
|
|
|
|
// Convenience allocation / deallocation based on picture->width/height:
|
2011-05-03 02:19:00 +02:00
|
|
|
// Allocate y/u/v buffers as per colorspace/width/height specification.
|
2011-02-19 08:33:46 +01:00
|
|
|
// Note! This function will free the previous buffer if needed.
|
|
|
|
// Returns 0 in case of memory error.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureAlloc(WebPPicture* const picture);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
// Release memory allocated by WebPPictureAlloc() or WebPPictureImport*()
|
|
|
|
// Note that this function does _not_ free the memory pointed to by 'picture'.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(void) WebPPictureFree(WebPPicture* const picture);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
// Copy the pixels of *src into *dst, using WebPPictureAlloc.
|
|
|
|
// Returns 0 in case of memory allocation error.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureCopy(const WebPPicture* const src,
|
|
|
|
WebPPicture* const dst);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2012-01-20 16:20:56 +01:00
|
|
|
// Compute PSNR or SSIM distortion between two pictures.
|
|
|
|
// Result is in dB, stores in result[] in the Y/U/V/Alpha/All order.
|
|
|
|
// Returns 0 in case of error (pic1 and pic2 don't have same dimension, ...)
|
|
|
|
// Warning: this function is rather CPU-intensive.
|
|
|
|
WEBP_EXTERN(int) WebPPictureDistortion(
|
|
|
|
const WebPPicture* const pic1, const WebPPicture* const pic2,
|
|
|
|
int metric_type, // 0 = PSNR, 1 = SSIM
|
|
|
|
float result[5]);
|
|
|
|
|
2011-02-19 08:33:46 +01:00
|
|
|
// self-crops a picture to the rectangle defined by top/left/width/height.
|
|
|
|
// Returns 0 in case of memory allocation error, or if the rectangle is
|
|
|
|
// outside of the source picture.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureCrop(WebPPicture* const picture,
|
|
|
|
int left, int top, int width, int height);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2011-05-03 02:19:00 +02:00
|
|
|
// Rescale a picture to new dimension width x height.
|
|
|
|
// Now gamma correction is applied.
|
|
|
|
// Returns false in case of error (invalid parameter or insufficient memory).
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureRescale(WebPPicture* const pic,
|
|
|
|
int width, int height);
|
2011-05-03 02:19:00 +02:00
|
|
|
|
EXPERIMENTAL: add support for alpha channel
This is a (minor) bitstream change: if the 'color_space' bit is set to '1'
(which is normally an undefined/invalid behaviour), we add extra data at the
end of partition #0 (so-called 'extensions')
Namely, we add the size of the extension data as 3 bytes (little-endian),
followed by a set of bits telling which extensions we're incorporating.
The data then _preceeds_ this trailing tags.
This is all experimental, and you'll need to have
'#define WEBP_EXPERIMENTAL_FEATURES' in webp/types.h to enable this code
(at your own risk! :))
Still, this hack produces almost-valid WebP file for decoders that don't
check this color_space bit. In particular, previous 'dwebp' (and for instance
Chrome) will recognize this files and decode them, but without the alpha
of course. Other decoder will just see random extra stuff at the end of
partition #0.
To experiment with the alpha-channel, you need to compile on Unix platform
and use PNGs for input/output.
If 'alpha.png' is a source with alpha channel, then you can try (on Unix):
cwebp alpha.png -o alpha.webp
dwebp alpha.webp -o test.png
cwebp now has a '-noalpha' flag to ignore any alpha information from the
source, if present.
More hacking and experimenting welcome!
Change-Id: I3c7b1fd8411c9e7a9f77690e898479ad85c52f3e
2011-04-26 01:58:04 +02:00
|
|
|
// Colorspace conversion function to import RGB samples.
|
|
|
|
// Previous buffer will be free'd, if any.
|
2011-02-19 08:33:46 +01:00
|
|
|
// *rgb buffer should have a size of at least height * rgb_stride.
|
|
|
|
// Returns 0 in case of memory error.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureImportRGB(
|
|
|
|
WebPPicture* const picture, const uint8_t* const rgb, int rgb_stride);
|
EXPERIMENTAL: add support for alpha channel
This is a (minor) bitstream change: if the 'color_space' bit is set to '1'
(which is normally an undefined/invalid behaviour), we add extra data at the
end of partition #0 (so-called 'extensions')
Namely, we add the size of the extension data as 3 bytes (little-endian),
followed by a set of bits telling which extensions we're incorporating.
The data then _preceeds_ this trailing tags.
This is all experimental, and you'll need to have
'#define WEBP_EXPERIMENTAL_FEATURES' in webp/types.h to enable this code
(at your own risk! :))
Still, this hack produces almost-valid WebP file for decoders that don't
check this color_space bit. In particular, previous 'dwebp' (and for instance
Chrome) will recognize this files and decode them, but without the alpha
of course. Other decoder will just see random extra stuff at the end of
partition #0.
To experiment with the alpha-channel, you need to compile on Unix platform
and use PNGs for input/output.
If 'alpha.png' is a source with alpha channel, then you can try (on Unix):
cwebp alpha.png -o alpha.webp
dwebp alpha.webp -o test.png
cwebp now has a '-noalpha' flag to ignore any alpha information from the
source, if present.
More hacking and experimenting welcome!
Change-Id: I3c7b1fd8411c9e7a9f77690e898479ad85c52f3e
2011-04-26 01:58:04 +02:00
|
|
|
// Same, but for RGBA buffer
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureImportRGBA(
|
|
|
|
WebPPicture* const picture, const uint8_t* const rgba, int rgba_stride);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
EXPERIMENTAL: add support for alpha channel
This is a (minor) bitstream change: if the 'color_space' bit is set to '1'
(which is normally an undefined/invalid behaviour), we add extra data at the
end of partition #0 (so-called 'extensions')
Namely, we add the size of the extension data as 3 bytes (little-endian),
followed by a set of bits telling which extensions we're incorporating.
The data then _preceeds_ this trailing tags.
This is all experimental, and you'll need to have
'#define WEBP_EXPERIMENTAL_FEATURES' in webp/types.h to enable this code
(at your own risk! :))
Still, this hack produces almost-valid WebP file for decoders that don't
check this color_space bit. In particular, previous 'dwebp' (and for instance
Chrome) will recognize this files and decode them, but without the alpha
of course. Other decoder will just see random extra stuff at the end of
partition #0.
To experiment with the alpha-channel, you need to compile on Unix platform
and use PNGs for input/output.
If 'alpha.png' is a source with alpha channel, then you can try (on Unix):
cwebp alpha.png -o alpha.webp
dwebp alpha.webp -o test.png
cwebp now has a '-noalpha' flag to ignore any alpha information from the
source, if present.
More hacking and experimenting welcome!
Change-Id: I3c7b1fd8411c9e7a9f77690e898479ad85c52f3e
2011-04-26 01:58:04 +02:00
|
|
|
// Variant of the above, but taking BGR(A) input:
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPPictureImportBGR(
|
|
|
|
WebPPicture* const picture, const uint8_t* const bgr, int bgr_stride);
|
|
|
|
WEBP_EXTERN(int) WebPPictureImportBGRA(
|
|
|
|
WebPPicture* const picture, const uint8_t* const bgra, int bgra_stride);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2012-01-17 09:18:22 +01:00
|
|
|
// Helper function: given a width x height plane of YUV(A) samples
|
|
|
|
// (with stride 'stride'), clean-up the YUV samples under fully transparent
|
|
|
|
// area, to help compressibility (no guarantee, though).
|
|
|
|
WEBP_EXTERN(void) WebPCleanupTransparentArea(WebPPicture* const picture);
|
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
// Main call
|
|
|
|
|
2011-07-16 03:58:56 +02:00
|
|
|
// Main encoding call, after config and picture have been initialized.
|
2011-09-12 21:27:21 +02:00
|
|
|
// 'picture' must be less than 16384x16384 in dimension (cf WEBP_MAX_DIMENSION),
|
|
|
|
// and the 'config' object must be a valid one.
|
2011-02-19 08:33:46 +01:00
|
|
|
// Returns false in case of error, true otherwise.
|
2011-06-02 15:55:03 +02:00
|
|
|
// In case of error, picture->error_code is updated accordingly.
|
2011-07-13 04:43:15 +02:00
|
|
|
WEBP_EXTERN(int) WebPEncode(
|
|
|
|
const WebPConfig* const config, WebPPicture* const picture);
|
2011-02-19 08:33:46 +01:00
|
|
|
|
2011-08-25 23:22:32 +02:00
|
|
|
//------------------------------------------------------------------------------
|
2011-02-19 08:33:46 +01:00
|
|
|
|
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* WEBP_WEBP_ENCODE_H_ */
|