/* * Copyright 2017 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef GrAHardwareBufferImageGenerator_DEFINED #define GrAHardwareBufferImageGenerator_DEFINED #include "SkImageGenerator.h" extern "C" { typedef struct AHardwareBuffer AHardwareBuffer; } /** * GrAHardwareBufferImageGenerator allows to create an SkImage attached to * an existing android native hardware buffer. A hardware buffer has to be * created with AHARDWAREBUFFER_USAGE_GPU_SAMPLED_IMAGE usage, because it is * bound to an external texture using an EGLImage. The image generator will * keep a reference to the hardware buffer for its lifetime. A hardware buffer * can be shared between processes and same buffer can be used in multiple GPU * contexts. * To implement certain features like tiling, Skia may copy the texture to * avoid OpenGL API limitations. */ class GrAHardwareBufferImageGenerator : public SkImageGenerator { public: static std::unique_ptr<SkImageGenerator> Make(AHardwareBuffer*, SkAlphaType, sk_sp<SkColorSpace>); ~GrAHardwareBufferImageGenerator() override; protected: bool onIsValid(GrContext*) const override; #if SK_SUPPORT_GPU TexGenType onCanGenerateTexture() const override { return TexGenType::kCheap; } sk_sp<GrTextureProxy> onGenerateTexture(GrContext*, const SkImageInfo&, const SkIPoint&, SkTransferFunctionBehavior, bool willNeedMipMaps) override; #endif private: GrAHardwareBufferImageGenerator(const SkImageInfo&, AHardwareBuffer*, SkAlphaType); sk_sp<GrTextureProxy> makeProxy(GrContext* context); void clear(); static void deleteImageTexture(void* ctx); AHardwareBuffer* fGraphicBuffer; GrTexture* fOriginalTexture = nullptr; uint32_t fOwningContextID; typedef SkImageGenerator INHERITED; }; #endif // GrAHardwareBufferImageGenerator_DEFINED