rt: apply filter settings before drawing frame
This commit is contained in:
parent
da2fb7adca
commit
18e1f758cd
3 changed files with 19 additions and 6 deletions
|
@ -505,6 +505,8 @@ impl FilterChainD3D11 {
|
|||
let (pass, last) = passes.split_at_mut(passes_len - 1);
|
||||
|
||||
for (index, pass) in pass.iter_mut().enumerate() {
|
||||
source.filter = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
let target = &self.output_framebuffers[index];
|
||||
let size = target.size;
|
||||
pass.draw(
|
||||
|
@ -537,6 +539,7 @@ impl FilterChainD3D11 {
|
|||
assert_eq!(last.len(), 1);
|
||||
if let Some(pass) = last.iter_mut().next() {
|
||||
source.filter = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
pass.draw(
|
||||
passes_len - 1,
|
||||
&self.common,
|
||||
|
|
|
@ -472,6 +472,10 @@ impl<T: GLInterface> FilterChainImpl<T> {
|
|||
|
||||
for (index, pass) in pass.iter_mut().enumerate() {
|
||||
let target = &self.output_framebuffers[index];
|
||||
source.filter = pass.config.filter;
|
||||
source.mip_filter = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
|
||||
pass.draw(
|
||||
index,
|
||||
&self.common,
|
||||
|
@ -497,6 +501,7 @@ impl<T: GLInterface> FilterChainImpl<T> {
|
|||
if let Some(pass) = last.iter_mut().next() {
|
||||
source.filter = pass.config.filter;
|
||||
source.mip_filter = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
|
||||
pass.draw(
|
||||
passes_len - 1,
|
||||
|
|
|
@ -641,7 +641,7 @@ impl FilterChainVulkan {
|
|||
mip_filter: filter,
|
||||
};
|
||||
|
||||
let mut source = &original;
|
||||
let mut source = original.clone();
|
||||
|
||||
// swap output and feedback **before** recording command buffers
|
||||
std::mem::swap(
|
||||
|
@ -712,6 +712,10 @@ impl FilterChainVulkan {
|
|||
|
||||
for (index, pass) in pass.iter_mut().enumerate() {
|
||||
let target = &self.output_framebuffers[index];
|
||||
source.filter_mode = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
source.mip_filter = pass.config.filter;
|
||||
|
||||
let out = RenderTarget {
|
||||
x: 0.0,
|
||||
y: 0.0,
|
||||
|
@ -731,7 +735,7 @@ impl FilterChainVulkan {
|
|||
frame_direction,
|
||||
viewport,
|
||||
&original,
|
||||
source,
|
||||
&source,
|
||||
&out,
|
||||
)?;
|
||||
|
||||
|
@ -741,7 +745,7 @@ impl FilterChainVulkan {
|
|||
out.output.end_pass(cmd);
|
||||
}
|
||||
|
||||
source = self.common.output_inputs[index].as_ref().unwrap();
|
||||
source = self.common.output_inputs[index].clone().unwrap();
|
||||
intermediates.dispose_outputs(out.output);
|
||||
intermediates.dispose_framebuffers(residual_fb);
|
||||
}
|
||||
|
@ -749,8 +753,9 @@ impl FilterChainVulkan {
|
|||
// try to hint the optimizer
|
||||
assert_eq!(last.len(), 1);
|
||||
if let Some(pass) = last.iter_mut().next() {
|
||||
// source.filter_mode = pass.config.filter;
|
||||
// source.mip_filter = pass.config.filter;
|
||||
source.filter_mode = pass.config.filter;
|
||||
source.wrap_mode = pass.config.wrap_mode;
|
||||
source.mip_filter = pass.config.filter;
|
||||
|
||||
let out = RenderTarget {
|
||||
x: viewport.x,
|
||||
|
@ -767,7 +772,7 @@ impl FilterChainVulkan {
|
|||
0,
|
||||
viewport,
|
||||
&original,
|
||||
source,
|
||||
&source,
|
||||
&out,
|
||||
)?;
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue