/* * 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 // 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 Decode(std::unique_ptr, SkCodec::Result*, SkCodecs::DecodeContext = nullptr); SK_API std::unique_ptr Decode(sk_sp, 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