diff options
author | TreeHugger Robot <treehugger-gerrit@google.com> | 2017-06-02 22:06:32 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2017-06-02 22:06:37 +0000 |
commit | aeb22da1bd57b0ae280d9492fab75f56a95cbe85 (patch) | |
tree | 696d02730c4247205f28f16529fff78a82f83482 /libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp | |
parent | 412652b001e86cc85b77409f4234809cf053c9f8 (diff) | |
parent | 7bc3bc6028d0c7b16fec72c3922fc627c8657951 (diff) |
Merge "Implement HW Bitmap for Skia pipeline"
Diffstat (limited to 'libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp')
-rw-r--r-- | libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp b/libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp index e8e8ccd96654..f1ef9e60f997 100644 --- a/libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp +++ b/libs/hwui/pipeline/skia/SkiaVulkanPipeline.cpp @@ -160,6 +160,25 @@ void SkiaVulkanPipeline::invokeFunctor(const RenderThread& thread, Functor* func (*functor)(mode, nullptr); } +sk_sp<Bitmap> SkiaVulkanPipeline::allocateHardwareBitmap(renderthread::RenderThread& renderThread, + SkBitmap& skBitmap) { + //TODO: implement this function for Vulkan pipeline + //code below is a hack to avoid crashing because of missing HW Bitmap support + sp<GraphicBuffer> buffer = new GraphicBuffer(skBitmap.info().width(), skBitmap.info().height(), + PIXEL_FORMAT_RGBA_8888, + GraphicBuffer::USAGE_HW_TEXTURE | + GraphicBuffer::USAGE_SW_WRITE_NEVER | + GraphicBuffer::USAGE_SW_READ_NEVER, + std::string("SkiaVulkanPipeline::allocateHardwareBitmap pid [") + + std::to_string(getpid()) + "]"); + status_t error = buffer->initCheck(); + if (error < 0) { + ALOGW("SkiaVulkanPipeline::allocateHardwareBitmap() failed in GraphicBuffer.create()"); + return nullptr; + } + return sk_sp<Bitmap>(new Bitmap(buffer.get(), skBitmap.info())); +} + } /* namespace skiapipeline */ } /* namespace uirenderer */ } /* namespace android */ |