2020-08-05 14:44:17 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2020 Google LLC
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2020-08-05 20:51:10 +00:00
|
|
|
#ifndef SkImageGeneratorNDK_DEFINED
|
|
|
|
#define SkImageGeneratorNDK_DEFINED
|
|
|
|
|
2020-08-05 14:44:17 +00:00
|
|
|
#include "include/core/SkTypes.h"
|
2020-08-05 20:51:10 +00:00
|
|
|
#ifdef SK_ENABLE_NDK_IMAGES
|
2020-08-05 14:44:17 +00:00
|
|
|
|
|
|
|
#include "include/core/SkData.h"
|
|
|
|
#include "include/core/SkImageGenerator.h"
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
namespace SkImageGeneratorNDK {
|
|
|
|
/**
|
|
|
|
* Create a generator that uses the Android NDK's APIs for decoding images.
|
|
|
|
*
|
|
|
|
* Only supported on devices where __ANDROID_API__ >= 30.
|
|
|
|
*
|
|
|
|
* As with SkCodec, the SkColorSpace passed to getPixels() determines the
|
|
|
|
* type of color space transformations to apply. A null SkColorSpace means to
|
|
|
|
* apply none.
|
|
|
|
*
|
|
|
|
* A note on scaling: Calling getPixels() on the resulting SkImageGenerator
|
|
|
|
* with dimensions that do not match getInfo() requests a scale. For WebP
|
|
|
|
* files, dimensions smaller than those of getInfo are supported. For Jpeg
|
|
|
|
* files, dimensions of 1/2, 1/4, and 1/8 are supported. TODO: Provide an
|
|
|
|
* API like SkCodecImageGenerator::getScaledDimensions() to report which
|
|
|
|
* dimensions are supported?
|
|
|
|
*/
|
|
|
|
SK_API std::unique_ptr<SkImageGenerator> MakeFromEncodedNDK(sk_sp<SkData>);
|
|
|
|
}
|
|
|
|
|
2020-08-05 20:51:10 +00:00
|
|
|
#endif // SK_ENABLE_NDK_IMAGES
|
|
|
|
#endif // SkImageGeneratorNDK_DEFINED
|