2022-08-23 14:47:48 +00:00
|
|
|
// Copyright 2022 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.
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Gamma correction utilities.
|
|
|
|
|
|
|
|
#ifndef WEBP_SHARPYUV_SHARPYUV_GAMMA_H_
|
|
|
|
#define WEBP_SHARPYUV_SHARPYUV_GAMMA_H_
|
|
|
|
|
2024-05-14 11:01:07 +00:00
|
|
|
#include "sharpyuv/sharpyuv.h"
|
2023-01-25 13:24:01 +00:00
|
|
|
#include "src/webp/types.h"
|
2022-08-23 14:47:48 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Initializes precomputed tables. Must be called once before calling
|
|
|
|
// SharpYuvGammaToLinear or SharpYuvLinearToGamma.
|
|
|
|
void SharpYuvInitGammaTables(void);
|
|
|
|
|
2024-05-14 11:01:07 +00:00
|
|
|
// Converts a 'bit_depth'-bit gamma color value to a 16-bit linear value.
|
|
|
|
uint32_t SharpYuvGammaToLinear(uint16_t v, int bit_depth,
|
|
|
|
SharpYuvTransferFunctionType transfer_type);
|
2022-08-23 14:47:48 +00:00
|
|
|
|
2024-05-14 11:01:07 +00:00
|
|
|
// Converts a 16-bit linear color value to a 'bit_depth'-bit gamma value.
|
|
|
|
uint16_t SharpYuvLinearToGamma(uint32_t value, int bit_depth,
|
|
|
|
SharpYuvTransferFunctionType transfer_type);
|
2022-08-23 14:47:48 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // WEBP_SHARPYUV_SHARPYUV_GAMMA_H_
|