Flutter Engine Uber Docs
Docs for the entire Flutter Engine repo.
 
Loading...
Searching...
No Matches
ahb_texture_source_vk.h
Go to the documentation of this file.
1// Copyright 2013 The Flutter Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef FLUTTER_IMPELLER_RENDERER_BACKEND_VULKAN_ANDROID_AHB_TEXTURE_SOURCE_VK_H_
6#define FLUTTER_IMPELLER_RENDERER_BACKEND_VULKAN_ANDROID_AHB_TEXTURE_SOURCE_VK_H_
7
12
14#include <android/hardware_buffer_jni.h>
15
16namespace impeller {
17
18class ContextVK;
19
20//------------------------------------------------------------------------------
21/// @brief A texture source that wraps an instance of AHardwareBuffer.
22///
23/// The formats and conversions supported by Android Hardware
24/// Buffers are a superset of those supported by Impeller (and
25/// Vulkan for that matter). Impeller and Vulkan descriptors
26/// obtained from the these texture sources are advisory and it
27/// usually isn't possible to create copies of images and image
28/// views held in these texture sources using the inferred
29/// descriptors. The objects are meant to be used directly (either
30/// as render targets or sources for sampling), not copied.
31///
32class AHBTextureSourceVK final : public TextureSourceVK {
33 public:
34 AHBTextureSourceVK(const std::shared_ptr<Context>& context,
35 struct AHardwareBuffer* hardware_buffer,
36 const AHardwareBuffer_Desc& hardware_buffer_desc);
37
38 AHBTextureSourceVK(const std::shared_ptr<Context>& context,
39 std::unique_ptr<android::HardwareBuffer> backing_store,
40 bool is_swapchain_image);
41
42 // |TextureSourceVK|
44
45 // |TextureSourceVK|
46 vk::Image GetImage() const override;
47
48 // |TextureSourceVK|
49 vk::ImageView GetImageView() const override;
50
51 // |TextureSourceVK|
52 vk::ImageView GetRenderTargetView() const override;
53
54 bool IsValid() const;
55
56 // |TextureSourceVK|
57 bool IsSwapchainImage() const override;
58
59 // |TextureSourceVK|
60 std::shared_ptr<YUVConversionVK> GetYUVConversion() const override;
61
63
64 using AHBProperties = vk::StructureChain<
65 // For VK_ANDROID_external_memory_android_hardware_buffer
66 vk::AndroidHardwareBufferPropertiesANDROID,
67 // For VK_ANDROID_external_memory_android_hardware_buffer
68 vk::AndroidHardwareBufferFormatPropertiesANDROID>;
69
70 using ImageViewInfo = vk::StructureChain<vk::ImageViewCreateInfo,
71 // Core in 1.1
72 vk::SamplerYcbcrConversionInfo>;
73
74 /// Create a VkImage that wraps an Android hardware buffer.
76 const vk::Device& device,
77 const AHBProperties& ahb_props,
78 const AHardwareBuffer_Desc& ahb_desc);
79
80 /// Create a VkImageViewCreateInfo that matches the properties of an Android
81 /// hardware buffer.
83 const vk::Image& image,
84 const std::shared_ptr<YUVConversionVK>& yuv_conversion_wrapper,
85 const AHBProperties& ahb_props,
86 const AHardwareBuffer_Desc& ahb_desc);
87
88 private:
89 std::unique_ptr<android::HardwareBuffer> backing_store_;
90 vk::UniqueDeviceMemory device_memory_ = {};
91 vk::UniqueImage image_ = {};
92 vk::UniqueImageView image_view_ = {};
93 std::shared_ptr<YUVConversionVK> yuv_conversion_ = {};
94 bool needs_yuv_conversion_ = false;
95 bool is_swapchain_image_ = false;
96 bool is_valid_ = false;
97
98 AHBTextureSourceVK(const AHBTextureSourceVK&) = delete;
99
100 AHBTextureSourceVK& operator=(const AHBTextureSourceVK&) = delete;
101};
102
103} // namespace impeller
104
105#endif // FLUTTER_IMPELLER_RENDERER_BACKEND_VULKAN_ANDROID_AHB_TEXTURE_SOURCE_VK_H_
A texture source that wraps an instance of AHardwareBuffer.
vk::StructureChain< vk::ImageViewCreateInfo, vk::SamplerYcbcrConversionInfo > ImageViewInfo
bool IsSwapchainImage() const override
Determines if swapchain image. That is, an image used as the root render target.
vk::Image GetImage() const override
Get the image handle for this texture source.
static vk::UniqueImage CreateVKImageWrapperForAndroidHarwareBuffer(const vk::Device &device, const AHBProperties &ahb_props, const AHardwareBuffer_Desc &ahb_desc)
Create a VkImage that wraps an Android hardware buffer.
const android::HardwareBuffer * GetBackingStore() const
std::shared_ptr< YUVConversionVK > GetYUVConversion() const override
When sampling from textures whose formats are not known to Vulkan, a custom conversion is necessary t...
vk::StructureChain< vk::AndroidHardwareBufferPropertiesANDROID, vk::AndroidHardwareBufferFormatPropertiesANDROID > AHBProperties
AHBTextureSourceVK(const std::shared_ptr< Context > &context, struct AHardwareBuffer *hardware_buffer, const AHardwareBuffer_Desc &hardware_buffer_desc)
vk::ImageView GetImageView() const override
Retrieve the image view used for sampling/blitting/compute with this texture source.
vk::ImageView GetRenderTargetView() const override
Retrieve the image view used for render target attachments with this texture source.
static ImageViewInfo CreateImageViewInfo(const vk::Image &image, const std::shared_ptr< YUVConversionVK > &yuv_conversion_wrapper, const AHBProperties &ahb_props, const AHardwareBuffer_Desc &ahb_desc)
Abstract base class that represents a vkImage and an vkImageView.
A wrapper for AHardwareBuffer https://developer.android.com/ndk/reference/group/a-hardware-buffer.
FlutterVulkanImage * image
VkDevice device
Definition main.cc:69