diff options
Diffstat (limited to 'libs/hwui/renderthread/RenderThread.cpp')
-rw-r--r-- | libs/hwui/renderthread/RenderThread.cpp | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/libs/hwui/renderthread/RenderThread.cpp b/libs/hwui/renderthread/RenderThread.cpp index 1450ec98dabf..055458397023 100644 --- a/libs/hwui/renderthread/RenderThread.cpp +++ b/libs/hwui/renderthread/RenderThread.cpp @@ -16,8 +16,12 @@ #include "RenderThread.h" -#include "../renderstate/RenderState.h" -#include "../pipeline/skia/SkiaOpenGLReadback.h" +#include "hwui/Bitmap.h" +#include "renderstate/RenderState.h" +#include "renderthread/OpenGLPipeline.h" +#include "pipeline/skia/SkiaOpenGLReadback.h" +#include "pipeline/skia/SkiaOpenGLPipeline.h" +#include "pipeline/skia/SkiaVulkanPipeline.h" #include "CanvasContext.h" #include "EglManager.h" #include "OpenGLReadback.h" @@ -433,6 +437,22 @@ RenderTask* RenderThread::nextTask(nsecs_t* nextWakeup) { return next; } +sk_sp<Bitmap> RenderThread::allocateHardwareBitmap(SkBitmap& skBitmap) { + auto renderType = Properties::getRenderPipelineType(); + switch (renderType) { + case RenderPipelineType::OpenGL: + return OpenGLPipeline::allocateHardwareBitmap(*this, skBitmap); + case RenderPipelineType::SkiaGL: + return skiapipeline::SkiaOpenGLPipeline::allocateHardwareBitmap(*this, skBitmap); + case RenderPipelineType::SkiaVulkan: + return skiapipeline::SkiaVulkanPipeline::allocateHardwareBitmap(*this, skBitmap); + default: + LOG_ALWAYS_FATAL("canvas context type %d not supported", (int32_t) renderType); + break; + } + return nullptr; +} + } /* namespace renderthread */ } /* namespace uirenderer */ } /* namespace android */ |