Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 1 | // Copyright 2011 Google Inc. All Rights Reserved. |
| 2 | // |
Vikas Arora | 0406ce1 | 2013-08-09 15:57:12 -0700 | [diff] [blame] | 3 | // Use of this source code is governed by a BSD-style license |
| 4 | // that can be found in the COPYING file in the root of the source |
| 5 | // tree. An additional intellectual property rights grant can be found |
| 6 | // in the file PATENTS. All contributing project authors may |
| 7 | // be found in the AUTHORS file in the root of the source tree. |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 8 | // ----------------------------------------------------------------------------- |
| 9 | // |
| 10 | // Spatial prediction using various filters |
| 11 | // |
| 12 | // Author: Urvang (urvang@google.com) |
| 13 | |
| 14 | #ifndef WEBP_UTILS_FILTERS_H_ |
| 15 | #define WEBP_UTILS_FILTERS_H_ |
| 16 | |
James Zern | 9e80ee9 | 2015-03-17 18:54:21 -0700 | [diff] [blame] | 17 | #include "../webp/types.h" |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 18 | |
Vikas Arora | 8b72022 | 2014-01-02 16:48:02 -0800 | [diff] [blame] | 19 | #ifdef __cplusplus |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 20 | extern "C" { |
| 21 | #endif |
| 22 | |
| 23 | // Filters. |
| 24 | typedef enum { |
| 25 | WEBP_FILTER_NONE = 0, |
| 26 | WEBP_FILTER_HORIZONTAL, |
| 27 | WEBP_FILTER_VERTICAL, |
| 28 | WEBP_FILTER_GRADIENT, |
| 29 | WEBP_FILTER_LAST = WEBP_FILTER_GRADIENT + 1, // end marker |
| 30 | WEBP_FILTER_BEST, |
| 31 | WEBP_FILTER_FAST |
| 32 | } WEBP_FILTER_TYPE; |
| 33 | |
| 34 | typedef void (*WebPFilterFunc)(const uint8_t* in, int width, int height, |
Vikas Arora | 0406ce1 | 2013-08-09 15:57:12 -0700 | [diff] [blame] | 35 | int stride, uint8_t* out); |
| 36 | typedef void (*WebPUnfilterFunc)(int width, int height, int stride, |
Vikas Arora | 8b72022 | 2014-01-02 16:48:02 -0800 | [diff] [blame] | 37 | int row, int num_rows, uint8_t* data); |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 38 | |
| 39 | // Filter the given data using the given predictor. |
| 40 | // 'in' corresponds to a 2-dimensional pixel array of size (stride * height) |
| 41 | // in raster order. |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 42 | // 'stride' is number of bytes per scan line (with possible padding). |
| 43 | // 'out' should be pre-allocated. |
| 44 | extern const WebPFilterFunc WebPFilters[WEBP_FILTER_LAST]; |
| 45 | |
Vikas Arora | 0406ce1 | 2013-08-09 15:57:12 -0700 | [diff] [blame] | 46 | // In-place reconstruct the original data from the given filtered data. |
Vikas Arora | 8b72022 | 2014-01-02 16:48:02 -0800 | [diff] [blame] | 47 | // The reconstruction will be done for 'num_rows' rows starting from 'row' |
| 48 | // (assuming rows upto 'row - 1' are already reconstructed). |
Vikas Arora | 0406ce1 | 2013-08-09 15:57:12 -0700 | [diff] [blame] | 49 | extern const WebPUnfilterFunc WebPUnfilters[WEBP_FILTER_LAST]; |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 50 | |
| 51 | // Fast estimate of a potentially good filter. |
Vikas Arora | 8b72022 | 2014-01-02 16:48:02 -0800 | [diff] [blame] | 52 | WEBP_FILTER_TYPE EstimateBestFilter(const uint8_t* data, |
| 53 | int width, int height, int stride); |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 54 | |
Vikas Arora | 8b72022 | 2014-01-02 16:48:02 -0800 | [diff] [blame] | 55 | #ifdef __cplusplus |
Vikas Arora | a241572 | 2012-08-09 16:18:58 -0700 | [diff] [blame] | 56 | } // extern "C" |
| 57 | #endif |
| 58 | |
| 59 | #endif /* WEBP_UTILS_FILTERS_H_ */ |