blob: 4a5004b02e47c78ede8639ea95b21148704e570e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
/*
* 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"
#include <android/hardware_buffer.h>
/**
* 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
bool onCanGenerateTexture() const override { return true; }
sk_sp<GrTextureProxy> onGenerateTexture(GrContext*, const SkImageInfo&,
const SkIPoint&) override;
#endif
private:
GrAHardwareBufferImageGenerator(const SkImageInfo&, AHardwareBuffer*, SkAlphaType);
static void deleteImageTexture(void* ctx);
AHardwareBuffer* fGraphicBuffer;
SkAlphaType fAlphaType;
typedef SkImageGenerator INHERITED;
};
#endif // GrAHardwareBufferImageGenerator_DEFINED
|