gl: buffer building
This commit is contained in:
parent
d37fc0ccb5
commit
888d7be50f
|
@ -21,6 +21,7 @@ pub struct FilterPass {
|
||||||
pub locations: FxHashMap<String, VariableLocation>,
|
pub locations: FxHashMap<String, VariableLocation>,
|
||||||
pub framebuffer: Framebuffer,
|
pub framebuffer: Framebuffer,
|
||||||
pub feedback_framebuffer: Framebuffer,
|
pub feedback_framebuffer: Framebuffer,
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl FilterPass {
|
impl FilterPass {
|
||||||
|
@ -29,26 +30,58 @@ impl FilterPass {
|
||||||
buffer.copy_from_slice(mvp);
|
buffer.copy_from_slice(mvp);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_vec4(buffer: &mut [u8], width: u32, height: u32) {
|
fn build_vec4(location: Location<GLint>, buffer: &mut [u8], size: Size) {
|
||||||
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32];
|
let vec4 = [size.width as f32, size.height as f32, 1.0 / size.width as f32, 1.0/ size.height as f32];
|
||||||
let vec4 = bytemuck::cast_slice(&vec4);
|
if location.fragment >= 0 || location.vertex >= 0 {
|
||||||
|
unsafe {
|
||||||
buffer.copy_from_slice(vec4);
|
if location.vertex >= 0 {
|
||||||
}
|
gl::Uniform4fv(location.vertex, 1, vec4.as_ptr());
|
||||||
|
}
|
||||||
fn build_vec4_uniform(location: Location<GLint>, width: u32, height: u32) {
|
if location.fragment >= 0 {
|
||||||
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32];
|
gl::Uniform4fv(location.fragment, 1, vec4.as_ptr());
|
||||||
unsafe {
|
}
|
||||||
if location.vertex >= 0 {
|
|
||||||
gl::Uniform4fv(location.vertex, 1, vec4.as_ptr());
|
|
||||||
}
|
|
||||||
if location.fragment >= 0 {
|
|
||||||
gl::Uniform4fv(location.fragment, 1, vec4.as_ptr());
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
let vec4 = bytemuck::cast_slice(&vec4);
|
||||||
|
buffer.copy_from_slice(vec4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_semantics(&mut self, mvp: Option<&[f32]>, fb_size: Size, vp_size: Size, original: &Texture, source: &Texture) {
|
#[inline(always)]
|
||||||
|
fn build_uniform<T>(location: Location<GLint>, buffer: &mut [u8], value: T, glfn: unsafe fn(GLint, T) -> ())
|
||||||
|
where T: Copy, T: bytemuck::Pod
|
||||||
|
{
|
||||||
|
if location.fragment >= 0 || location.vertex >= 0 {
|
||||||
|
unsafe {
|
||||||
|
if location.vertex >= 0 {
|
||||||
|
glfn(location.vertex, value);
|
||||||
|
}
|
||||||
|
if location.fragment >= 0 {
|
||||||
|
glfn(location.fragment, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
let mut buffer = bytemuck::cast_slice_mut(buffer);
|
||||||
|
buffer[0] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn build_uint(location: Location<GLint>, buffer: &mut [u8], value: u32) {
|
||||||
|
Self::build_uniform(location, buffer, value, gl::Uniform1ui)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn build_sint(location: Location<GLint>, buffer: &mut [u8], value: i32) {
|
||||||
|
Self::build_uniform(location, buffer, value, gl::Uniform1i)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn build_float(location: Location<GLint>, buffer: &mut [u8], value: f32) {
|
||||||
|
Self::build_uniform(location, buffer, value, gl::Uniform1f)
|
||||||
|
}
|
||||||
|
|
||||||
|
// todo: build vec4 texture
|
||||||
|
|
||||||
|
// framecount should be pre-modded
|
||||||
|
fn build_semantics(&mut self, mvp: Option<&[f32]>, frame_count: u32, frame_direction: u32, fb_size: Size, vp_size: Size, original: &Texture, source: &Texture) {
|
||||||
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::MVP) {
|
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::MVP) {
|
||||||
let mvp = mvp.unwrap_or(&[
|
let mvp = mvp.unwrap_or(&[
|
||||||
2f32, 0.0, 0.0, 0.0,
|
2f32, 0.0, 0.0, 0.0,
|
||||||
|
@ -66,16 +99,56 @@ impl FilterPass {
|
||||||
|
|
||||||
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::Output) {
|
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::Output) {
|
||||||
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
||||||
if location.fragment >= 0 || location.vertex >= 0 {
|
let (buffer, offset) = match variable.offset {
|
||||||
FilterPass::build_vec4_uniform(location, fb_size.width, fb_size.height);
|
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
||||||
} else {
|
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
||||||
let (buffer, offset) = match variable.offset {
|
};
|
||||||
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
FilterPass::build_vec4(location, &mut buffer[offset..][..4], fb_size)
|
||||||
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
//
|
||||||
};
|
// if location.fragment >= 0 || location.vertex >= 0 {
|
||||||
|
// FilterPass::build_vec4_uniform(location, fb_size);
|
||||||
FilterPass::build_vec4(&mut buffer[offset..][..4], fb_size.width, fb_size.height)
|
// } else {
|
||||||
}
|
// let (buffer, offset) = match variable.offset {
|
||||||
|
// MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
||||||
|
// MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
||||||
|
// };
|
||||||
|
//
|
||||||
|
// FilterPass::build_vec4(&mut buffer[offset..][..4], fb_size)
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FinalViewport) {
|
||||||
|
// todo: do all variables have location..?
|
||||||
|
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
||||||
|
let (buffer, offset) = match variable.offset {
|
||||||
|
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
||||||
|
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
||||||
|
};
|
||||||
|
FilterPass::build_vec4(location, &mut buffer[offset..][..4], vp_size)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FrameCount) {
|
||||||
|
// todo: do all variables have location..?
|
||||||
|
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
||||||
|
let (buffer, offset) = match variable.offset {
|
||||||
|
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
||||||
|
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
||||||
|
};
|
||||||
|
FilterPass::build_uint(location, &mut buffer[offset..][..4], frame_count)
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Some(variable) = self.reflection.meta.variable_meta.get(&VariableSemantics::FrameDirection) {
|
||||||
|
// todo: do all variables have location..?
|
||||||
|
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
||||||
|
let (buffer, offset) = match variable.offset {
|
||||||
|
MemberOffset::Ubo(offset) => (&mut self.uniform_buffer, offset),
|
||||||
|
MemberOffset::PushConstant(offset) => (&mut self.push_buffer, offset)
|
||||||
|
};
|
||||||
|
|
||||||
|
FilterPass::build_uint(location, &mut buffer[offset..][..4], frame_direction)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue