23 {
24
25 void* pNext = nullptr;
27 if (ycbcrConversion) {
29 conversionInfo.
pNext =
nullptr;
30 conversionInfo.
conversion = ycbcrConversion->ycbcrConversion();
31 pNext = &conversionInfo;
32 }
33
35
41 break;
45 break;
46 default:
48 break;
49 }
50
51 miplevels = 1;
52 } else {
54 }
57 pNext,
58 0,
66 { aspectFlags, 0, miplevels, 0, 1 },
67 };
68
72 CreateImageView(sharedCtx->device(), &viewInfo,
nullptr, &
imageView));
74 return nullptr;
75 }
76
77 return std::unique_ptr<VulkanImageView>(
new VulkanImageView(sharedCtx,
imageView,
usage,
78 ycbcrConversion));
79}
#define VULKAN_CALL_RESULT(SHARED_CONTEXT, RESULT, X)
VkImageView imageView() const
uint32_t uint32_t * format
VkSamplerYcbcrConversion conversion
VkFlags VkImageAspectFlags
@ VK_IMAGE_ASPECT_COLOR_BIT
@ VK_IMAGE_ASPECT_STENCIL_BIT
@ VK_IMAGE_ASPECT_DEPTH_BIT
@ VK_COMPONENT_SWIZZLE_IDENTITY
@ VK_FORMAT_D24_UNORM_S8_UINT
@ VK_FORMAT_D32_SFLOAT_S8_UINT
@ VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO
@ VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO