17 const std::shared_ptr<YUVConversionVK>& yuv_conversion) {
25 vk::StructureChain<vk::SamplerCreateInfo,
27 vk::SamplerYcbcrConversionInfo>
30 auto& sampler_info = sampler_chain.get();
32 sampler_info.magFilter = mag_filter;
33 sampler_info.minFilter = min_filter;
34 sampler_info.addressModeU = address_mode_u;
35 sampler_info.addressModeV = address_mode_v;
36 sampler_info.addressModeW = address_mode_w;
37 sampler_info.borderColor = vk::BorderColor::eFloatTransparentBlack;
38 sampler_info.maxLod = VK_LOD_CLAMP_NONE;
43 sampler_info.mipmapMode = vk::SamplerMipmapMode::eNearest;
44 sampler_info.minLod = sampler_info.maxLod = 0.0f;
47 sampler_info.mipmapMode = vk::SamplerMipmapMode::eNearest;
50 sampler_info.mipmapMode = vk::SamplerMipmapMode::eLinear;
54 if (yuv_conversion && yuv_conversion->IsValid()) {
55 sampler_chain.get<vk::SamplerYcbcrConversionInfo>().conversion =
56 yuv_conversion->GetConversion();
68 sampler_info.minFilter = sampler_info.magFilter =
69 yuv_conversion->GetDescriptor().get().chromaFilter;
78 sampler_info.addressModeU = vk::SamplerAddressMode::eClampToEdge;
79 sampler_info.addressModeV = vk::SamplerAddressMode::eClampToEdge;
80 sampler_info.addressModeW = vk::SamplerAddressMode::eClampToEdge;
81 sampler_info.anisotropyEnable =
false;
82 sampler_info.unnormalizedCoordinates =
false;
84 sampler_chain.unlink<vk::SamplerYcbcrConversionInfo>();
87 auto sampler =
device.createSamplerUnique(sampler_chain.get());
88 if (sampler.result != vk::Result::eSuccess) {
90 << vk::to_string(sampler.result);
94 if (!desc.
label.empty()) {
98 return std::move(sampler.value);
bool SetDebugName(T handle, std::string_view label) const
std::optional< PipelineDescriptor > desc_