test(d3d11): allow hello_triangle to take image as input
This commit is contained in:
parent
2d6a967c7f
commit
3c13dc8277
5 changed files with 46 additions and 62 deletions
|
@ -16,7 +16,8 @@ impl From<FilterMode> for Direct3D11::D3D11_FILTER {
|
|||
fn from(value: FilterMode) -> Self {
|
||||
match value {
|
||||
FilterMode::Linear => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_LINEAR,
|
||||
_ => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_POINT,
|
||||
FilterMode::Nearest => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_POINT,
|
||||
_ => Direct3D11::D3D11_FILTER_MIN_MAG_MIP_LINEAR,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -243,11 +243,12 @@ pub mod d3d11_hello_triangle {
|
|||
use crate::filter_chain::FilterChainD3D11;
|
||||
|
||||
use crate::options::{FilterChainOptionsD3D11, FrameOptionsD3D11};
|
||||
use crate::texture::D3D11InputView;
|
||||
use crate::texture::{D3D11InputView, LutTexture};
|
||||
use crate::D3D11OutputView;
|
||||
use librashader_common::{Size, Viewport};
|
||||
use librashader_common::{FilterMode, ImageFormat, Size, Viewport, WrapMode};
|
||||
use std::slice;
|
||||
use std::time::Instant;
|
||||
use librashader_runtime::image::Image;
|
||||
|
||||
pub struct Sample {
|
||||
pub dxgi_factory: IDXGIFactory4,
|
||||
|
@ -255,6 +256,7 @@ pub mod d3d11_hello_triangle {
|
|||
pub context: ID3D11DeviceContext,
|
||||
pub resources: Option<Resources>,
|
||||
pub filter: FilterChainD3D11,
|
||||
pub lut: Option<ID3D11Texture2D>
|
||||
}
|
||||
|
||||
pub struct Resources {
|
||||
|
@ -284,15 +286,37 @@ pub mod d3d11_hello_triangle {
|
|||
pub(crate) fn new(
|
||||
filter: impl AsRef<Path>,
|
||||
filter_options: Option<&FilterChainOptionsD3D11>,
|
||||
image: Option<Image>,
|
||||
) -> Result<Self> {
|
||||
let (dxgi_factory, device, context) = create_device()?;
|
||||
let filter = FilterChainD3D11::load_from_path(&device, filter, filter_options).unwrap();
|
||||
let lut = if let Some(image) = image {
|
||||
let lut = LutTexture::new(&device, &context, &image, D3D11_TEXTURE2D_DESC {
|
||||
Width: image.size.width,
|
||||
Height: image.size.height,
|
||||
MipLevels: 1,
|
||||
ArraySize: 0,
|
||||
Format: ImageFormat::R8G8B8A8Unorm.into(),
|
||||
SampleDesc: DXGI_SAMPLE_DESC {
|
||||
Count: 1,
|
||||
Quality: 0,
|
||||
},
|
||||
Usage: D3D11_USAGE_DYNAMIC,
|
||||
BindFlags: D3D11_BIND_SHADER_RESOURCE,
|
||||
CPUAccessFlags: Default::default(),
|
||||
MiscFlags: Default::default(),
|
||||
}, FilterMode::Linear, WrapMode::ClampToEdge).unwrap();
|
||||
Some(lut.handle)
|
||||
} else {
|
||||
None
|
||||
};
|
||||
Ok(Sample {
|
||||
filter,
|
||||
dxgi_factory,
|
||||
device,
|
||||
context,
|
||||
resources: None,
|
||||
lut,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -488,32 +512,24 @@ pub mod d3d11_hello_triangle {
|
|||
|
||||
unsafe {
|
||||
self.context.DrawIndexed(3, 0, 0);
|
||||
self.context.OMSetRenderTargets(None, None);
|
||||
}
|
||||
|
||||
unsafe {
|
||||
let input = if let Some(lut) = &self.lut {
|
||||
lut.clone()
|
||||
} else {
|
||||
resources.renderbuffer.clone()
|
||||
};
|
||||
|
||||
let mut tex2d_desc = Default::default();
|
||||
resources.renderbuffer.GetDesc(&mut tex2d_desc);
|
||||
input.GetDesc(&mut tex2d_desc);
|
||||
let mut backbuffer_desc = Default::default();
|
||||
resources.backbuffer.as_ref().unwrap().GetDesc(&mut backbuffer_desc);
|
||||
|
||||
let mut renderbuffer_copy = None;
|
||||
|
||||
self.device.CreateTexture2D(
|
||||
&D3D11_TEXTURE2D_DESC {
|
||||
BindFlags: D3D11_BIND_SHADER_RESOURCE | D3D11_BIND_RENDER_TARGET,
|
||||
CPUAccessFlags: D3D11_CPU_ACCESS_READ | D3D11_CPU_ACCESS_WRITE,
|
||||
..tex2d_desc
|
||||
},
|
||||
None,
|
||||
Some(&mut renderbuffer_copy),
|
||||
)?;
|
||||
let backup = renderbuffer_copy.unwrap();
|
||||
|
||||
self.context.CopyResource(&backup, &resources.renderbuffer);
|
||||
|
||||
let mut copy_srv = None;
|
||||
let mut input_srv = None;
|
||||
self.device.CreateShaderResourceView(
|
||||
&backup,
|
||||
&input,
|
||||
Some(&D3D11_SHADER_RESOURCE_VIEW_DESC {
|
||||
Format: tex2d_desc.Format,
|
||||
ViewDimension: D3D_SRV_DIMENSION_TEXTURE2D,
|
||||
|
@ -524,27 +540,9 @@ pub mod d3d11_hello_triangle {
|
|||
},
|
||||
},
|
||||
}),
|
||||
Some(&mut copy_srv),
|
||||
)?;
|
||||
let srv = copy_srv.unwrap();
|
||||
|
||||
let mut shader_out = None;
|
||||
self.device
|
||||
.CreateTexture2D(&tex2d_desc, None, Some(&mut shader_out))?;
|
||||
let shader_out = shader_out.unwrap();
|
||||
|
||||
let mut rtv = None;
|
||||
self.device.CreateRenderTargetView(
|
||||
&shader_out,
|
||||
Some(&D3D11_RENDER_TARGET_VIEW_DESC {
|
||||
Format: tex2d_desc.Format,
|
||||
ViewDimension: D3D11_RTV_DIMENSION_TEXTURE2D,
|
||||
Anonymous: D3D11_RENDER_TARGET_VIEW_DESC_0 {
|
||||
Texture2D: D3D11_TEX2D_RTV { MipSlice: 0 },
|
||||
},
|
||||
}),
|
||||
Some(&mut rtv),
|
||||
Some(&mut input_srv),
|
||||
)?;
|
||||
let srv = input_srv.unwrap();
|
||||
|
||||
// eprintln!("w: {} h: {}", backbuffer_desc.Width, backbuffer_desc.Height);
|
||||
self.filter
|
||||
|
@ -557,8 +555,8 @@ pub mod d3d11_hello_triangle {
|
|||
},
|
||||
},
|
||||
&Viewport {
|
||||
x: resources.viewport.TopLeftX,
|
||||
y: resources.viewport.TopLeftY,
|
||||
x: 0f32,
|
||||
y: 0f32,
|
||||
output: D3D11OutputView {
|
||||
size: Size {
|
||||
width: backbuffer_desc.Width,
|
||||
|
|
|
@ -27,6 +27,7 @@ pub use texture::D3D11OutputView;
|
|||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use librashader_runtime::image::{Image, UVDirection};
|
||||
use super::*;
|
||||
use crate::options::FilterChainOptionsD3D11;
|
||||
|
||||
|
@ -41,6 +42,7 @@ mod tests {
|
|||
use_deferred_context: false,
|
||||
force_no_mipmaps: false,
|
||||
}),
|
||||
Some(Image::load("../test/sf2.png", UVDirection::TopLeft).unwrap())
|
||||
)
|
||||
.unwrap();
|
||||
// let sample = hello_triangle_old::d3d11_hello_triangle::Sample::new(
|
||||
|
|
|
@ -10,6 +10,7 @@ use windows::Win32::Graphics::Direct3D11::{
|
|||
D3D11_TEXTURE2D_DESC, D3D11_USAGE_DYNAMIC, D3D11_USAGE_STAGING,
|
||||
};
|
||||
use windows::Win32::Graphics::Dxgi::Common::DXGI_SAMPLE_DESC;
|
||||
use librashader_runtime::scaling::MipmapSize;
|
||||
|
||||
use crate::error::{assume_d3d11_init, Result};
|
||||
use crate::framebuffer::OwnedFramebuffer;
|
||||
|
@ -116,15 +117,8 @@ impl LutTexture {
|
|||
|
||||
// determine number of mipmaps required
|
||||
if (desc.MiscFlags & D3D11_RESOURCE_MISC_GENERATE_MIPS).0 != 0 {
|
||||
let mut width = desc.Width >> 5;
|
||||
let mut height = desc.Height >> 5;
|
||||
desc.BindFlags |= D3D11_BIND_RENDER_TARGET;
|
||||
|
||||
while width != 0 && height != 0 {
|
||||
width >>= 1;
|
||||
height >>= 1;
|
||||
desc.MipLevels += 1;
|
||||
}
|
||||
desc.MipLevels = source.size.calculate_miplevels();
|
||||
}
|
||||
|
||||
// Don't need to determine format support because LUTs are always DXGI_FORMAT_R8G8B8A8_UNORM
|
||||
|
|
|
@ -93,14 +93,3 @@ where
|
|||
height: height.round().as_(),
|
||||
}
|
||||
}
|
||||
|
||||
pub fn calculate_miplevels(size: Size<u32>) -> u32 {
|
||||
let mut size = std::cmp::max(size.width, size.height);
|
||||
let mut levels = 0;
|
||||
while size != 0 {
|
||||
levels += 1;
|
||||
size >>= 1;
|
||||
}
|
||||
|
||||
levels
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue