gl: buffer building
This commit is contained in:
parent
d37fc0ccb5
commit
888d7be50f
1 changed files with 99 additions and 26 deletions
|
@ -21,6 +21,7 @@ pub struct FilterPass {
|
|||
pub locations: FxHashMap<String, VariableLocation>,
|
||||
pub framebuffer: Framebuffer,
|
||||
pub feedback_framebuffer: Framebuffer,
|
||||
|
||||
}
|
||||
|
||||
impl FilterPass {
|
||||
|
@ -29,26 +30,58 @@ impl FilterPass {
|
|||
buffer.copy_from_slice(mvp);
|
||||
}
|
||||
|
||||
fn build_vec4(buffer: &mut [u8], width: u32, height: u32) {
|
||||
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32];
|
||||
let vec4 = bytemuck::cast_slice(&vec4);
|
||||
|
||||
buffer.copy_from_slice(vec4);
|
||||
}
|
||||
|
||||
fn build_vec4_uniform(location: Location<GLint>, width: u32, height: u32) {
|
||||
let vec4 = [width as f32, height as f32, 1.0 / width as f32, 1.0/ height as f32];
|
||||
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());
|
||||
fn build_vec4(location: Location<GLint>, buffer: &mut [u8], size: Size) {
|
||||
let vec4 = [size.width as f32, size.height as f32, 1.0 / size.width as f32, 1.0/ size.height as f32];
|
||||
if location.fragment >= 0 || location.vertex >= 0 {
|
||||
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) {
|
||||
let mvp = mvp.unwrap_or(&[
|
||||
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) {
|
||||
let location = self.locations.get(&variable.id).expect("variable did not have location mapped").location();
|
||||
if location.fragment >= 0 || location.vertex >= 0 {
|
||||
FilterPass::build_vec4_uniform(location, 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.width, fb_size.height)
|
||||
}
|
||||
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], fb_size)
|
||||
//
|
||||
// if location.fragment >= 0 || location.vertex >= 0 {
|
||||
// FilterPass::build_vec4_uniform(location, fb_size);
|
||||
// } 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…
Add table
Reference in a new issue