d3d11: initialize output buffers
This commit is contained in:
parent
816402758a
commit
60fd644a2a
15 changed files with 345 additions and 163 deletions
|
@ -1,41 +1,41 @@
|
||||||
use crate::{FilterMode, ShaderFormat, WrapMode};
|
use crate::{FilterMode, ImageFormat, WrapMode};
|
||||||
use windows::Win32::Graphics::Direct3D11;
|
use windows::Win32::Graphics::Direct3D11;
|
||||||
use windows::Win32::Graphics::Dxgi::Common as dxgi;
|
use windows::Win32::Graphics::Dxgi::Common as dxgi;
|
||||||
|
|
||||||
impl From<ShaderFormat> for dxgi::DXGI_FORMAT {
|
impl From<ImageFormat> for dxgi::DXGI_FORMAT {
|
||||||
fn from(format: ShaderFormat) -> Self {
|
fn from(format: ImageFormat) -> Self {
|
||||||
match format {
|
match format {
|
||||||
ShaderFormat::Unknown => dxgi::DXGI_FORMAT_UNKNOWN,
|
ImageFormat::Unknown => dxgi::DXGI_FORMAT_UNKNOWN,
|
||||||
ShaderFormat::R8Unorm => dxgi::DXGI_FORMAT_R8_UNORM,
|
ImageFormat::R8Unorm => dxgi::DXGI_FORMAT_R8_UNORM,
|
||||||
ShaderFormat::R8Uint => dxgi::DXGI_FORMAT_R8_UINT,
|
ImageFormat::R8Uint => dxgi::DXGI_FORMAT_R8_UINT,
|
||||||
ShaderFormat::R8Sint => dxgi::DXGI_FORMAT_R8_SINT,
|
ImageFormat::R8Sint => dxgi::DXGI_FORMAT_R8_SINT,
|
||||||
ShaderFormat::R8G8Unorm => dxgi::DXGI_FORMAT_R8G8_UNORM,
|
ImageFormat::R8G8Unorm => dxgi::DXGI_FORMAT_R8G8_UNORM,
|
||||||
ShaderFormat::R8G8Uint => dxgi::DXGI_FORMAT_R8G8_UINT,
|
ImageFormat::R8G8Uint => dxgi::DXGI_FORMAT_R8G8_UINT,
|
||||||
ShaderFormat::R8G8Sint => dxgi::DXGI_FORMAT_R8G8_SINT,
|
ImageFormat::R8G8Sint => dxgi::DXGI_FORMAT_R8G8_SINT,
|
||||||
ShaderFormat::R8G8B8A8Unorm => dxgi::DXGI_FORMAT_R8G8B8A8_UNORM,
|
ImageFormat::R8G8B8A8Unorm => dxgi::DXGI_FORMAT_R8G8B8A8_UNORM,
|
||||||
ShaderFormat::R8G8B8A8Uint => dxgi::DXGI_FORMAT_R8G8B8A8_UINT,
|
ImageFormat::R8G8B8A8Uint => dxgi::DXGI_FORMAT_R8G8B8A8_UINT,
|
||||||
ShaderFormat::R8G8B8A8Sint => dxgi::DXGI_FORMAT_R8G8B8A8_SINT,
|
ImageFormat::R8G8B8A8Sint => dxgi::DXGI_FORMAT_R8G8B8A8_SINT,
|
||||||
ShaderFormat::R8G8B8A8Srgb => dxgi::DXGI_FORMAT_R8G8B8A8_UNORM_SRGB,
|
ImageFormat::R8G8B8A8Srgb => dxgi::DXGI_FORMAT_R8G8B8A8_UNORM_SRGB,
|
||||||
ShaderFormat::A2B10G10R10UnormPack32 => dxgi::DXGI_FORMAT_R10G10B10A2_UNORM,
|
ImageFormat::A2B10G10R10UnormPack32 => dxgi::DXGI_FORMAT_R10G10B10A2_UNORM,
|
||||||
ShaderFormat::A2B10G10R10UintPack32 => dxgi::DXGI_FORMAT_R10G10B10A2_UINT,
|
ImageFormat::A2B10G10R10UintPack32 => dxgi::DXGI_FORMAT_R10G10B10A2_UINT,
|
||||||
ShaderFormat::R16Uint => dxgi::DXGI_FORMAT_R16_UINT,
|
ImageFormat::R16Uint => dxgi::DXGI_FORMAT_R16_UINT,
|
||||||
ShaderFormat::R16Sint => dxgi::DXGI_FORMAT_R16_SINT,
|
ImageFormat::R16Sint => dxgi::DXGI_FORMAT_R16_SINT,
|
||||||
ShaderFormat::R16Sfloat => dxgi::DXGI_FORMAT_R16_FLOAT,
|
ImageFormat::R16Sfloat => dxgi::DXGI_FORMAT_R16_FLOAT,
|
||||||
ShaderFormat::R16G16Uint => dxgi::DXGI_FORMAT_R16G16_UINT,
|
ImageFormat::R16G16Uint => dxgi::DXGI_FORMAT_R16G16_UINT,
|
||||||
ShaderFormat::R16G16Sint => dxgi::DXGI_FORMAT_R16G16_SINT,
|
ImageFormat::R16G16Sint => dxgi::DXGI_FORMAT_R16G16_SINT,
|
||||||
ShaderFormat::R16G16Sfloat => dxgi::DXGI_FORMAT_R16G16_FLOAT,
|
ImageFormat::R16G16Sfloat => dxgi::DXGI_FORMAT_R16G16_FLOAT,
|
||||||
ShaderFormat::R16G16B16A16Uint => dxgi::DXGI_FORMAT_R16G16B16A16_UINT,
|
ImageFormat::R16G16B16A16Uint => dxgi::DXGI_FORMAT_R16G16B16A16_UINT,
|
||||||
ShaderFormat::R16G16B16A16Sint => dxgi::DXGI_FORMAT_R16G16B16A16_SINT,
|
ImageFormat::R16G16B16A16Sint => dxgi::DXGI_FORMAT_R16G16B16A16_SINT,
|
||||||
ShaderFormat::R16G16B16A16Sfloat => dxgi::DXGI_FORMAT_R16G16B16A16_FLOAT,
|
ImageFormat::R16G16B16A16Sfloat => dxgi::DXGI_FORMAT_R16G16B16A16_FLOAT,
|
||||||
ShaderFormat::R32Uint => dxgi::DXGI_FORMAT_R32_UINT,
|
ImageFormat::R32Uint => dxgi::DXGI_FORMAT_R32_UINT,
|
||||||
ShaderFormat::R32Sint =>dxgi::DXGI_FORMAT_R32_SINT,
|
ImageFormat::R32Sint =>dxgi::DXGI_FORMAT_R32_SINT,
|
||||||
ShaderFormat::R32Sfloat => dxgi::DXGI_FORMAT_R32_FLOAT,
|
ImageFormat::R32Sfloat => dxgi::DXGI_FORMAT_R32_FLOAT,
|
||||||
ShaderFormat::R32G32Uint => dxgi::DXGI_FORMAT_R32G32_UINT,
|
ImageFormat::R32G32Uint => dxgi::DXGI_FORMAT_R32G32_UINT,
|
||||||
ShaderFormat::R32G32Sint => dxgi::DXGI_FORMAT_R32G32_SINT,
|
ImageFormat::R32G32Sint => dxgi::DXGI_FORMAT_R32G32_SINT,
|
||||||
ShaderFormat::R32G32Sfloat => dxgi::DXGI_FORMAT_R32G32_FLOAT,
|
ImageFormat::R32G32Sfloat => dxgi::DXGI_FORMAT_R32G32_FLOAT,
|
||||||
ShaderFormat::R32G32B32A32Uint => dxgi::DXGI_FORMAT_R32G32B32A32_UINT,
|
ImageFormat::R32G32B32A32Uint => dxgi::DXGI_FORMAT_R32G32B32A32_UINT,
|
||||||
ShaderFormat::R32G32B32A32Sint => dxgi::DXGI_FORMAT_R32G32B32A32_SINT,
|
ImageFormat::R32G32B32A32Sint => dxgi::DXGI_FORMAT_R32G32B32A32_SINT,
|
||||||
ShaderFormat::R32G32B32A32Sfloat => dxgi::DXGI_FORMAT_R32G32B32A32_FLOAT,
|
ImageFormat::R32G32B32A32Sfloat => dxgi::DXGI_FORMAT_R32G32B32A32_FLOAT,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,39 +1,39 @@
|
||||||
use crate::{FilterMode, ShaderFormat, WrapMode};
|
use crate::{FilterMode, ImageFormat, WrapMode};
|
||||||
|
|
||||||
impl From<ShaderFormat> for gl::types::GLenum {
|
impl From<ImageFormat> for gl::types::GLenum {
|
||||||
fn from(format: ShaderFormat) -> Self {
|
fn from(format: ImageFormat) -> Self {
|
||||||
match format {
|
match format {
|
||||||
ShaderFormat::Unknown => 0 as gl::types::GLenum,
|
ImageFormat::Unknown => 0 as gl::types::GLenum,
|
||||||
ShaderFormat::R8Unorm => gl::R8,
|
ImageFormat::R8Unorm => gl::R8,
|
||||||
ShaderFormat::R8Uint => gl::R8UI,
|
ImageFormat::R8Uint => gl::R8UI,
|
||||||
ShaderFormat::R8Sint => gl::R8I,
|
ImageFormat::R8Sint => gl::R8I,
|
||||||
ShaderFormat::R8G8Unorm => gl::RG8,
|
ImageFormat::R8G8Unorm => gl::RG8,
|
||||||
ShaderFormat::R8G8Uint => gl::RG8UI,
|
ImageFormat::R8G8Uint => gl::RG8UI,
|
||||||
ShaderFormat::R8G8Sint => gl::RG8I,
|
ImageFormat::R8G8Sint => gl::RG8I,
|
||||||
ShaderFormat::R8G8B8A8Unorm => gl::RGBA8,
|
ImageFormat::R8G8B8A8Unorm => gl::RGBA8,
|
||||||
ShaderFormat::R8G8B8A8Uint => gl::RGBA8UI,
|
ImageFormat::R8G8B8A8Uint => gl::RGBA8UI,
|
||||||
ShaderFormat::R8G8B8A8Sint => gl::RGBA8I,
|
ImageFormat::R8G8B8A8Sint => gl::RGBA8I,
|
||||||
ShaderFormat::R8G8B8A8Srgb => gl::SRGB8_ALPHA8,
|
ImageFormat::R8G8B8A8Srgb => gl::SRGB8_ALPHA8,
|
||||||
ShaderFormat::A2B10G10R10UnormPack32 => gl::RGB10_A2,
|
ImageFormat::A2B10G10R10UnormPack32 => gl::RGB10_A2,
|
||||||
ShaderFormat::A2B10G10R10UintPack32 => gl::RGB10_A2UI,
|
ImageFormat::A2B10G10R10UintPack32 => gl::RGB10_A2UI,
|
||||||
ShaderFormat::R16Uint => gl::R16UI,
|
ImageFormat::R16Uint => gl::R16UI,
|
||||||
ShaderFormat::R16Sint => gl::R16I,
|
ImageFormat::R16Sint => gl::R16I,
|
||||||
ShaderFormat::R16Sfloat => gl::R16F,
|
ImageFormat::R16Sfloat => gl::R16F,
|
||||||
ShaderFormat::R16G16Uint => gl::RG16UI,
|
ImageFormat::R16G16Uint => gl::RG16UI,
|
||||||
ShaderFormat::R16G16Sint => gl::RG16I,
|
ImageFormat::R16G16Sint => gl::RG16I,
|
||||||
ShaderFormat::R16G16Sfloat => gl::RG16F,
|
ImageFormat::R16G16Sfloat => gl::RG16F,
|
||||||
ShaderFormat::R16G16B16A16Uint => gl::RGBA16UI,
|
ImageFormat::R16G16B16A16Uint => gl::RGBA16UI,
|
||||||
ShaderFormat::R16G16B16A16Sint => gl::RGBA16I,
|
ImageFormat::R16G16B16A16Sint => gl::RGBA16I,
|
||||||
ShaderFormat::R16G16B16A16Sfloat => gl::RGBA16F,
|
ImageFormat::R16G16B16A16Sfloat => gl::RGBA16F,
|
||||||
ShaderFormat::R32Uint => gl::R32UI,
|
ImageFormat::R32Uint => gl::R32UI,
|
||||||
ShaderFormat::R32Sint => gl::R32I,
|
ImageFormat::R32Sint => gl::R32I,
|
||||||
ShaderFormat::R32Sfloat => gl::R32F,
|
ImageFormat::R32Sfloat => gl::R32F,
|
||||||
ShaderFormat::R32G32Uint => gl::RG32UI,
|
ImageFormat::R32G32Uint => gl::RG32UI,
|
||||||
ShaderFormat::R32G32Sint => gl::RG32I,
|
ImageFormat::R32G32Sint => gl::RG32I,
|
||||||
ShaderFormat::R32G32Sfloat => gl::RG32F,
|
ImageFormat::R32G32Sfloat => gl::RG32F,
|
||||||
ShaderFormat::R32G32B32A32Uint => gl::RGBA32UI,
|
ImageFormat::R32G32B32A32Uint => gl::RGBA32UI,
|
||||||
ShaderFormat::R32G32B32A32Sint => gl::RGBA32I,
|
ImageFormat::R32G32B32A32Sint => gl::RGBA32I,
|
||||||
ShaderFormat::R32G32B32A32Sfloat => gl::RGBA32F,
|
ImageFormat::R32G32B32A32Sfloat => gl::RGBA32F,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@ use num_traits::AsPrimitive;
|
||||||
|
|
||||||
#[repr(u32)]
|
#[repr(u32)]
|
||||||
#[derive(Default, Copy, Clone, Debug, Eq, PartialEq, Hash)]
|
#[derive(Default, Copy, Clone, Debug, Eq, PartialEq, Hash)]
|
||||||
pub enum ShaderFormat {
|
pub enum ImageFormat {
|
||||||
#[default]
|
#[default]
|
||||||
Unknown = 0,
|
Unknown = 0,
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ pub enum WrapMode {
|
||||||
MirroredRepeat,
|
MirroredRepeat,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FromStr for ShaderFormat {
|
impl FromStr for ImageFormat {
|
||||||
type Err = Infallible;
|
type Err = Infallible;
|
||||||
|
|
||||||
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||||
|
|
|
@ -5,7 +5,7 @@ mod stage;
|
||||||
|
|
||||||
use crate::include::read_source;
|
use crate::include::read_source;
|
||||||
pub use error::*;
|
pub use error::*;
|
||||||
use librashader_common::ShaderFormat;
|
use librashader_common::ImageFormat;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone, PartialEq)]
|
||||||
|
@ -14,7 +14,7 @@ pub struct ShaderSource {
|
||||||
pub fragment: String,
|
pub fragment: String,
|
||||||
pub name: Option<String>,
|
pub name: Option<String>,
|
||||||
pub parameters: Vec<ShaderParameter>,
|
pub parameters: Vec<ShaderParameter>,
|
||||||
pub format: ShaderFormat,
|
pub format: ImageFormat,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone, PartialEq)]
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use crate::{PreprocessError, ShaderParameter};
|
use crate::{PreprocessError, ShaderParameter};
|
||||||
use librashader_common::ShaderFormat;
|
use librashader_common::ImageFormat;
|
||||||
use nom::bytes::complete::{is_not, tag, take_while};
|
use nom::bytes::complete::{is_not, tag, take_while};
|
||||||
|
|
||||||
use nom::character::complete::multispace1;
|
use nom::character::complete::multispace1;
|
||||||
|
@ -10,7 +10,7 @@ use std::str::FromStr;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub(crate) struct ShaderMeta {
|
pub(crate) struct ShaderMeta {
|
||||||
pub(crate) format: ShaderFormat,
|
pub(crate) format: ImageFormat,
|
||||||
pub(crate) parameters: Vec<ShaderParameter>,
|
pub(crate) parameters: Vec<ShaderParameter>,
|
||||||
pub(crate) name: Option<String>,
|
pub(crate) name: Option<String>,
|
||||||
}
|
}
|
||||||
|
@ -73,7 +73,7 @@ fn parse_parameter_string(input: &str) -> Result<ShaderParameter, PreprocessErro
|
||||||
pub(crate) fn parse_pragma_meta(source: impl AsRef<str>) -> Result<ShaderMeta, PreprocessError> {
|
pub(crate) fn parse_pragma_meta(source: impl AsRef<str>) -> Result<ShaderMeta, PreprocessError> {
|
||||||
let source = source.as_ref();
|
let source = source.as_ref();
|
||||||
let mut parameters: Vec<ShaderParameter> = Vec::new();
|
let mut parameters: Vec<ShaderParameter> = Vec::new();
|
||||||
let mut format = ShaderFormat::default();
|
let mut format = ImageFormat::default();
|
||||||
let mut name = None;
|
let mut name = None;
|
||||||
for line in source.lines() {
|
for line in source.lines() {
|
||||||
if line.starts_with("#pragma parameter ") {
|
if line.starts_with("#pragma parameter ") {
|
||||||
|
@ -88,14 +88,14 @@ pub(crate) fn parse_pragma_meta(source: impl AsRef<str>) -> Result<ShaderMeta, P
|
||||||
}
|
}
|
||||||
|
|
||||||
if line.starts_with("#pragma format ") {
|
if line.starts_with("#pragma format ") {
|
||||||
if format != ShaderFormat::Unknown {
|
if format != ImageFormat::Unknown {
|
||||||
return Err(PreprocessError::DuplicatePragmaError(line.to_string()));
|
return Err(PreprocessError::DuplicatePragmaError(line.to_string()));
|
||||||
}
|
}
|
||||||
|
|
||||||
let format_string = line["#pragma format ".len()..].trim();
|
let format_string = line["#pragma format ".len()..].trim();
|
||||||
format = ShaderFormat::from_str(format_string)?;
|
format = ImageFormat::from_str(format_string)?;
|
||||||
|
|
||||||
if format == ShaderFormat::Unknown {
|
if format == ImageFormat::Unknown {
|
||||||
return Err(PreprocessError::UnknownShaderFormat);
|
return Err(PreprocessError::UnknownShaderFormat);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use crate::texture::{DxImageView, OwnedTexture, Texture};
|
use crate::texture::{DxImageView, OwnedTexture, Texture};
|
||||||
use librashader_common::image::Image;
|
use librashader_common::image::Image;
|
||||||
use librashader_common::Size;
|
use librashader_common::{ImageFormat, Size};
|
||||||
use librashader_preprocess::ShaderSource;
|
use librashader_preprocess::ShaderSource;
|
||||||
use librashader_presets::{ShaderPassConfig, ShaderPreset, TextureConfig};
|
use librashader_presets::{ShaderPassConfig, ShaderPreset, TextureConfig};
|
||||||
use librashader_reflect::back::cross::GlslangHlslContext;
|
use librashader_reflect::back::cross::GlslangHlslContext;
|
||||||
|
@ -19,7 +19,7 @@ use windows::Win32::Graphics::Direct3D11::{D3D11_BIND_CONSTANT_BUFFER, D3D11_BIN
|
||||||
use windows::Win32::Graphics::Dxgi::Common::{DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_R8G8B8A8_UNORM, DXGI_SAMPLE_DESC};
|
use windows::Win32::Graphics::Dxgi::Common::{DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_R8G8B8A8_UNORM, DXGI_SAMPLE_DESC};
|
||||||
use librashader_runtime::uniforms::UniformStorage;
|
use librashader_runtime::uniforms::UniformStorage;
|
||||||
use crate::filter_pass::{ConstantBufferBinding, FilterPass};
|
use crate::filter_pass::{ConstantBufferBinding, FilterPass};
|
||||||
use crate::framebuffer::OutputFramebuffer;
|
use crate::framebuffer::{OutputFramebuffer, OwnedFramebuffer};
|
||||||
use crate::quad_render::DrawQuad;
|
use crate::quad_render::DrawQuad;
|
||||||
use crate::render_target::RenderTarget;
|
use crate::render_target::RenderTarget;
|
||||||
use crate::samplers::SamplerSet;
|
use crate::samplers::SamplerSet;
|
||||||
|
@ -38,6 +38,7 @@ type ShaderPassMeta<'a> = (
|
||||||
pub struct FilterChain {
|
pub struct FilterChain {
|
||||||
pub common: FilterCommon,
|
pub common: FilterCommon,
|
||||||
pub passes: Vec<FilterPass>,
|
pub passes: Vec<FilterPass>,
|
||||||
|
pub output_framebuffers: Box<[OwnedFramebuffer]>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Direct3D11 {
|
pub struct Direct3D11 {
|
||||||
|
@ -185,15 +186,16 @@ impl FilterChain {
|
||||||
// initialize passes
|
// initialize passes
|
||||||
let filters = FilterChain::init_passes(device, passes, &semantics).unwrap();
|
let filters = FilterChain::init_passes(device, passes, &semantics).unwrap();
|
||||||
|
|
||||||
// let default_filter = filters.first().map(|f| f.config.filter).unwrap_or_default();
|
let default_filter = filters.first().map(|f| f.config.filter).unwrap_or_default();
|
||||||
// let default_wrap = filters
|
let default_wrap = filters
|
||||||
// .first()
|
.first()
|
||||||
// .map(|f| f.config.wrap_mode)
|
.map(|f| f.config.wrap_mode)
|
||||||
// .unwrap_or_default();
|
.unwrap_or_default();
|
||||||
|
|
||||||
// // initialize output framebuffers
|
// initialize output framebuffers
|
||||||
// let mut output_framebuffers = Vec::new();
|
let mut output_framebuffers = Vec::new();
|
||||||
// output_framebuffers.resize_with(filters.len(), || Framebuffer::new(1));
|
output_framebuffers.resize_with(filters.len(), || OwnedFramebuffer::new(device, Size::new(1, 1),
|
||||||
|
ImageFormat::R8G8B8A8Unorm).unwrap());
|
||||||
// let mut output_textures = Vec::new();
|
// let mut output_textures = Vec::new();
|
||||||
// output_textures.resize_with(filters.len(), Texture::default);
|
// output_textures.resize_with(filters.len(), Texture::default);
|
||||||
//
|
//
|
||||||
|
@ -220,7 +222,7 @@ impl FilterChain {
|
||||||
// todo: make vbo: d3d11.c 1376
|
// todo: make vbo: d3d11.c 1376
|
||||||
Ok(FilterChain {
|
Ok(FilterChain {
|
||||||
passes: filters,
|
passes: filters,
|
||||||
// output_framebuffers: output_framebuffers.into_boxed_slice(),
|
output_framebuffers: output_framebuffers.into_boxed_slice(),
|
||||||
// feedback_framebuffers: feedback_framebuffers.into_boxed_slice(),
|
// feedback_framebuffers: feedback_framebuffers.into_boxed_slice(),
|
||||||
// history_framebuffers,
|
// history_framebuffers,
|
||||||
// filter_vao,
|
// filter_vao,
|
||||||
|
@ -346,13 +348,34 @@ impl FilterChain {
|
||||||
|
|
||||||
let mut source = original.clone();
|
let mut source = original.clone();
|
||||||
|
|
||||||
|
// rescale render buffers to ensure all bindings are valid.
|
||||||
|
for (index, pass) in passes.iter_mut().enumerate() {
|
||||||
|
self.output_framebuffers[index].scale(
|
||||||
|
pass.config.scaling.clone(),
|
||||||
|
pass.get_format(),
|
||||||
|
viewport,
|
||||||
|
&original,
|
||||||
|
&source,
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for (index, pass) in passes.iter_mut().enumerate() {
|
for (index, pass) in passes.iter_mut().enumerate() {
|
||||||
|
let target = &self.output_framebuffers[index];
|
||||||
|
let size = target.size;
|
||||||
|
|
||||||
pass.draw(index, &self.common, if pass.config.frame_count_mod > 0 {
|
pass.draw(index, &self.common, if pass.config.frame_count_mod > 0 {
|
||||||
count % pass.config.frame_count_mod as usize
|
count % pass.config.frame_count_mod as usize
|
||||||
} else {
|
} else {
|
||||||
count
|
count
|
||||||
} as u32, 1, viewport, &original, &source, RenderTarget::new(output.clone(), None))?;
|
} as u32, 1, viewport, &original, &source, RenderTarget::new(target.as_output_framebuffer().unwrap(), None))?;
|
||||||
|
|
||||||
|
source = Texture {
|
||||||
|
view: DxImageView { handle: target.create_shader_resource_view().unwrap(), size },
|
||||||
|
filter,
|
||||||
|
wrap_mode,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use crate::filter_chain::FilterCommon;
|
use crate::filter_chain::FilterCommon;
|
||||||
use crate::texture::{Texture, OwnedTexture};
|
use crate::texture::{Texture, OwnedTexture};
|
||||||
use librashader_common::Size;
|
use librashader_common::{ImageFormat, Size};
|
||||||
use librashader_preprocess::ShaderSource;
|
use librashader_preprocess::ShaderSource;
|
||||||
use librashader_presets::ShaderPassConfig;
|
use librashader_presets::ShaderPassConfig;
|
||||||
use librashader_reflect::back::cross::GlslangHlslContext;
|
use librashader_reflect::back::cross::GlslangHlslContext;
|
||||||
|
@ -41,25 +41,14 @@ pub struct FilterPass {
|
||||||
}
|
}
|
||||||
// slang_process.cpp 229
|
// slang_process.cpp 229
|
||||||
impl FilterPass {
|
impl FilterPass {
|
||||||
fn build_mvp(buffer: &mut [u8], mvp: &[f32]) {
|
pub fn get_format(&self) -> ImageFormat {
|
||||||
let mvp = bytemuck::cast_slice(mvp);
|
let mut fb_format = ImageFormat::R8G8B8A8Unorm;
|
||||||
buffer.copy_from_slice(mvp);
|
if self.config.srgb_framebuffer {
|
||||||
|
fb_format = ImageFormat::R8G8B8A8Srgb;
|
||||||
|
} else if self.config.float_framebuffer {
|
||||||
|
fb_format = ImageFormat::R16G16B16A16Sfloat;
|
||||||
}
|
}
|
||||||
|
fb_format
|
||||||
#[inline(always)]
|
|
||||||
fn build_uniform<T>(buffer: &mut [u8], value: T)
|
|
||||||
where
|
|
||||||
T: Copy,
|
|
||||||
T: bytemuck::Pod,
|
|
||||||
{
|
|
||||||
let buffer = bytemuck::cast_slice_mut(buffer);
|
|
||||||
buffer[0] = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
fn build_vec4(buffer: &mut [u8], size: impl Into<[f32; 4]>) {
|
|
||||||
let vec4 = size.into();
|
|
||||||
let vec4 = bytemuck::cast_slice(&vec4);
|
|
||||||
buffer.copy_from_slice(vec4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn bind_texture(
|
fn bind_texture(
|
||||||
|
@ -204,30 +193,24 @@ impl FilterPass {
|
||||||
// }
|
// }
|
||||||
|
|
||||||
// PassOutput
|
// PassOutput
|
||||||
// for (index, output) in parent.output_textures.iter().enumerate() {
|
for (index, output) in parent.output_textures.iter().enumerate() {
|
||||||
// if let Some(binding) = self
|
if let Some(binding) = self
|
||||||
// .reflection
|
.reflection
|
||||||
// .meta
|
.meta
|
||||||
// .texture_meta
|
.texture_meta
|
||||||
// .get(&TextureSemantics::PassOutput.semantics(index))
|
.get(&TextureSemantics::PassOutput.semantics(index))
|
||||||
// {
|
{
|
||||||
// FilterPass::bind_texture(binding, output);
|
FilterPass::bind_texture(binding, output);
|
||||||
// }
|
}
|
||||||
//
|
|
||||||
// if let Some(offset) = self
|
if let Some(offset) = self
|
||||||
// .uniform_bindings
|
.uniform_bindings
|
||||||
// .get(&TextureSemantics::PassOutput.semantics(index).into())
|
.get(&TextureSemantics::PassOutput.semantics(index).into())
|
||||||
// {
|
{
|
||||||
// let (buffer, offset) = match offset {
|
self.uniform_storage.bind_vec4(*offset, output.image.size, None);
|
||||||
// MemberOffset::Ubo(offset) => (&mut self.uniform_buffer.storage, *offset),
|
|
||||||
// MemberOffset::PushConstant(offset) => (&mut self.push_buffer.storage, *offset),
|
}
|
||||||
// };
|
}
|
||||||
// FilterPass::build_uniform(
|
|
||||||
// &mut buffer[offset..][..16],
|
|
||||||
// output.image.size,
|
|
||||||
// );
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
// PassFeedback
|
// PassFeedback
|
||||||
// for (index, feedback) in parent.feedback_textures.iter().enumerate() {
|
// for (index, feedback) in parent.feedback_textures.iter().enumerate() {
|
||||||
|
|
|
@ -1,16 +1,192 @@
|
||||||
use windows::Win32::Graphics::Direct3D11::{D3D11_VIEWPORT, ID3D11RenderTargetView, ID3D11ShaderResourceView, ID3D11Texture2D};
|
use windows::Win32::Graphics::Direct3D11::{D3D11_BIND_RENDER_TARGET, D3D11_BIND_SHADER_RESOURCE, D3D11_CPU_ACCESS_WRITE, D3D11_FORMAT_SUPPORT_RENDER_TARGET, D3D11_FORMAT_SUPPORT_SHADER_SAMPLE, D3D11_FORMAT_SUPPORT_TEXTURE2D, D3D11_RENDER_TARGET_VIEW_DESC, D3D11_RENDER_TARGET_VIEW_DESC_0, D3D11_RTV_DIMENSION_TEXTURE2D, D3D11_SHADER_RESOURCE_VIEW_DESC, D3D11_SHADER_RESOURCE_VIEW_DESC_0, D3D11_TEX2D_RTV, D3D11_TEX2D_SRV, D3D11_TEXTURE2D_DESC, D3D11_USAGE_DEFAULT, D3D11_USAGE_DYNAMIC, D3D11_VIEWPORT, ID3D11Device, ID3D11RenderTargetView, ID3D11ShaderResourceView, ID3D11Texture2D};
|
||||||
use librashader_common::Size;
|
use windows::Win32::Graphics::Direct3D::D3D_SRV_DIMENSION_TEXTURE2D;
|
||||||
|
use windows::Win32::Graphics::Dxgi::Common::{DXGI_FORMAT, DXGI_SAMPLE_DESC};
|
||||||
|
use librashader_common::{ImageFormat, Size};
|
||||||
|
use librashader_presets::{Scale2D, ScaleType, Scaling};
|
||||||
|
use crate::texture::Texture;
|
||||||
|
use crate::util;
|
||||||
|
use crate::util::d3d11_get_closest_format;
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct OwnedFramebuffer {
|
pub struct OwnedFramebuffer {
|
||||||
pub srv: ID3D11ShaderResourceView,
|
|
||||||
pub rtv: ID3D11RenderTargetView,
|
|
||||||
pub texture: ID3D11Texture2D,
|
pub texture: ID3D11Texture2D,
|
||||||
|
pub size: Size<u32>,
|
||||||
|
pub format: DXGI_FORMAT,
|
||||||
|
device: ID3D11Device,
|
||||||
|
is_raw: bool
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
impl OwnedFramebuffer {
|
||||||
|
pub fn new(device: &ID3D11Device, size: Size<u32>, format: ImageFormat) -> util::Result<OwnedFramebuffer> {
|
||||||
|
unsafe {
|
||||||
|
let format = d3d11_get_closest_format(device, DXGI_FORMAT::from(format),
|
||||||
|
D3D11_FORMAT_SUPPORT_TEXTURE2D.0 | D3D11_FORMAT_SUPPORT_SHADER_SAMPLE.0 | D3D11_FORMAT_SUPPORT_RENDER_TARGET.0);
|
||||||
|
eprintln!("{format:?}");
|
||||||
|
let desc = default_desc(size, format);
|
||||||
|
let texture = device.CreateTexture2D(&desc, None)?;
|
||||||
|
|
||||||
|
Ok(OwnedFramebuffer {
|
||||||
|
texture,
|
||||||
|
size,
|
||||||
|
format,
|
||||||
|
device: device.clone(),
|
||||||
|
is_raw: false,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) fn scale(
|
||||||
|
&mut self,
|
||||||
|
scaling: Scale2D,
|
||||||
|
format: ImageFormat,
|
||||||
|
viewport_size: &Size<u32>,
|
||||||
|
_original: &Texture,
|
||||||
|
source: &Texture,
|
||||||
|
) -> util::Result<Size<u32>> {
|
||||||
|
if self.is_raw {
|
||||||
|
return Ok(self.size);
|
||||||
|
}
|
||||||
|
|
||||||
|
let width;
|
||||||
|
let height;
|
||||||
|
|
||||||
|
match scaling.x {
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Input,
|
||||||
|
factor,
|
||||||
|
} => width = source.view.size.width * factor,
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Absolute,
|
||||||
|
factor,
|
||||||
|
} => width = factor.into(),
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Viewport,
|
||||||
|
factor,
|
||||||
|
} => width = viewport_size.width * factor,
|
||||||
|
};
|
||||||
|
|
||||||
|
match scaling.y {
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Input,
|
||||||
|
factor,
|
||||||
|
} => height = source.view.size.height * factor,
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Absolute,
|
||||||
|
factor,
|
||||||
|
} => height = factor.into(),
|
||||||
|
Scaling {
|
||||||
|
scale_type: ScaleType::Viewport,
|
||||||
|
factor,
|
||||||
|
} => height = viewport_size.height * factor,
|
||||||
|
};
|
||||||
|
|
||||||
|
let size = Size {
|
||||||
|
width: width.round() as u32,
|
||||||
|
height: height.round() as u32,
|
||||||
|
};
|
||||||
|
|
||||||
|
if self.size != size {
|
||||||
|
self.size = size;
|
||||||
|
|
||||||
|
self.init(
|
||||||
|
size,
|
||||||
|
if format == ImageFormat::Unknown {
|
||||||
|
ImageFormat::R8G8B8A8Unorm
|
||||||
|
} else {
|
||||||
|
format
|
||||||
|
},
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
Ok(size)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn init(&mut self, size: Size<u32>, format: ImageFormat) -> util::Result<()> {
|
||||||
|
if self.is_raw {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
|
let format = d3d11_get_closest_format(&self.device, DXGI_FORMAT::from(format),
|
||||||
|
D3D11_FORMAT_SUPPORT_TEXTURE2D.0 |
|
||||||
|
D3D11_FORMAT_SUPPORT_SHADER_SAMPLE.0 | D3D11_FORMAT_SUPPORT_RENDER_TARGET.0);
|
||||||
|
let desc = default_desc(size, format);
|
||||||
|
unsafe {
|
||||||
|
let mut texture = self.device.CreateTexture2D(&desc, None)?;
|
||||||
|
std::mem::swap(&mut self.texture, &mut texture);
|
||||||
|
drop(texture)
|
||||||
|
}
|
||||||
|
self.format = format;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn create_shader_resource_view(&self) -> util::Result<ID3D11ShaderResourceView> {
|
||||||
|
unsafe {
|
||||||
|
Ok(self.device.CreateShaderResourceView(&self.texture, Some(&D3D11_SHADER_RESOURCE_VIEW_DESC {
|
||||||
|
Format: self.format,
|
||||||
|
ViewDimension: D3D_SRV_DIMENSION_TEXTURE2D,
|
||||||
|
Anonymous: D3D11_SHADER_RESOURCE_VIEW_DESC_0 {
|
||||||
|
Texture2D: D3D11_TEX2D_SRV {
|
||||||
|
MostDetailedMip: 0,
|
||||||
|
MipLevels: u32::MAX,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}))?)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn create_render_target_view(&self) -> util::Result<ID3D11RenderTargetView> {
|
||||||
|
unsafe {
|
||||||
|
Ok(self.device.CreateRenderTargetView(&self.texture, Some(&D3D11_RENDER_TARGET_VIEW_DESC {
|
||||||
|
Format: self.format,
|
||||||
|
ViewDimension: D3D11_RTV_DIMENSION_TEXTURE2D,
|
||||||
|
Anonymous: D3D11_RENDER_TARGET_VIEW_DESC_0 {
|
||||||
|
Texture2D: D3D11_TEX2D_RTV {
|
||||||
|
MipSlice: 0,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}))?)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn as_output_framebuffer(&self) -> util::Result<OutputFramebuffer> {
|
||||||
|
Ok(OutputFramebuffer {
|
||||||
|
rtv: self.create_render_target_view()?,
|
||||||
|
size: self.size,
|
||||||
|
viewport: default_viewport(self.size)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
pub struct OutputFramebuffer {
|
pub struct OutputFramebuffer {
|
||||||
pub rtv: ID3D11RenderTargetView,
|
pub rtv: ID3D11RenderTargetView,
|
||||||
pub size: Size<u32>,
|
pub size: Size<u32>,
|
||||||
pub viewport: D3D11_VIEWPORT
|
pub viewport: D3D11_VIEWPORT
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn default_desc(size: Size<u32>, format: DXGI_FORMAT) -> D3D11_TEXTURE2D_DESC {
|
||||||
|
D3D11_TEXTURE2D_DESC {
|
||||||
|
Width: size.width,
|
||||||
|
Height: size.height,
|
||||||
|
MipLevels: 1,
|
||||||
|
ArraySize: 1,
|
||||||
|
Format: format,
|
||||||
|
SampleDesc: DXGI_SAMPLE_DESC {
|
||||||
|
Count: 1,
|
||||||
|
Quality: 0,
|
||||||
|
},
|
||||||
|
Usage: D3D11_USAGE_DEFAULT,
|
||||||
|
BindFlags: D3D11_BIND_SHADER_RESOURCE | D3D11_BIND_RENDER_TARGET,
|
||||||
|
CPUAccessFlags: D3D11_CPU_ACCESS_WRITE,
|
||||||
|
MiscFlags: Default::default(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub const fn default_viewport(size: Size<u32>) -> D3D11_VIEWPORT {
|
||||||
|
D3D11_VIEWPORT {
|
||||||
|
TopLeftX: 0.0,
|
||||||
|
TopLeftY: 0.0,
|
||||||
|
Width: size.width as f32,
|
||||||
|
Height: size.height as f32,
|
||||||
|
MinDepth: 0.0,
|
||||||
|
MaxDepth: 1.0,
|
||||||
|
}
|
||||||
|
}
|
|
@ -694,7 +694,7 @@ pub mod d3d11_hello_triangle {
|
||||||
let dxgi_factory_flags = if cfg!(debug_assertions) {
|
let dxgi_factory_flags = if cfg!(debug_assertions) {
|
||||||
DXGI_CREATE_FACTORY_DEBUG
|
DXGI_CREATE_FACTORY_DEBUG
|
||||||
} else {
|
} else {
|
||||||
0
|
DXGI_CREATE_FACTORY_DEBUG
|
||||||
};
|
};
|
||||||
|
|
||||||
let dxgi_factory: IDXGIFactory4 = unsafe { CreateDXGIFactory2(dxgi_factory_flags) }?;
|
let dxgi_factory: IDXGIFactory4 = unsafe { CreateDXGIFactory2(dxgi_factory_flags) }?;
|
||||||
|
@ -709,7 +709,7 @@ pub mod d3d11_hello_triangle {
|
||||||
None,
|
None,
|
||||||
D3D_DRIVER_TYPE_HARDWARE,
|
D3D_DRIVER_TYPE_HARDWARE,
|
||||||
HINSTANCE::default(),
|
HINSTANCE::default(),
|
||||||
D3D11_CREATE_DEVICE_BGRA_SUPPORT | D3D11_CREATE_DEVICE_DEBUG,
|
D3D11_CREATE_DEVICE_DEBUG,
|
||||||
Some(&feature_levels),
|
Some(&feature_levels),
|
||||||
D3D11_SDK_VERSION,
|
D3D11_SDK_VERSION,
|
||||||
Some(&mut out_device),
|
Some(&mut out_device),
|
||||||
|
|
|
@ -34,7 +34,7 @@ mod tests {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn triangle_d3d11() {
|
fn triangle_d3d11() {
|
||||||
let sample = hello_triangle::d3d11_hello_triangle::Sample::new("../test/slang-shaders/crt/crt-royale.slangp").unwrap();
|
let sample = hello_triangle::d3d11_hello_triangle::Sample::new("../test/basic.slangp").unwrap();
|
||||||
// let sample = hello_triangle::d3d11_hello_triangle::Sample::new("../test/basic.slangp").unwrap();
|
// let sample = hello_triangle::d3d11_hello_triangle::Sample::new("../test/basic.slangp").unwrap();
|
||||||
|
|
||||||
hello_triangle::main(sample).unwrap();
|
hello_triangle::main(sample).unwrap();
|
||||||
|
|
|
@ -4,7 +4,7 @@ use librashader_reflect::back::cross::GlslangGlslContext;
|
||||||
use librashader_reflect::back::ShaderCompilerOutput;
|
use librashader_reflect::back::ShaderCompilerOutput;
|
||||||
use librashader_reflect::reflect::ShaderReflection;
|
use librashader_reflect::reflect::ShaderReflection;
|
||||||
|
|
||||||
use librashader_common::{ShaderFormat, Size};
|
use librashader_common::{ImageFormat, Size};
|
||||||
use librashader_preprocess::ShaderSource;
|
use librashader_preprocess::ShaderSource;
|
||||||
use librashader_presets::ShaderPassConfig;
|
use librashader_presets::ShaderPassConfig;
|
||||||
use librashader_reflect::reflect::semantics::{BindingStage, MemberOffset, TextureBinding, TextureSemantics, UniformBinding, VariableSemantics};
|
use librashader_reflect::reflect::semantics::{BindingStage, MemberOffset, TextureBinding, TextureSemantics, UniformBinding, VariableSemantics};
|
||||||
|
@ -135,12 +135,12 @@ impl FilterPass {
|
||||||
|
|
||||||
|
|
||||||
impl FilterPass {
|
impl FilterPass {
|
||||||
pub fn get_format(&self) -> ShaderFormat {
|
pub fn get_format(&self) -> ImageFormat {
|
||||||
let mut fb_format = ShaderFormat::R8G8B8A8Unorm;
|
let mut fb_format = ImageFormat::R8G8B8A8Unorm;
|
||||||
if self.config.srgb_framebuffer {
|
if self.config.srgb_framebuffer {
|
||||||
fb_format = ShaderFormat::R8G8B8A8Srgb;
|
fb_format = ImageFormat::R8G8B8A8Srgb;
|
||||||
} else if self.config.float_framebuffer {
|
} else if self.config.float_framebuffer {
|
||||||
fb_format = ShaderFormat::R16G16B16A16Sfloat;
|
fb_format = ImageFormat::R16G16B16A16Sfloat;
|
||||||
}
|
}
|
||||||
fb_format
|
fb_format
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use crate::util;
|
use crate::util;
|
||||||
use crate::texture::Texture;
|
use crate::texture::Texture;
|
||||||
use gl::types::{GLenum, GLint, GLsizei, GLuint};
|
use gl::types::{GLenum, GLint, GLsizei, GLuint};
|
||||||
use librashader_common::{FilterMode, ShaderFormat, Size, WrapMode};
|
use librashader_common::{FilterMode, ImageFormat, Size, WrapMode};
|
||||||
use librashader_presets::{Scale2D, ScaleType, Scaling};
|
use librashader_presets::{Scale2D, ScaleType, Scaling};
|
||||||
use crate::error::FilterChainError;
|
use crate::error::FilterChainError;
|
||||||
use crate::error::Result;
|
use crate::error::Result;
|
||||||
|
@ -75,7 +75,7 @@ impl Framebuffer {
|
||||||
pub(crate) fn scale(
|
pub(crate) fn scale(
|
||||||
&mut self,
|
&mut self,
|
||||||
scaling: Scale2D,
|
scaling: Scale2D,
|
||||||
format: ShaderFormat,
|
format: ImageFormat,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
_original: &Texture,
|
_original: &Texture,
|
||||||
source: &Texture,
|
source: &Texture,
|
||||||
|
@ -127,8 +127,8 @@ impl Framebuffer {
|
||||||
|
|
||||||
self.init(
|
self.init(
|
||||||
size,
|
size,
|
||||||
if format == ShaderFormat::Unknown {
|
if format == ImageFormat::Unknown {
|
||||||
ShaderFormat::R8G8B8A8Unorm
|
ImageFormat::R8G8B8A8Unorm
|
||||||
} else {
|
} else {
|
||||||
format
|
format
|
||||||
},
|
},
|
||||||
|
@ -302,7 +302,7 @@ impl Framebuffer {
|
||||||
gl::TexStorage2D(
|
gl::TexStorage2D(
|
||||||
gl::TEXTURE_2D,
|
gl::TEXTURE_2D,
|
||||||
self.levels as GLsizei,
|
self.levels as GLsizei,
|
||||||
ShaderFormat::R8G8B8A8Unorm.into(),
|
ImageFormat::R8G8B8A8Unorm.into(),
|
||||||
size.width as GLsizei,
|
size.width as GLsizei,
|
||||||
size.height as GLsizei,
|
size.height as GLsizei,
|
||||||
);
|
);
|
||||||
|
|
|
@ -3,7 +3,7 @@ use librashader_reflect::back::cross::GlslangGlslContext;
|
||||||
use librashader_reflect::back::ShaderCompilerOutput;
|
use librashader_reflect::back::ShaderCompilerOutput;
|
||||||
use librashader_reflect::reflect::ShaderReflection;
|
use librashader_reflect::reflect::ShaderReflection;
|
||||||
|
|
||||||
use librashader_common::{ShaderFormat, Size};
|
use librashader_common::{ImageFormat, Size};
|
||||||
use librashader_preprocess::ShaderSource;
|
use librashader_preprocess::ShaderSource;
|
||||||
use librashader_presets::ShaderPassConfig;
|
use librashader_presets::ShaderPassConfig;
|
||||||
use librashader_reflect::reflect::semantics::{BindingStage, MemberOffset, TextureBinding, TextureSemantics, UniformBinding, VariableSemantics};
|
use librashader_reflect::reflect::semantics::{BindingStage, MemberOffset, TextureBinding, TextureSemantics, UniformBinding, VariableSemantics};
|
||||||
|
@ -124,12 +124,12 @@ impl FilterPass {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterPass {
|
impl FilterPass {
|
||||||
pub fn get_format(&self) -> ShaderFormat {
|
pub fn get_format(&self) -> ImageFormat {
|
||||||
let mut fb_format = ShaderFormat::R8G8B8A8Unorm;
|
let mut fb_format = ImageFormat::R8G8B8A8Unorm;
|
||||||
if self.config.srgb_framebuffer {
|
if self.config.srgb_framebuffer {
|
||||||
fb_format = ShaderFormat::R8G8B8A8Srgb;
|
fb_format = ImageFormat::R8G8B8A8Srgb;
|
||||||
} else if self.config.float_framebuffer {
|
} else if self.config.float_framebuffer {
|
||||||
fb_format = ShaderFormat::R16G16B16A16Sfloat;
|
fb_format = ImageFormat::R16G16B16A16Sfloat;
|
||||||
}
|
}
|
||||||
fb_format
|
fb_format
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use crate::util;
|
use crate::util;
|
||||||
use crate::texture::Texture;
|
use crate::texture::Texture;
|
||||||
use gl::types::{GLenum, GLint, GLsizei, GLuint};
|
use gl::types::{GLenum, GLint, GLsizei, GLuint};
|
||||||
use librashader_common::{FilterMode, ShaderFormat, Size, WrapMode};
|
use librashader_common::{FilterMode, ImageFormat, Size, WrapMode};
|
||||||
use librashader_presets::{Scale2D, ScaleType, Scaling};
|
use librashader_presets::{Scale2D, ScaleType, Scaling};
|
||||||
use crate::error::FilterChainError;
|
use crate::error::FilterChainError;
|
||||||
use crate::error::Result;
|
use crate::error::Result;
|
||||||
|
@ -73,7 +73,7 @@ impl Framebuffer {
|
||||||
pub(crate) fn scale(
|
pub(crate) fn scale(
|
||||||
&mut self,
|
&mut self,
|
||||||
scaling: Scale2D,
|
scaling: Scale2D,
|
||||||
format: ShaderFormat,
|
format: ImageFormat,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
_original: &Texture,
|
_original: &Texture,
|
||||||
source: &Texture,
|
source: &Texture,
|
||||||
|
@ -125,8 +125,8 @@ impl Framebuffer {
|
||||||
|
|
||||||
self.init(
|
self.init(
|
||||||
size,
|
size,
|
||||||
if format == ShaderFormat::Unknown {
|
if format == ImageFormat::Unknown {
|
||||||
ShaderFormat::R8G8B8A8Unorm
|
ImageFormat::R8G8B8A8Unorm
|
||||||
} else {
|
} else {
|
||||||
format
|
format
|
||||||
},
|
},
|
||||||
|
@ -241,7 +241,7 @@ impl Framebuffer {
|
||||||
gl::TextureStorage2D(
|
gl::TextureStorage2D(
|
||||||
self.image,
|
self.image,
|
||||||
self.levels as GLsizei,
|
self.levels as GLsizei,
|
||||||
ShaderFormat::R8G8B8A8Unorm.into(),
|
ImageFormat::R8G8B8A8Unorm.into(),
|
||||||
size.width as GLsizei,
|
size.width as GLsizei,
|
||||||
size.height as GLsizei,
|
size.height as GLsizei,
|
||||||
);
|
);
|
||||||
|
|
|
@ -73,7 +73,7 @@ pub mod targets {
|
||||||
|
|
||||||
pub use librashader_common::{
|
pub use librashader_common::{
|
||||||
FilterMode,
|
FilterMode,
|
||||||
ShaderFormat,
|
ImageFormat,
|
||||||
Size,
|
Size,
|
||||||
WrapMode
|
WrapMode
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Reference in a new issue