mirror of
https://github.com/webmproject/libwebp.git
synced 2025-01-22 04:22:51 +01:00
47178dbd45
This is useful for converting associated to unassociated. Change-Id: I0e6d16ec63cb5514a0f945c14a54e0d01e1fab0a
78 lines
3.2 KiB
C
78 lines
3.2 KiB
C
// Copyright 2015 Google Inc. All Rights Reserved.
|
|
//
|
|
// Use of this source code is governed by a BSD-style license
|
|
// that can be found in the COPYING file in the root of the source
|
|
// tree. An additional intellectual property rights grant can be found
|
|
// in the file PATENTS. All contributing project authors may
|
|
// be found in the AUTHORS file in the root of the source tree.
|
|
// -----------------------------------------------------------------------------
|
|
//
|
|
|
|
#ifndef WEBP_EXTRAS_EXTRAS_H_
|
|
#define WEBP_EXTRAS_EXTRAS_H_
|
|
|
|
#include "webp/types.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include "webp/encode.h"
|
|
|
|
#define WEBP_EXTRAS_ABI_VERSION 0x0002 // MAJOR(8b) + MINOR(8b)
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
// Returns the version number of the extras library, packed in hexadecimal using
|
|
// 8bits for each of major/minor/revision. E.g: v2.5.7 is 0x020507.
|
|
WEBP_EXTERN int WebPGetExtrasVersion(void);
|
|
|
|
//------------------------------------------------------------------------------
|
|
// Ad-hoc colorspace importers.
|
|
|
|
// Import luma sample (gray scale image) into 'picture'. The 'picture'
|
|
// width and height must be set prior to calling this function.
|
|
WEBP_EXTERN int WebPImportGray(const uint8_t* gray, WebPPicture* picture);
|
|
|
|
// Import rgb sample in RGB565 packed format into 'picture'. The 'picture'
|
|
// width and height must be set prior to calling this function.
|
|
WEBP_EXTERN int WebPImportRGB565(const uint8_t* rgb565, WebPPicture* pic);
|
|
|
|
// Import rgb sample in RGB4444 packed format into 'picture'. The 'picture'
|
|
// width and height must be set prior to calling this function.
|
|
WEBP_EXTERN int WebPImportRGB4444(const uint8_t* rgb4444, WebPPicture* pic);
|
|
|
|
// Import a color mapped image. The number of colors is less or equal to
|
|
// MAX_PALETTE_SIZE. 'pic' must have been initialized. Its content, if any,
|
|
// will be discarded. Returns 'false' in case of error, or if indexed[] contains
|
|
// invalid indices.
|
|
WEBP_EXTERN int
|
|
WebPImportColorMappedARGB(const uint8_t* indexed, int indexed_stride,
|
|
const uint32_t palette[], int palette_size,
|
|
WebPPicture* pic);
|
|
|
|
// Convert the ARGB content of 'pic' from associated to unassociated.
|
|
// 'pic' can be for instance the result of calling of some WebPPictureImportXXX
|
|
// functions, with pic->use_argb set to 'true'. It is assumed (and not checked)
|
|
// that the pre-multiplied r/g/b values as less or equal than the alpha value.
|
|
// Return false in case of error (invalid parameter, ...).
|
|
WEBP_EXTERN int WebPUnmultiplyARGB(WebPPicture* pic);
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
// Parse a bitstream, search for VP8 (lossy) header and report a
|
|
// rough estimation of the quality factor used for compressing the bitstream.
|
|
// If the bitstream is in lossless format, the special value '101' is returned.
|
|
// Otherwise (lossy bitstream), the returned value is in the range [0..100].
|
|
// Any error (invalid bitstream, animated WebP, incomplete header, etc.)
|
|
// will return a value of -1.
|
|
WEBP_EXTERN int VP8EstimateQuality(const uint8_t* const data, size_t size);
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|
|
|
|
#endif // WEBP_EXTRAS_EXTRAS_H_
|