vk: create sampler set
This commit is contained in:
parent
12da07a1cf
commit
abd38b9076
6 changed files with 141 additions and 10 deletions
|
@ -1,4 +1,4 @@
|
|||
use crate::{ImageFormat, Size};
|
||||
use crate::{FilterMode, ImageFormat, Size, WrapMode};
|
||||
use ash::vk;
|
||||
|
||||
impl From<ImageFormat> for vk::Format {
|
||||
|
@ -87,3 +87,33 @@ impl From<Size<u32>> for vk::Extent3D {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<FilterMode> for vk::Filter {
|
||||
fn from(value: FilterMode) -> Self {
|
||||
match value {
|
||||
FilterMode::Linear => vk::Filter::LINEAR,
|
||||
FilterMode::Nearest => vk::Filter::NEAREST
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
impl From<FilterMode> for vk::SamplerMipmapMode {
|
||||
fn from(value: FilterMode) -> Self {
|
||||
match value {
|
||||
FilterMode::Linear => vk::SamplerMipmapMode::LINEAR,
|
||||
FilterMode::Nearest => vk::SamplerMipmapMode::NEAREST
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<WrapMode> for vk::SamplerAddressMode {
|
||||
fn from(value: WrapMode) -> Self {
|
||||
match value {
|
||||
WrapMode::ClampToBorder => vk::SamplerAddressMode::CLAMP_TO_BORDER,
|
||||
WrapMode::ClampToEdge => vk::SamplerAddressMode::CLAMP_TO_EDGE,
|
||||
WrapMode::Repeat => vk::SamplerAddressMode::REPEAT,
|
||||
WrapMode::MirroredRepeat => vk::SamplerAddressMode::MIRRORED_REPEAT
|
||||
}
|
||||
}
|
||||
}
|
|
@ -8,9 +8,9 @@ pub struct SamplerSet {
|
|||
}
|
||||
|
||||
impl SamplerSet {
|
||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mip: FilterMode) -> GLuint {
|
||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> GLuint {
|
||||
// eprintln!("{wrap}, {filter}, {mip}");
|
||||
*self.samplers.get(&(wrap, filter, mip)).unwrap()
|
||||
*self.samplers.get(&(wrap, filter, mipmap)).unwrap()
|
||||
}
|
||||
|
||||
fn make_sampler(sampler: GLuint, wrap: WrapMode, filter: FilterMode, mip: FilterMode) {
|
||||
|
|
|
@ -1,9 +1,17 @@
|
|||
#[rustfmt::skip]
|
||||
static VBO_OFFSCREEN_MVP: &[f32; 16] = &[
|
||||
// Offscreen
|
||||
-1.0, -1.0, 0.0, 0.0, -1.0, 1.0, 0.0, 1.0, 1.0, -1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0,
|
||||
-1.0, -1.0, 0.0, 0.0,
|
||||
-1.0, 1.0, 0.0, 1.0,
|
||||
1.0, -1.0, 1.0, 0.0,
|
||||
1.0, 1.0, 1.0, 1.0,
|
||||
];
|
||||
|
||||
#[rustfmt::skip]
|
||||
static VBO_DEFAULT_FINAL_MVP: &[f32; 16] = &[
|
||||
// Final
|
||||
0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.0,
|
||||
0.0, 0.0, 0.0, 0.0,
|
||||
0.0, 1.0, 0.0, 1.0,
|
||||
1.0, 0.0, 1.0, 0.0,
|
||||
1.0, 1.0, 1.0, 1.0,
|
||||
];
|
||||
|
|
|
@ -19,6 +19,7 @@ use librashader_runtime::uniforms::UniformStorage;
|
|||
use rustc_hash::FxHashMap;
|
||||
use std::error::Error;
|
||||
use std::path::Path;
|
||||
use crate::samplers::SamplerSet;
|
||||
|
||||
pub struct Vulkan {
|
||||
// physical_device: vk::PhysicalDevice,
|
||||
|
@ -126,13 +127,12 @@ pub struct FilterChainVulkan {
|
|||
}
|
||||
|
||||
pub(crate) struct FilterCommon {
|
||||
// pub(crate) luts: FxHashMap<usize, LutTexture>,
|
||||
// pub samplers: SamplerSet,
|
||||
pub(crate) luts: FxHashMap<usize, LutTexture>,
|
||||
pub samplers: SamplerSet,
|
||||
// pub output_textures: Box<[Option<Texture>]>,
|
||||
// pub feedback_textures: Box<[Option<Texture>]>,
|
||||
// pub history_textures: Box<[Option<Texture>]>,
|
||||
// pub config: FilterMutable,
|
||||
luts: FxHashMap<usize, LutTexture>,
|
||||
}
|
||||
|
||||
pub type FilterChainOptionsVulkan = ();
|
||||
|
@ -161,10 +161,10 @@ impl FilterChainVulkan {
|
|||
let filters = Self::init_passes(&device, passes, &semantics, 3)?;
|
||||
|
||||
let luts = FilterChainVulkan::load_luts(&device, &preset.textures)?;
|
||||
|
||||
let samplers = SamplerSet::new(&device.device)?;
|
||||
eprintln!("filters initialized ok.");
|
||||
Ok(FilterChainVulkan {
|
||||
common: FilterCommon { luts },
|
||||
common: FilterCommon { luts, samplers },
|
||||
passes: filters,
|
||||
})
|
||||
}
|
||||
|
|
|
@ -12,6 +12,7 @@ mod renderpass;
|
|||
mod util;
|
||||
mod vulkan_primitives;
|
||||
mod vulkan_state;
|
||||
mod samplers;
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
|
|
|
@ -0,0 +1,92 @@
|
|||
use ash::vk;
|
||||
use rustc_hash::FxHashMap;
|
||||
use librashader_common::{FilterMode, WrapMode};
|
||||
use crate::error;
|
||||
|
||||
pub struct VulkanSampler {
|
||||
pub handle: vk::Sampler,
|
||||
device: ash::Device
|
||||
}
|
||||
|
||||
impl VulkanSampler {
|
||||
pub fn new(device: &ash::Device, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> error::Result<VulkanSampler> {
|
||||
let create_info = vk::SamplerCreateInfo::builder()
|
||||
.mip_lod_bias(0.0)
|
||||
.max_anisotropy(1.0)
|
||||
.compare_enable(false)
|
||||
.min_lod(0.0)
|
||||
.max_lod(vk::LOD_CLAMP_NONE)
|
||||
.unnormalized_coordinates(false)
|
||||
.border_color(vk::BorderColor::FLOAT_TRANSPARENT_BLACK)
|
||||
.mag_filter(filter.into())
|
||||
.min_filter(filter.into())
|
||||
.mipmap_mode(mipmap.into())
|
||||
.address_mode_u(wrap.into())
|
||||
.address_mode_v(wrap.into())
|
||||
.address_mode_w(wrap.into())
|
||||
.build();
|
||||
|
||||
let sampler = unsafe {
|
||||
device.create_sampler(&create_info, None)?
|
||||
};
|
||||
|
||||
Ok(VulkanSampler {
|
||||
handle: sampler,
|
||||
device: device.clone()
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
impl Drop for VulkanSampler {
|
||||
fn drop(&mut self) {
|
||||
if self.handle != vk::Sampler::null() {
|
||||
unsafe {
|
||||
self.device.destroy_sampler(self.handle, None);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
pub struct SamplerSet {
|
||||
// todo: may need to deal with differences in mip filter.
|
||||
samplers: FxHashMap<(WrapMode, FilterMode, FilterMode), VulkanSampler>,
|
||||
}
|
||||
|
||||
impl SamplerSet {
|
||||
pub fn get(&self, wrap: WrapMode, filter: FilterMode, mipmap: FilterMode) -> &VulkanSampler {
|
||||
// eprintln!("{wrap}, {filter}, {mip}");
|
||||
self.samplers.get(&(wrap, filter, mipmap)).unwrap()
|
||||
}
|
||||
|
||||
pub fn new(device: &ash::Device) -> error::Result<SamplerSet> {
|
||||
let mut samplers = FxHashMap::default();
|
||||
let wrap_modes = &[
|
||||
WrapMode::ClampToBorder,
|
||||
WrapMode::ClampToEdge,
|
||||
WrapMode::Repeat,
|
||||
WrapMode::MirroredRepeat,
|
||||
];
|
||||
for wrap_mode in wrap_modes {
|
||||
samplers.insert(
|
||||
(*wrap_mode, FilterMode::Linear, FilterMode::Linear),
|
||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Linear, FilterMode::Linear)?,
|
||||
);
|
||||
samplers.insert(
|
||||
(*wrap_mode, FilterMode::Linear, FilterMode::Nearest),
|
||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Linear, FilterMode::Nearest)?,
|
||||
);
|
||||
|
||||
samplers.insert(
|
||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Nearest),
|
||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Nearest, FilterMode::Nearest)?
|
||||
);
|
||||
samplers.insert(
|
||||
(*wrap_mode, FilterMode::Nearest, FilterMode::Linear),
|
||||
VulkanSampler::new(device, *wrap_mode, FilterMode::Nearest, FilterMode::Linear)?
|
||||
);
|
||||
}
|
||||
|
||||
Ok(SamplerSet { samplers })
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue