api: remove FilterChain
trait
This commit is contained in:
parent
dc6e8f9a2c
commit
abaebe56cc
|
@ -7,11 +7,11 @@ pub type libra_shader_preset_t = Option<NonNull<ShaderPreset>>;
|
||||||
pub type libra_error_t = Option<NonNull<LibrashaderError>>;
|
pub type libra_error_t = Option<NonNull<LibrashaderError>>;
|
||||||
|
|
||||||
#[cfg(feature = "runtime-opengl")]
|
#[cfg(feature = "runtime-opengl")]
|
||||||
pub type libra_gl_filter_chain_t = Option<NonNull<librashader::runtime::gl::FilterChainGL>>;
|
pub type libra_gl_filter_chain_t = Option<NonNull<librashader::runtime::gl::FilterChain>>;
|
||||||
|
|
||||||
#[cfg(feature = "runtime-d3d11")]
|
#[cfg(feature = "runtime-d3d11")]
|
||||||
pub type libra_d3d11_filter_chain_t =
|
pub type libra_d3d11_filter_chain_t =
|
||||||
Option<NonNull<librashader::runtime::d3d11::FilterChainD3D11>>;
|
Option<NonNull<librashader::runtime::d3d11::FilterChain>>;
|
||||||
|
|
||||||
/// Parameters for the output viewport.
|
/// Parameters for the output viewport.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
|
|
|
@ -11,8 +11,8 @@ use windows::Win32::Graphics::Direct3D11::{
|
||||||
ID3D11Device, ID3D11RenderTargetView, ID3D11ShaderResourceView,
|
ID3D11Device, ID3D11RenderTargetView, ID3D11ShaderResourceView,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub use librashader::runtime::d3d11::options::FilterChainOptionsD3D11;
|
pub use librashader::runtime::d3d11::options::FilterChainOptions;
|
||||||
pub use librashader::runtime::d3d11::options::FrameOptionsD3D11;
|
pub use librashader::runtime::d3d11::options::FrameOptions;
|
||||||
use librashader::Size;
|
use librashader::Size;
|
||||||
|
|
||||||
/// OpenGL parameters for the source image.
|
/// OpenGL parameters for the source image.
|
||||||
|
@ -42,7 +42,7 @@ impl TryFrom<libra_source_image_d3d11_t> for D3D11ImageView {
|
||||||
|
|
||||||
pub type PFN_lbr_d3d11_filter_chain_create = unsafe extern "C" fn(
|
pub type PFN_lbr_d3d11_filter_chain_create = unsafe extern "C" fn(
|
||||||
preset: *mut libra_shader_preset_t,
|
preset: *mut libra_shader_preset_t,
|
||||||
options: *const FilterChainOptionsD3D11,
|
options: *const FilterChainOptions,
|
||||||
device: *const ID3D11Device,
|
device: *const ID3D11Device,
|
||||||
out: *mut MaybeUninit<libra_d3d11_filter_chain_t>,
|
out: *mut MaybeUninit<libra_d3d11_filter_chain_t>,
|
||||||
) -> libra_error_t;
|
) -> libra_error_t;
|
||||||
|
@ -58,7 +58,7 @@ pub type PFN_lbr_d3d11_filter_chain_create = unsafe extern "C" fn(
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn libra_d3d11_filter_chain_create(
|
pub unsafe extern "C" fn libra_d3d11_filter_chain_create(
|
||||||
preset: *mut libra_shader_preset_t,
|
preset: *mut libra_shader_preset_t,
|
||||||
options: *const FilterChainOptionsD3D11,
|
options: *const FilterChainOptions,
|
||||||
device: *const ID3D11Device,
|
device: *const ID3D11Device,
|
||||||
out: *mut MaybeUninit<libra_d3d11_filter_chain_t>,
|
out: *mut MaybeUninit<libra_d3d11_filter_chain_t>,
|
||||||
) -> libra_error_t {
|
) -> libra_error_t {
|
||||||
|
@ -77,7 +77,7 @@ pub unsafe extern "C" fn libra_d3d11_filter_chain_create(
|
||||||
Some(unsafe { &*options })
|
Some(unsafe { &*options })
|
||||||
};
|
};
|
||||||
|
|
||||||
let chain = librashader::runtime::d3d11::FilterChainD3D11::load_from_preset(
|
let chain = librashader::runtime::d3d11::FilterChain::load_from_preset(
|
||||||
unsafe { &*device },
|
unsafe { &*device },
|
||||||
*preset,
|
*preset,
|
||||||
options,
|
options,
|
||||||
|
@ -98,7 +98,7 @@ pub type PFN_lbr_d3d11_filter_chain_frame = unsafe extern "C" fn(
|
||||||
viewport: libra_viewport_t,
|
viewport: libra_viewport_t,
|
||||||
out: *const ID3D11RenderTargetView,
|
out: *const ID3D11RenderTargetView,
|
||||||
mvp: *const f32,
|
mvp: *const f32,
|
||||||
opt: *const FrameOptionsD3D11,
|
opt: *const FrameOptions,
|
||||||
) -> libra_error_t;
|
) -> libra_error_t;
|
||||||
|
|
||||||
/// Draw a frame with the given parameters for the given filter chain.
|
/// Draw a frame with the given parameters for the given filter chain.
|
||||||
|
@ -118,7 +118,7 @@ pub unsafe extern "C" fn libra_d3d11_filter_chain_frame(
|
||||||
viewport: libra_viewport_t,
|
viewport: libra_viewport_t,
|
||||||
out: *const ID3D11RenderTargetView,
|
out: *const ID3D11RenderTargetView,
|
||||||
mvp: *const f32,
|
mvp: *const f32,
|
||||||
opt: *const FrameOptionsD3D11,
|
opt: *const FrameOptions,
|
||||||
) -> libra_error_t {
|
) -> libra_error_t {
|
||||||
ffi_body!(mut |chain| {
|
ffi_body!(mut |chain| {
|
||||||
assert_some_ptr!(mut chain);
|
assert_some_ptr!(mut chain);
|
||||||
|
|
|
@ -3,15 +3,14 @@ use crate::ctypes::{
|
||||||
};
|
};
|
||||||
use crate::error::{assert_non_null, assert_some_ptr, LibrashaderError};
|
use crate::error::{assert_non_null, assert_some_ptr, LibrashaderError};
|
||||||
use crate::ffi::ffi_body;
|
use crate::ffi::ffi_body;
|
||||||
use librashader::runtime::gl::{GLImage, Viewport};
|
use librashader::runtime::gl::{Framebuffer, GLImage, Viewport};
|
||||||
use librashader::runtime::FilterChain;
|
|
||||||
use std::ffi::{c_char, c_void, CString};
|
use std::ffi::{c_char, c_void, CString};
|
||||||
use std::mem::MaybeUninit;
|
use std::mem::MaybeUninit;
|
||||||
use std::ptr::NonNull;
|
use std::ptr::NonNull;
|
||||||
use std::slice;
|
use std::slice;
|
||||||
|
|
||||||
pub use librashader::runtime::gl::options::FilterChainOptionsGL;
|
pub use librashader::runtime::gl::options::FilterChainOptions;
|
||||||
pub use librashader::runtime::gl::options::FrameOptionsGL;
|
pub use librashader::runtime::gl::options::FrameOptions;
|
||||||
use librashader::Size;
|
use librashader::Size;
|
||||||
|
|
||||||
/// A GL function loader that librashader needs to be initialized with.
|
/// A GL function loader that librashader needs to be initialized with.
|
||||||
|
@ -37,7 +36,7 @@ pub unsafe extern "C" fn libra_gl_init_context(loader: gl_loader_t) -> libra_err
|
||||||
|
|
||||||
pub type PFN_lbr_gl_filter_chain_create = unsafe extern "C" fn(
|
pub type PFN_lbr_gl_filter_chain_create = unsafe extern "C" fn(
|
||||||
preset: *mut libra_shader_preset_t,
|
preset: *mut libra_shader_preset_t,
|
||||||
options: *const FilterChainOptionsGL,
|
options: *const FilterChainOptions,
|
||||||
out: *mut MaybeUninit<libra_gl_filter_chain_t>,
|
out: *mut MaybeUninit<libra_gl_filter_chain_t>,
|
||||||
) -> libra_error_t;
|
) -> libra_error_t;
|
||||||
/// Create the filter chain given the shader preset.
|
/// Create the filter chain given the shader preset.
|
||||||
|
@ -52,7 +51,7 @@ pub type PFN_lbr_gl_filter_chain_create = unsafe extern "C" fn(
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn libra_gl_filter_chain_create(
|
pub unsafe extern "C" fn libra_gl_filter_chain_create(
|
||||||
preset: *mut libra_shader_preset_t,
|
preset: *mut libra_shader_preset_t,
|
||||||
options: *const FilterChainOptionsGL,
|
options: *const FilterChainOptions,
|
||||||
out: *mut MaybeUninit<libra_gl_filter_chain_t>,
|
out: *mut MaybeUninit<libra_gl_filter_chain_t>,
|
||||||
) -> libra_error_t {
|
) -> libra_error_t {
|
||||||
ffi_body!({
|
ffi_body!({
|
||||||
|
@ -69,7 +68,7 @@ pub unsafe extern "C" fn libra_gl_filter_chain_create(
|
||||||
Some(unsafe { &*options })
|
Some(unsafe { &*options })
|
||||||
};
|
};
|
||||||
|
|
||||||
let chain = librashader::runtime::gl::FilterChainGL::load_from_preset(*preset, options)?;
|
let chain = librashader::runtime::gl::FilterChain::load_from_preset(*preset, options)?;
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
out.write(MaybeUninit::new(NonNull::new(Box::into_raw(Box::new(
|
out.write(MaybeUninit::new(NonNull::new(Box::into_raw(Box::new(
|
||||||
|
@ -121,7 +120,7 @@ pub type PFN_lbr_gl_filter_chain_frame = unsafe extern "C" fn(
|
||||||
viewport: libra_viewport_t,
|
viewport: libra_viewport_t,
|
||||||
out: libra_draw_framebuffer_gl_t,
|
out: libra_draw_framebuffer_gl_t,
|
||||||
mvp: *const f32,
|
mvp: *const f32,
|
||||||
opt: *const FrameOptionsGL,
|
opt: *const FrameOptions,
|
||||||
) -> libra_error_t;
|
) -> libra_error_t;
|
||||||
|
|
||||||
/// Draw a frame with the given parameters for the given filter chain.
|
/// Draw a frame with the given parameters for the given filter chain.
|
||||||
|
@ -141,7 +140,7 @@ pub unsafe extern "C" fn libra_gl_filter_chain_frame(
|
||||||
viewport: libra_viewport_t,
|
viewport: libra_viewport_t,
|
||||||
out: libra_draw_framebuffer_gl_t,
|
out: libra_draw_framebuffer_gl_t,
|
||||||
mvp: *const f32,
|
mvp: *const f32,
|
||||||
opt: *const FrameOptionsGL,
|
opt: *const FrameOptions,
|
||||||
) -> libra_error_t {
|
) -> libra_error_t {
|
||||||
ffi_body!(mut |chain| {
|
ffi_body!(mut |chain| {
|
||||||
assert_some_ptr!(mut chain);
|
assert_some_ptr!(mut chain);
|
||||||
|
@ -159,10 +158,11 @@ pub unsafe extern "C" fn libra_gl_filter_chain_frame(
|
||||||
Some(unsafe { opt.read() })
|
Some(unsafe { opt.read() })
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let framebuffer = Framebuffer::new_from_raw(out.texture, out.handle, out.format, Size::new(viewport.width, viewport.height), 1);
|
||||||
let viewport = Viewport {
|
let viewport = Viewport {
|
||||||
x: viewport.x,
|
x: viewport.x,
|
||||||
y: viewport.y,
|
y: viewport.y,
|
||||||
output: &chain.create_framebuffer_raw(out.texture, out.handle, out.format, Size::new(viewport.width, viewport.height), 1),
|
output: &framebuffer,
|
||||||
mvp,
|
mvp,
|
||||||
};
|
};
|
||||||
chain.frame(&image, &viewport, frame_count, opt.as_ref())?;
|
chain.frame(&image, &viewport, frame_count, opt.as_ref())?;
|
||||||
|
|
|
@ -19,7 +19,7 @@ use std::path::Path;
|
||||||
use crate::error::FilterChainError;
|
use crate::error::FilterChainError;
|
||||||
use crate::filter_pass::{ConstantBufferBinding, FilterPass};
|
use crate::filter_pass::{ConstantBufferBinding, FilterPass};
|
||||||
use crate::framebuffer::OwnedFramebuffer;
|
use crate::framebuffer::OwnedFramebuffer;
|
||||||
use crate::options::{FilterChainOptionsD3D11, FrameOptionsD3D11};
|
use crate::options::{FilterChainOptions, FrameOptions};
|
||||||
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;
|
||||||
|
@ -47,7 +47,7 @@ type ShaderPassMeta = (
|
||||||
>,
|
>,
|
||||||
);
|
);
|
||||||
|
|
||||||
pub struct FilterChainD3D11 {
|
pub struct FilterChain {
|
||||||
pub(crate) common: FilterCommon,
|
pub(crate) common: FilterCommon,
|
||||||
pub(crate) passes: Vec<FilterPass>,
|
pub(crate) passes: Vec<FilterPass>,
|
||||||
pub(crate) output_framebuffers: Box<[OwnedFramebuffer]>,
|
pub(crate) output_framebuffers: Box<[OwnedFramebuffer]>,
|
||||||
|
@ -74,13 +74,13 @@ pub(crate) struct FilterCommon {
|
||||||
pub disable_mipmaps: bool,
|
pub disable_mipmaps: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterChainD3D11 {
|
impl FilterChain {
|
||||||
/// Load the shader preset at the given path into a filter chain.
|
/// Load the shader preset at the given path into a filter chain.
|
||||||
pub fn load_from_path(
|
pub fn load_from_path(
|
||||||
device: &ID3D11Device,
|
device: &ID3D11Device,
|
||||||
path: impl AsRef<Path>,
|
path: impl AsRef<Path>,
|
||||||
options: Option<&FilterChainOptionsD3D11>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> error::Result<FilterChainD3D11> {
|
) -> error::Result<FilterChain> {
|
||||||
// load passes from preset
|
// load passes from preset
|
||||||
let preset = ShaderPreset::try_parse(path)?;
|
let preset = ShaderPreset::try_parse(path)?;
|
||||||
Self::load_from_preset(device, preset, options)
|
Self::load_from_preset(device, preset, options)
|
||||||
|
@ -90,16 +90,16 @@ impl FilterChainD3D11 {
|
||||||
pub fn load_from_preset(
|
pub fn load_from_preset(
|
||||||
device: &ID3D11Device,
|
device: &ID3D11Device,
|
||||||
preset: ShaderPreset,
|
preset: ShaderPreset,
|
||||||
options: Option<&FilterChainOptionsD3D11>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> error::Result<FilterChainD3D11> {
|
) -> error::Result<FilterChain> {
|
||||||
let (passes, semantics) = FilterChainD3D11::load_preset(preset.shaders, &preset.textures)?;
|
let (passes, semantics) = FilterChain::load_preset(preset.shaders, &preset.textures)?;
|
||||||
|
|
||||||
let use_deferred_context = options.map(|f| f.use_deferred_context).unwrap_or(false);
|
let use_deferred_context = options.map(|f| f.use_deferred_context).unwrap_or(false);
|
||||||
|
|
||||||
let samplers = SamplerSet::new(device)?;
|
let samplers = SamplerSet::new(device)?;
|
||||||
|
|
||||||
// initialize passes
|
// initialize passes
|
||||||
let filters = FilterChainD3D11::init_passes(device, passes, &semantics)?;
|
let filters = FilterChain::init_passes(device, passes, &semantics)?;
|
||||||
|
|
||||||
let mut immediate_context = None;
|
let mut immediate_context = None;
|
||||||
unsafe {
|
unsafe {
|
||||||
|
@ -154,15 +154,15 @@ impl FilterChainD3D11 {
|
||||||
feedback_textures.resize_with(filters.len(), || None);
|
feedback_textures.resize_with(filters.len(), || None);
|
||||||
|
|
||||||
// load luts
|
// load luts
|
||||||
let luts = FilterChainD3D11::load_luts(device, ¤t_context, &preset.textures)?;
|
let luts = FilterChain::load_luts(device, ¤t_context, &preset.textures)?;
|
||||||
|
|
||||||
let (history_framebuffers, history_textures) =
|
let (history_framebuffers, history_textures) =
|
||||||
FilterChainD3D11::init_history(device, ¤t_context, &filters)?;
|
FilterChain::init_history(device, ¤t_context, &filters)?;
|
||||||
|
|
||||||
let draw_quad = DrawQuad::new(device, ¤t_context)?;
|
let draw_quad = DrawQuad::new(device, ¤t_context)?;
|
||||||
|
|
||||||
// todo: make vbo: d3d11.c 1376
|
// todo: make vbo: d3d11.c 1376
|
||||||
Ok(FilterChainD3D11 {
|
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(),
|
||||||
|
@ -194,7 +194,7 @@ impl FilterChainD3D11 {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterChainD3D11 {
|
impl FilterChain {
|
||||||
fn create_constant_buffer(device: &ID3D11Device, size: u32) -> error::Result<ID3D11Buffer> {
|
fn create_constant_buffer(device: &ID3D11Device, size: u32) -> error::Result<ID3D11Buffer> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let buffer = device.CreateBuffer(
|
let buffer = device.CreateBuffer(
|
||||||
|
@ -247,7 +247,7 @@ impl FilterChainD3D11 {
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
let ubo_cbuffer = if let Some(ubo) = &reflection.ubo && ubo.size != 0 {
|
let ubo_cbuffer = if let Some(ubo) = &reflection.ubo && ubo.size != 0 {
|
||||||
let buffer = FilterChainD3D11::create_constant_buffer(device, ubo.size)?;
|
let buffer = FilterChain::create_constant_buffer(device, ubo.size)?;
|
||||||
Some(ConstantBufferBinding {
|
Some(ConstantBufferBinding {
|
||||||
binding: ubo.binding,
|
binding: ubo.binding,
|
||||||
size: ubo.size,
|
size: ubo.size,
|
||||||
|
@ -259,7 +259,7 @@ impl FilterChainD3D11 {
|
||||||
};
|
};
|
||||||
|
|
||||||
let push_cbuffer = if let Some(push) = &reflection.push_constant && push.size != 0 {
|
let push_cbuffer = if let Some(push) = &reflection.push_constant && push.size != 0 {
|
||||||
let buffer = FilterChainD3D11::create_constant_buffer(device, push.size)?;
|
let buffer = FilterChain::create_constant_buffer(device, push.size)?;
|
||||||
Some(ConstantBufferBinding {
|
Some(ConstantBufferBinding {
|
||||||
binding: if ubo_cbuffer.is_some() { 1 } else { 0 },
|
binding: if ubo_cbuffer.is_some() { 1 } else { 0 },
|
||||||
size: push.size,
|
size: push.size,
|
||||||
|
@ -468,7 +468,7 @@ impl FilterChainD3D11 {
|
||||||
input: D3D11ImageView,
|
input: D3D11ImageView,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
frame_count: usize,
|
frame_count: usize,
|
||||||
options: Option<&FrameOptionsD3D11>,
|
options: Option<&FrameOptions>,
|
||||||
) -> error::Result<()> {
|
) -> error::Result<()> {
|
||||||
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
||||||
if let Some(options) = options {
|
if let Some(options) = options {
|
||||||
|
@ -612,20 +612,3 @@ impl FilterChainD3D11 {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl librashader_runtime::filter_chain::FilterChain for FilterChainD3D11 {
|
|
||||||
type Error = FilterChainError;
|
|
||||||
type Input<'a> = D3D11ImageView;
|
|
||||||
type Viewport<'a> = Viewport<'a>;
|
|
||||||
type FrameOptions = FrameOptionsD3D11;
|
|
||||||
|
|
||||||
fn frame<'a>(
|
|
||||||
&mut self,
|
|
||||||
input: Self::Input<'a>,
|
|
||||||
viewport: &Self::Viewport<'a>,
|
|
||||||
frame_count: usize,
|
|
||||||
options: Option<&Self::FrameOptions>,
|
|
||||||
) -> Result<(), Self::Error> {
|
|
||||||
self.frame(input, viewport, frame_count, options)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -225,9 +225,9 @@ pub mod d3d11_hello_triangle {
|
||||||
use super::*;
|
use super::*;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
use crate::filter_chain::FilterChainD3D11;
|
use crate::filter_chain::FilterChain;
|
||||||
|
|
||||||
use crate::options::FilterChainOptionsD3D11;
|
use crate::options::FilterChainOptions;
|
||||||
use crate::texture::D3D11ImageView;
|
use crate::texture::D3D11ImageView;
|
||||||
use crate::viewport::Viewport;
|
use crate::viewport::Viewport;
|
||||||
use librashader_common::Size;
|
use librashader_common::Size;
|
||||||
|
@ -239,7 +239,7 @@ pub mod d3d11_hello_triangle {
|
||||||
pub device: ID3D11Device,
|
pub device: ID3D11Device,
|
||||||
pub context: ID3D11DeviceContext,
|
pub context: ID3D11DeviceContext,
|
||||||
pub resources: Option<Resources>,
|
pub resources: Option<Resources>,
|
||||||
pub filter: FilterChainD3D11,
|
pub filter: FilterChain,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Resources {
|
pub struct Resources {
|
||||||
|
@ -266,10 +266,10 @@ pub mod d3d11_hello_triangle {
|
||||||
impl Sample {
|
impl Sample {
|
||||||
pub(crate) fn new(
|
pub(crate) fn new(
|
||||||
filter: impl AsRef<Path>,
|
filter: impl AsRef<Path>,
|
||||||
filter_options: Option<&FilterChainOptionsD3D11>,
|
filter_options: Option<&FilterChainOptions>,
|
||||||
) -> Result<Self> {
|
) -> Result<Self> {
|
||||||
let (dxgi_factory, device, context) = create_device()?;
|
let (dxgi_factory, device, context) = create_device()?;
|
||||||
let filter = FilterChainD3D11::load_from_path(&device, filter, filter_options).unwrap();
|
let filter = FilterChain::load_from_path(&device, filter, filter_options).unwrap();
|
||||||
Ok(Sample {
|
Ok(Sample {
|
||||||
filter,
|
filter,
|
||||||
dxgi_factory,
|
dxgi_factory,
|
||||||
|
|
|
@ -17,21 +17,21 @@ mod texture;
|
||||||
mod util;
|
mod util;
|
||||||
mod viewport;
|
mod viewport;
|
||||||
|
|
||||||
pub use filter_chain::FilterChainD3D11;
|
pub use filter_chain::FilterChain;
|
||||||
pub use texture::D3D11ImageView;
|
pub use texture::D3D11ImageView;
|
||||||
pub use viewport::Viewport;
|
pub use viewport::Viewport;
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::options::FilterChainOptionsD3D11;
|
use crate::options::FilterChainOptions;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn triangle_d3d11() {
|
fn triangle_d3d11() {
|
||||||
let sample = hello_triangle::d3d11_hello_triangle::Sample::new(
|
let sample = hello_triangle::d3d11_hello_triangle::Sample::new(
|
||||||
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
||||||
// "../test/basic.slangp",
|
// "../test/basic.slangp",
|
||||||
Some(&FilterChainOptionsD3D11 {
|
Some(&FilterChainOptions {
|
||||||
use_deferred_context: false,
|
use_deferred_context: false,
|
||||||
force_no_mipmaps: false,
|
force_no_mipmaps: false,
|
||||||
}),
|
}),
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/// Options for each Direct3D11 shader frame.
|
/// Options for each Direct3D11 shader frame.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FrameOptionsD3D11 {
|
pub struct FrameOptions {
|
||||||
/// Whether or not to clear the history buffers.
|
/// Whether or not to clear the history buffers.
|
||||||
pub clear_history: bool,
|
pub clear_history: bool,
|
||||||
/// The direction of the frame. 1 should be vertical.
|
/// The direction of the frame. 1 should be vertical.
|
||||||
|
@ -11,7 +11,7 @@ pub struct FrameOptionsD3D11 {
|
||||||
/// Options for Direct3D11 filter chain creation.
|
/// Options for Direct3D11 filter chain creation.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FilterChainOptionsD3D11 {
|
pub struct FilterChainOptions {
|
||||||
/// Use a deferred context to record shader rendering state.
|
/// Use a deferred context to record shader rendering state.
|
||||||
///
|
///
|
||||||
/// The deferred context will be executed on the immediate context
|
/// The deferred context will be executed on the immediate context
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
use crate::FilterChainD3D11;
|
use crate::FilterChain;
|
||||||
use librashader_runtime::parameters::FilterChainParameters;
|
use librashader_runtime::parameters::FilterChainParameters;
|
||||||
use std::collections::hash_map::Iter;
|
use std::collections::hash_map::Iter;
|
||||||
|
|
||||||
impl FilterChainParameters for FilterChainD3D11 {
|
impl FilterChainParameters for FilterChain {
|
||||||
fn get_enabled_pass_count(&self) -> usize {
|
fn get_enabled_pass_count(&self) -> usize {
|
||||||
self.common.config.passes_enabled
|
self.common.config.passes_enabled
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ use crate::binding::{GlUniformStorage, UniformLocation, VariableLocation};
|
||||||
use crate::error::FilterChainError;
|
use crate::error::FilterChainError;
|
||||||
use crate::filter_pass::FilterPass;
|
use crate::filter_pass::FilterPass;
|
||||||
use crate::gl::{DrawQuad, Framebuffer, FramebufferInterface, GLInterface, LoadLut, UboRing};
|
use crate::gl::{DrawQuad, Framebuffer, FramebufferInterface, GLInterface, LoadLut, UboRing};
|
||||||
use crate::options::{FilterChainOptionsGL, FrameOptionsGL};
|
use crate::options::{FilterChainOptions, FrameOptions};
|
||||||
use crate::render_target::RenderTarget;
|
use crate::render_target::RenderTarget;
|
||||||
use crate::samplers::SamplerSet;
|
use crate::samplers::SamplerSet;
|
||||||
use crate::texture::Texture;
|
use crate::texture::Texture;
|
||||||
|
@ -88,20 +88,10 @@ type ShaderPassMeta = (
|
||||||
);
|
);
|
||||||
|
|
||||||
impl<T: GLInterface> FilterChainImpl<T> {
|
impl<T: GLInterface> FilterChainImpl<T> {
|
||||||
pub(crate) fn create_framebuffer_raw(
|
|
||||||
&self,
|
|
||||||
texture: GLuint,
|
|
||||||
handle: GLuint,
|
|
||||||
format: GLenum,
|
|
||||||
size: Size<u32>,
|
|
||||||
miplevels: u32,
|
|
||||||
) -> Framebuffer {
|
|
||||||
T::FramebufferInterface::new_from_raw(texture, handle, format, size, miplevels)
|
|
||||||
}
|
|
||||||
/// Load a filter chain from a pre-parsed `ShaderPreset`.
|
/// Load a filter chain from a pre-parsed `ShaderPreset`.
|
||||||
pub(crate) fn load_from_preset(
|
pub(crate) fn load_from_preset(
|
||||||
preset: ShaderPreset,
|
preset: ShaderPreset,
|
||||||
options: Option<&FilterChainOptionsGL>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> error::Result<Self> {
|
) -> error::Result<Self> {
|
||||||
let (passes, semantics) = Self::load_preset(preset.shaders, &preset.textures)?;
|
let (passes, semantics) = Self::load_preset(preset.shaders, &preset.textures)?;
|
||||||
|
|
||||||
|
@ -431,7 +421,7 @@ impl<T: GLInterface> FilterChainImpl<T> {
|
||||||
count: usize,
|
count: usize,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
input: &GLImage,
|
input: &GLImage,
|
||||||
options: Option<&FrameOptionsGL>,
|
options: Option<&FrameOptions>,
|
||||||
) -> error::Result<()> {
|
) -> error::Result<()> {
|
||||||
// limit number of passes to those enabled.
|
// limit number of passes to those enabled.
|
||||||
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
||||||
|
|
|
@ -5,7 +5,7 @@ use std::path::Path;
|
||||||
use crate::error::{FilterChainError, Result};
|
use crate::error::{FilterChainError, Result};
|
||||||
use crate::filter_chain::filter_impl::FilterChainImpl;
|
use crate::filter_chain::filter_impl::FilterChainImpl;
|
||||||
use crate::filter_chain::inner::FilterChainDispatch;
|
use crate::filter_chain::inner::FilterChainDispatch;
|
||||||
use crate::options::{FilterChainOptionsGL, FrameOptionsGL};
|
use crate::options::{FilterChainOptions, FrameOptions};
|
||||||
use crate::{Framebuffer, GLImage, Viewport};
|
use crate::{Framebuffer, GLImage, Viewport};
|
||||||
use librashader_presets::ShaderPreset;
|
use librashader_presets::ShaderPreset;
|
||||||
|
|
||||||
|
@ -16,31 +16,14 @@ mod parameters;
|
||||||
pub(crate) use filter_impl::FilterCommon;
|
pub(crate) use filter_impl::FilterCommon;
|
||||||
use librashader_common::Size;
|
use librashader_common::Size;
|
||||||
|
|
||||||
pub struct FilterChainGL {
|
pub struct FilterChain {
|
||||||
pub(in crate::filter_chain) filter: FilterChainDispatch,
|
pub(in crate::filter_chain) filter: FilterChainDispatch,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterChainGL {
|
impl FilterChain {
|
||||||
pub fn create_framebuffer_raw(
|
|
||||||
&self,
|
|
||||||
texture: GLuint,
|
|
||||||
handle: GLuint,
|
|
||||||
format: GLenum,
|
|
||||||
size: Size<u32>,
|
|
||||||
miplevels: u32,
|
|
||||||
) -> Framebuffer {
|
|
||||||
match &self.filter {
|
|
||||||
FilterChainDispatch::DirectStateAccess(p) => {
|
|
||||||
p.create_framebuffer_raw(texture, handle, format, size, miplevels)
|
|
||||||
}
|
|
||||||
FilterChainDispatch::Compatibility(p) => {
|
|
||||||
p.create_framebuffer_raw(texture, handle, format, size, miplevels)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pub fn load_from_preset(
|
pub fn load_from_preset(
|
||||||
preset: ShaderPreset,
|
preset: ShaderPreset,
|
||||||
options: Option<&FilterChainOptionsGL>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> Result<Self> {
|
) -> Result<Self> {
|
||||||
let result = catch_unwind(|| {
|
let result = catch_unwind(|| {
|
||||||
if let Some(options) = options && options.use_dsa {
|
if let Some(options) = options && options.use_dsa {
|
||||||
|
@ -63,7 +46,7 @@ impl FilterChainGL {
|
||||||
/// Load the shader preset at the given path into a filter chain.
|
/// Load the shader preset at the given path into a filter chain.
|
||||||
pub fn load_from_path(
|
pub fn load_from_path(
|
||||||
path: impl AsRef<Path>,
|
path: impl AsRef<Path>,
|
||||||
options: Option<&FilterChainOptionsGL>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> Result<Self> {
|
) -> Result<Self> {
|
||||||
// load passes from preset
|
// load passes from preset
|
||||||
let preset = ShaderPreset::try_parse(path)?;
|
let preset = ShaderPreset::try_parse(path)?;
|
||||||
|
@ -72,13 +55,14 @@ impl FilterChainGL {
|
||||||
|
|
||||||
/// Process a frame with the input image.
|
/// Process a frame with the input image.
|
||||||
///
|
///
|
||||||
/// When this frame returns, GL_FRAMEBUFFER is bound to 0 if not using Direct State Access.
|
/// When this frame returns, `GL_FRAMEBUFFER` is bound to 0 if not using Direct State Access.
|
||||||
pub(crate) fn frame(
|
/// Otherwise, it is untouched.
|
||||||
|
pub fn frame(
|
||||||
&mut self,
|
&mut self,
|
||||||
input: &GLImage,
|
input: &GLImage,
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
frame_count: usize,
|
frame_count: usize,
|
||||||
options: Option<&FrameOptionsGL>,
|
options: Option<&FrameOptions>,
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
match &mut self.filter {
|
match &mut self.filter {
|
||||||
FilterChainDispatch::DirectStateAccess(p) => {
|
FilterChainDispatch::DirectStateAccess(p) => {
|
||||||
|
@ -88,20 +72,3 @@ impl FilterChainGL {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl librashader_runtime::filter_chain::FilterChain for FilterChainGL {
|
|
||||||
type Error = FilterChainError;
|
|
||||||
type Input<'a> = &'a GLImage;
|
|
||||||
type Viewport<'a> = Viewport<'a>;
|
|
||||||
type FrameOptions = FrameOptionsGL;
|
|
||||||
|
|
||||||
fn frame<'a>(
|
|
||||||
&mut self,
|
|
||||||
input: Self::Input<'a>,
|
|
||||||
viewport: &Self::Viewport<'a>,
|
|
||||||
frame_count: usize,
|
|
||||||
options: Option<&Self::FrameOptions>,
|
|
||||||
) -> std::result::Result<(), Self::Error> {
|
|
||||||
self.frame(input, viewport, frame_count, options)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
use crate::filter_chain::filter_impl::FilterChainImpl;
|
use crate::filter_chain::filter_impl::FilterChainImpl;
|
||||||
use crate::filter_chain::inner::FilterChainDispatch;
|
use crate::filter_chain::inner::FilterChainDispatch;
|
||||||
use crate::gl::GLInterface;
|
use crate::gl::GLInterface;
|
||||||
use crate::FilterChainGL;
|
use crate::FilterChain;
|
||||||
use librashader_runtime::parameters::FilterChainParameters;
|
use librashader_runtime::parameters::FilterChainParameters;
|
||||||
use std::collections::hash_map::Iter;
|
use std::collections::hash_map::Iter;
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ impl AsMut<dyn FilterChainParameters + 'static> for FilterChainDispatch {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterChainParameters for FilterChainGL {
|
impl FilterChainParameters for FilterChain {
|
||||||
fn get_enabled_pass_count(&self) -> usize {
|
fn get_enabled_pass_count(&self) -> usize {
|
||||||
self.filter.as_ref().get_enabled_pass_count()
|
self.filter.as_ref().get_enabled_pass_count()
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,35 +9,44 @@ use librashader_presets::Scale2D;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Framebuffer {
|
pub struct Framebuffer {
|
||||||
pub image: GLuint,
|
pub(crate) image: GLuint,
|
||||||
pub handle: GLuint,
|
pub(crate) handle: GLuint,
|
||||||
pub size: Size<u32>,
|
pub(crate) size: Size<u32>,
|
||||||
pub format: GLenum,
|
pub(crate) format: GLenum,
|
||||||
pub max_levels: u32,
|
pub(crate) max_levels: u32,
|
||||||
pub mip_levels: u32,
|
pub(crate) mip_levels: u32,
|
||||||
pub is_raw: bool,
|
pub(crate) is_raw: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Framebuffer {
|
impl Framebuffer {
|
||||||
pub fn new<T: FramebufferInterface>(max_levels: u32) -> Self {
|
pub(crate) fn new<T: FramebufferInterface>(max_levels: u32) -> Self {
|
||||||
T::new(max_levels)
|
T::new(max_levels)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new_from_raw<T: FramebufferInterface>(
|
/// Create a framebuffer from an already initialized texture and framebuffer.
|
||||||
|
pub fn new_from_raw(
|
||||||
texture: GLuint,
|
texture: GLuint,
|
||||||
handle: GLuint,
|
fbo: GLuint,
|
||||||
format: GLenum,
|
format: GLenum,
|
||||||
size: Size<u32>,
|
size: Size<u32>,
|
||||||
mip_levels: u32,
|
miplevels: u32,
|
||||||
) -> Self {
|
) -> Framebuffer {
|
||||||
T::new_from_raw(texture, handle, format, size, mip_levels)
|
Framebuffer {
|
||||||
|
image: texture,
|
||||||
|
size,
|
||||||
|
format,
|
||||||
|
max_levels: miplevels,
|
||||||
|
mip_levels: miplevels,
|
||||||
|
handle: fbo,
|
||||||
|
is_raw: true,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn clear<T: FramebufferInterface, const REBIND: bool>(&self) {
|
pub(crate) fn clear<T: FramebufferInterface, const REBIND: bool>(&self) {
|
||||||
T::clear::<REBIND>(self)
|
T::clear::<REBIND>(self)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn scale<T: FramebufferInterface>(
|
pub(crate) fn scale<T: FramebufferInterface>(
|
||||||
&mut self,
|
&mut self,
|
||||||
scaling: Scale2D,
|
scaling: Scale2D,
|
||||||
format: ImageFormat,
|
format: ImageFormat,
|
||||||
|
@ -49,11 +58,11 @@ impl Framebuffer {
|
||||||
T::scale(self, scaling, format, viewport, original, source, mipmap)
|
T::scale(self, scaling, format, viewport, original, source, mipmap)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn copy_from<T: FramebufferInterface>(&mut self, image: &GLImage) -> Result<()> {
|
pub(crate) fn copy_from<T: FramebufferInterface>(&mut self, image: &GLImage) -> Result<()> {
|
||||||
T::copy_from(self, image)
|
T::copy_from(self, image)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn as_texture(&self, filter: FilterMode, wrap_mode: WrapMode) -> Texture {
|
pub(crate) fn as_texture(&self, filter: FilterMode, wrap_mode: WrapMode) -> Texture {
|
||||||
Texture {
|
Texture {
|
||||||
image: GLImage {
|
image: GLImage {
|
||||||
handle: self.image,
|
handle: self.image,
|
||||||
|
@ -70,6 +79,10 @@ impl Framebuffer {
|
||||||
|
|
||||||
impl Drop for Framebuffer {
|
impl Drop for Framebuffer {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
|
if self.is_raw {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
if self.handle != 0 {
|
if self.handle != 0 {
|
||||||
gl::DeleteFramebuffers(1, &self.handle);
|
gl::DeleteFramebuffers(1, &self.handle);
|
||||||
|
|
|
@ -34,23 +34,6 @@ impl FramebufferInterface for Gl3Framebuffer {
|
||||||
is_raw: false,
|
is_raw: false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn new_from_raw(
|
|
||||||
texture: GLuint,
|
|
||||||
handle: GLuint,
|
|
||||||
format: GLenum,
|
|
||||||
size: Size<u32>,
|
|
||||||
miplevels: u32,
|
|
||||||
) -> Framebuffer {
|
|
||||||
Framebuffer {
|
|
||||||
image: texture,
|
|
||||||
size,
|
|
||||||
format,
|
|
||||||
max_levels: miplevels,
|
|
||||||
mip_levels: miplevels,
|
|
||||||
handle,
|
|
||||||
is_raw: true,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn scale(
|
fn scale(
|
||||||
fb: &mut Framebuffer,
|
fb: &mut Framebuffer,
|
||||||
|
|
|
@ -7,7 +7,7 @@ use glfw::{Context, Glfw, Window, WindowEvent};
|
||||||
use gl::types::{GLchar, GLenum, GLint, GLsizei, GLuint};
|
use gl::types::{GLchar, GLenum, GLint, GLsizei, GLuint};
|
||||||
use librashader_common::Size;
|
use librashader_common::Size;
|
||||||
|
|
||||||
use crate::filter_chain::FilterChainGL;
|
use crate::filter_chain::FilterChain;
|
||||||
use crate::framebuffer::GLImage;
|
use crate::framebuffer::GLImage;
|
||||||
use crate::gl::gl3::CompatibilityGL;
|
use crate::gl::gl3::CompatibilityGL;
|
||||||
use crate::gl::{FramebufferInterface, GLInterface};
|
use crate::gl::{FramebufferInterface, GLInterface};
|
||||||
|
@ -268,7 +268,7 @@ pub fn do_loop(
|
||||||
events: Receiver<(f64, WindowEvent)>,
|
events: Receiver<(f64, WindowEvent)>,
|
||||||
triangle_program: GLuint,
|
triangle_program: GLuint,
|
||||||
triangle_vao: GLuint,
|
triangle_vao: GLuint,
|
||||||
filter: &mut FilterChainGL,
|
filter: &mut FilterChain,
|
||||||
) {
|
) {
|
||||||
let mut framecount = 0;
|
let mut framecount = 0;
|
||||||
let mut rendered_framebuffer = 0;
|
let mut rendered_framebuffer = 0;
|
||||||
|
|
|
@ -32,23 +32,6 @@ impl FramebufferInterface for Gl46Framebuffer {
|
||||||
is_raw: false,
|
is_raw: false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fn new_from_raw(
|
|
||||||
texture: GLuint,
|
|
||||||
handle: GLuint,
|
|
||||||
format: GLenum,
|
|
||||||
size: Size<u32>,
|
|
||||||
miplevels: u32,
|
|
||||||
) -> Framebuffer {
|
|
||||||
Framebuffer {
|
|
||||||
image: texture,
|
|
||||||
size,
|
|
||||||
format,
|
|
||||||
max_levels: miplevels,
|
|
||||||
mip_levels: miplevels,
|
|
||||||
handle,
|
|
||||||
is_raw: true,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn scale(
|
fn scale(
|
||||||
fb: &mut Framebuffer,
|
fb: &mut Framebuffer,
|
||||||
|
|
|
@ -7,7 +7,7 @@ use glfw::{Context, Glfw, Window, WindowEvent};
|
||||||
use gl::types::{GLchar, GLenum, GLint, GLsizei, GLuint};
|
use gl::types::{GLchar, GLenum, GLint, GLsizei, GLuint};
|
||||||
use librashader_common::Size;
|
use librashader_common::Size;
|
||||||
|
|
||||||
use crate::filter_chain::FilterChainGL;
|
use crate::filter_chain::FilterChain;
|
||||||
use crate::framebuffer::GLImage;
|
use crate::framebuffer::GLImage;
|
||||||
use crate::gl::gl46::DirectStateAccessGL;
|
use crate::gl::gl46::DirectStateAccessGL;
|
||||||
use crate::gl::{FramebufferInterface, GLInterface};
|
use crate::gl::{FramebufferInterface, GLInterface};
|
||||||
|
@ -259,7 +259,7 @@ pub fn do_loop(
|
||||||
events: Receiver<(f64, WindowEvent)>,
|
events: Receiver<(f64, WindowEvent)>,
|
||||||
triangle_program: GLuint,
|
triangle_program: GLuint,
|
||||||
triangle_vao: GLuint,
|
triangle_vao: GLuint,
|
||||||
filter: &mut FilterChainGL,
|
filter: &mut FilterChain,
|
||||||
) {
|
) {
|
||||||
let mut framecount = 0;
|
let mut framecount = 0;
|
||||||
let mut rendered_framebuffer = 0;
|
let mut rendered_framebuffer = 0;
|
||||||
|
|
|
@ -38,13 +38,6 @@ pub trait UboRing<const SIZE: usize> {
|
||||||
|
|
||||||
pub trait FramebufferInterface {
|
pub trait FramebufferInterface {
|
||||||
fn new(max_levels: u32) -> Framebuffer;
|
fn new(max_levels: u32) -> Framebuffer;
|
||||||
fn new_from_raw(
|
|
||||||
texture: GLuint,
|
|
||||||
handle: GLuint,
|
|
||||||
format: GLenum,
|
|
||||||
size: Size<u32>,
|
|
||||||
miplevels: u32,
|
|
||||||
) -> Framebuffer;
|
|
||||||
fn scale(
|
fn scale(
|
||||||
fb: &mut Framebuffer,
|
fb: &mut Framebuffer,
|
||||||
scaling: Scale2D,
|
scaling: Scale2D,
|
||||||
|
|
|
@ -18,22 +18,22 @@ pub mod options;
|
||||||
mod viewport;
|
mod viewport;
|
||||||
|
|
||||||
pub use crate::gl::Framebuffer;
|
pub use crate::gl::Framebuffer;
|
||||||
pub use filter_chain::FilterChainGL;
|
pub use filter_chain::FilterChain;
|
||||||
pub use framebuffer::GLImage;
|
pub use framebuffer::GLImage;
|
||||||
pub use viewport::Viewport;
|
pub use viewport::Viewport;
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::filter_chain::FilterChainGL;
|
use crate::filter_chain::FilterChain;
|
||||||
use crate::options::FilterChainOptionsGL;
|
use crate::options::FilterChainOptions;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn triangle_gl() {
|
fn triangle_gl() {
|
||||||
let (glfw, window, events, shader, vao) = gl::gl3::hello_triangle::setup();
|
let (glfw, window, events, shader, vao) = gl::gl3::hello_triangle::setup();
|
||||||
let mut filter = FilterChainGL::load_from_path(
|
let mut filter = FilterChain::load_from_path(
|
||||||
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
||||||
Some(&FilterChainOptionsGL {
|
Some(&FilterChainOptions {
|
||||||
gl_version: 0,
|
gl_version: 0,
|
||||||
use_dsa: false,
|
use_dsa: false,
|
||||||
force_no_mipmaps: false,
|
force_no_mipmaps: false,
|
||||||
|
@ -47,10 +47,10 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn triangle_gl46() {
|
fn triangle_gl46() {
|
||||||
let (glfw, window, events, shader, vao) = gl::gl46::hello_triangle::setup();
|
let (glfw, window, events, shader, vao) = gl::gl46::hello_triangle::setup();
|
||||||
let mut filter = FilterChainGL::load_from_path(
|
let mut filter = FilterChain::load_from_path(
|
||||||
// "../test/slang-shaders/vhs/VHSPro.slangp",
|
// "../test/slang-shaders/vhs/VHSPro.slangp",
|
||||||
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
"../test/slang-shaders/bezel/Mega_Bezel/Presets/MBZ__0__SMOOTH-ADV.slangp",
|
||||||
Some(&FilterChainOptionsGL {
|
Some(&FilterChainOptions {
|
||||||
gl_version: 0,
|
gl_version: 0,
|
||||||
use_dsa: true,
|
use_dsa: true,
|
||||||
force_no_mipmaps: false,
|
force_no_mipmaps: false,
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/// Options for each OpenGL shader frame.
|
/// Options for each OpenGL shader frame.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FrameOptionsGL {
|
pub struct FrameOptions {
|
||||||
/// Whether or not to clear the history buffers.
|
/// Whether or not to clear the history buffers.
|
||||||
pub clear_history: bool,
|
pub clear_history: bool,
|
||||||
/// The direction of the frame. 1 should be vertical.
|
/// The direction of the frame. 1 should be vertical.
|
||||||
|
@ -11,7 +11,7 @@ pub struct FrameOptionsGL {
|
||||||
/// Options for filter chain creation.
|
/// Options for filter chain creation.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FilterChainOptionsGL {
|
pub struct FilterChainOptions {
|
||||||
/// The GLSL version. Should be at least `330`.
|
/// The GLSL version. Should be at least `330`.
|
||||||
pub gl_version: u16,
|
pub gl_version: u16,
|
||||||
/// Whether or not to use the Direct State Access APIs. Only available on OpenGL 4.5+.
|
/// Whether or not to use the Direct State Access APIs. Only available on OpenGL 4.5+.
|
||||||
|
|
|
@ -27,7 +27,7 @@ use librashader_runtime::uniforms::UniformStorage;
|
||||||
use rustc_hash::FxHashMap;
|
use rustc_hash::FxHashMap;
|
||||||
use std::collections::VecDeque;
|
use std::collections::VecDeque;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
use crate::options::{FilterChainOptionsVulkan, FrameOptionsVulkan};
|
use crate::options::{FilterChainOptions, FrameOptions};
|
||||||
|
|
||||||
pub struct Vulkan {
|
pub struct Vulkan {
|
||||||
pub(crate) device: ash::Device,
|
pub(crate) device: ash::Device,
|
||||||
|
@ -44,7 +44,7 @@ type ShaderPassMeta = (
|
||||||
|
|
||||||
/// A collection of handles needed to access the Vulkan instance.
|
/// A collection of handles needed to access the Vulkan instance.
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct VulkanInfo {
|
pub struct VulkanInstance {
|
||||||
/// A `VkDevice` handle.
|
/// A `VkDevice` handle.
|
||||||
pub device: vk::Device,
|
pub device: vk::Device,
|
||||||
/// A `VkInstance` handle.
|
/// A `VkInstance` handle.
|
||||||
|
@ -55,10 +55,10 @@ pub struct VulkanInfo {
|
||||||
pub get_instance_proc_addr: vk::PFN_vkGetInstanceProcAddr,
|
pub get_instance_proc_addr: vk::PFN_vkGetInstanceProcAddr,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TryFrom<VulkanInfo> for Vulkan {
|
impl TryFrom<VulkanInstance> for Vulkan {
|
||||||
type Error = FilterChainError;
|
type Error = FilterChainError;
|
||||||
|
|
||||||
fn try_from(vulkan: VulkanInfo) -> Result<Self, FilterChainError> {
|
fn try_from(vulkan: VulkanInstance) -> Result<Self, FilterChainError> {
|
||||||
unsafe {
|
unsafe {
|
||||||
let instance = ash::Instance::load(
|
let instance = ash::Instance::load(
|
||||||
&vk::StaticFn {
|
&vk::StaticFn {
|
||||||
|
@ -179,7 +179,7 @@ impl FilterChainVulkan {
|
||||||
pub fn load_from_path(
|
pub fn load_from_path(
|
||||||
vulkan: impl TryInto<Vulkan, Error = FilterChainError>,
|
vulkan: impl TryInto<Vulkan, Error = FilterChainError>,
|
||||||
path: impl AsRef<Path>,
|
path: impl AsRef<Path>,
|
||||||
options: Option<&FilterChainOptionsVulkan>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> error::Result<FilterChainVulkan> {
|
) -> error::Result<FilterChainVulkan> {
|
||||||
// load passes from preset
|
// load passes from preset
|
||||||
let preset = ShaderPreset::try_parse(path)?;
|
let preset = ShaderPreset::try_parse(path)?;
|
||||||
|
@ -189,7 +189,7 @@ impl FilterChainVulkan {
|
||||||
pub fn load_from_preset(
|
pub fn load_from_preset(
|
||||||
vulkan: impl TryInto<Vulkan, Error = FilterChainError>,
|
vulkan: impl TryInto<Vulkan, Error = FilterChainError>,
|
||||||
preset: ShaderPreset,
|
preset: ShaderPreset,
|
||||||
options: Option<&FilterChainOptionsVulkan>,
|
options: Option<&FilterChainOptions>,
|
||||||
) -> error::Result<FilterChainVulkan> {
|
) -> error::Result<FilterChainVulkan> {
|
||||||
let (passes, semantics) = FilterChainVulkan::load_preset(preset.shaders, &preset.textures)?;
|
let (passes, semantics) = FilterChainVulkan::load_preset(preset.shaders, &preset.textures)?;
|
||||||
let device = vulkan.try_into()?;
|
let device = vulkan.try_into()?;
|
||||||
|
@ -565,7 +565,7 @@ impl FilterChainVulkan {
|
||||||
viewport: &Viewport,
|
viewport: &Viewport,
|
||||||
input: &VulkanImage,
|
input: &VulkanImage,
|
||||||
cmd: vk::CommandBuffer,
|
cmd: vk::CommandBuffer,
|
||||||
options: Option<FrameOptionsVulkan>,
|
options: Option<FrameOptions>,
|
||||||
) -> error::Result<FrameIntermediates> {
|
) -> error::Result<FrameIntermediates> {
|
||||||
// limit number of passes to those enabled.
|
// limit number of passes to those enabled.
|
||||||
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
let passes = &mut self.passes[0..self.common.config.passes_enabled];
|
||||||
|
|
|
@ -23,7 +23,7 @@ mod vulkan_state;
|
||||||
pub use filter_chain::FrameIntermediates;
|
pub use filter_chain::FrameIntermediates;
|
||||||
pub use filter_chain::FilterChainVulkan;
|
pub use filter_chain::FilterChainVulkan;
|
||||||
pub use filter_chain::Vulkan;
|
pub use filter_chain::Vulkan;
|
||||||
pub use filter_chain::VulkanInfo;
|
pub use filter_chain::VulkanInstance;
|
||||||
pub use texture::VulkanImage;
|
pub use texture::VulkanImage;
|
||||||
pub use viewport::Viewport;
|
pub use viewport::Viewport;
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/// Options for each Vulkan shader frame.
|
/// Options for each Vulkan shader frame.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FrameOptionsVulkan {
|
pub struct FrameOptions {
|
||||||
/// Whether or not to clear the history buffers.
|
/// Whether or not to clear the history buffers.
|
||||||
pub clear_history: bool,
|
pub clear_history: bool,
|
||||||
/// The direction of the frame. 1 should be vertical.
|
/// The direction of the frame. 1 should be vertical.
|
||||||
|
@ -11,7 +11,7 @@ pub struct FrameOptionsVulkan {
|
||||||
/// Options for filter chain creation.
|
/// Options for filter chain creation.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct FilterChainOptionsVulkan {
|
pub struct FilterChainOptions {
|
||||||
/// Whether or not to explicitly disable mipmap generation regardless of shader preset settings.
|
/// Whether or not to explicitly disable mipmap generation regardless of shader preset settings.
|
||||||
pub force_no_mipmaps: bool,
|
pub force_no_mipmaps: bool,
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
use std::error::Error;
|
|
||||||
|
|
||||||
/// Common trait for filter chains.
|
|
||||||
pub trait FilterChain {
|
|
||||||
/// The error type for a filter chain.
|
|
||||||
type Error: Error;
|
|
||||||
|
|
||||||
/// The type for the input surface to apply a filter chain to.
|
|
||||||
type Input<'a>;
|
|
||||||
|
|
||||||
/// The type for the output surface, including viewport information, to output the result of a
|
|
||||||
/// filter chain to.
|
|
||||||
type Viewport<'a>;
|
|
||||||
|
|
||||||
/// The per-frame options to pass to the filter chain.
|
|
||||||
type FrameOptions;
|
|
||||||
|
|
||||||
/// Process a frame with the input image.
|
|
||||||
///
|
|
||||||
/// The output image should be written to the viewport. It is expected that the viewport
|
|
||||||
/// contains some sort of handle with interior mutability to a GPU buffer, e.g. a
|
|
||||||
/// `RenderTargetView`, `vkImage`, or a texture `GLuint`.
|
|
||||||
fn frame<'a>(
|
|
||||||
&mut self,
|
|
||||||
input: Self::Input<'a>,
|
|
||||||
viewport: &Self::Viewport<'a>,
|
|
||||||
frame_count: usize,
|
|
||||||
options: Option<&Self::FrameOptions>,
|
|
||||||
) -> Result<(), Self::Error>;
|
|
||||||
}
|
|
|
@ -13,9 +13,6 @@ pub mod uniforms;
|
||||||
/// Parameter reflection helpers and traits.
|
/// Parameter reflection helpers and traits.
|
||||||
pub mod parameters;
|
pub mod parameters;
|
||||||
|
|
||||||
/// Filter chain helpers and traits.
|
|
||||||
pub mod filter_chain;
|
|
||||||
|
|
||||||
/// Image handling helpers.
|
/// Image handling helpers.
|
||||||
pub mod image;
|
pub mod image;
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
//!
|
//!
|
||||||
//! ## Usage
|
//! ## Usage
|
||||||
//! The core objects in librashader are the [`ShaderPreset`](crate::presets::ShaderPreset) and the
|
//! The core objects in librashader are the [`ShaderPreset`](crate::presets::ShaderPreset) and the
|
||||||
//! [`FilterChain`](crate::runtime::FilterChain), the implementation of which is runtime dependent.
|
//! filter chain implementations.
|
||||||
//!
|
//!
|
||||||
//! The basic workflow involves parsing a `ShaderPreset`, which can then be used to construct
|
//! The basic workflow involves parsing a `ShaderPreset`, which can then be used to construct
|
||||||
//! a `FilterChain`. All shaders will then be compiled, after which `FilterChain::frame` can be
|
//! a `FilterChain`. All shaders will then be compiled, after which `FilterChain::frame` can be
|
||||||
|
@ -91,7 +91,6 @@ pub mod reflect {
|
||||||
/// Shader runtimes to execute a filter chain on a GPU surface.
|
/// Shader runtimes to execute a filter chain on a GPU surface.
|
||||||
#[cfg(feature = "runtime")]
|
#[cfg(feature = "runtime")]
|
||||||
pub mod runtime {
|
pub mod runtime {
|
||||||
pub use librashader_runtime::filter_chain::FilterChain;
|
|
||||||
pub use librashader_runtime::parameters::FilterChainParameters;
|
pub use librashader_runtime::parameters::FilterChainParameters;
|
||||||
|
|
||||||
#[cfg(feature = "gl")]
|
#[cfg(feature = "gl")]
|
||||||
|
|
Loading…
Reference in a new issue