blob: f1a06b0868cdd74e7f5de72733cfac296f9942a6 [file] [log] [blame]
/*
* Copyright 2023 Google LLC
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkHeifDecoder_DEFINED
#define SkHeifDecoder_DEFINED
#include "include/codec/SkCodec.h"
#include "include/core/SkRefCnt.h"
class SkData;
class SkStream;
#include <memory>
// This codec depends on heif libraries that are only part of the Android framework.
// It will not work on other platforms currently.
//
// For historical reasons, this codec also decodes AVIF images.
// There is a newer, dedicated SkAvifDecoder which could be used instead.
namespace SkHeifDecoder {
/** Returns true if this data claims to be a HEIF (or AVIF) image. */
SK_API bool IsHeif(const void*, size_t);
/**
* Attempts to decode the given bytes as a HEIF (or AVIF).
*
* If the bytes are not a HEIF (or AVIF), returns nullptr.
*
* DecodeContext is treated as a SkCodec::SelectionPolicy*
*/
SK_API std::unique_ptr<SkCodec> Decode(std::unique_ptr<SkStream>,
SkCodec::Result*,
SkCodecs::DecodeContext = nullptr);
SK_API std::unique_ptr<SkCodec> Decode(sk_sp<SkData>,
SkCodec::Result*,
SkCodecs::DecodeContext = nullptr);
// Do not register this codec using "avif" as the key (even though it can handle that type).
// Doing so would cause internal codec sniffing to choose the wrong sampler.
inline SkCodecs::Decoder Decoder() {
return { "heif", IsHeif, Decode };
}
} // namespace SkHeifDecoder
#endif // SkHeifDecoder_DEFINED