0adf3505ec
This doesn't cause an API break in the C API but we don't actually make an attempt to verify that it's safe to access any of the device contexts.
29 lines
773 B
Rust
29 lines
773 B
Rust
use ash::prelude::VkResult;
|
|
use ash::vk;
|
|
|
|
pub struct VulkanFramebuffer {
|
|
pub framebuffer: vk::Framebuffer,
|
|
}
|
|
|
|
impl VulkanFramebuffer {
|
|
pub fn new(
|
|
device: &ash::Device,
|
|
image_view: &vk::ImageView,
|
|
render_pass: &vk::RenderPass,
|
|
width: u32,
|
|
height: u32,
|
|
) -> VkResult<VulkanFramebuffer> {
|
|
let attachments = &[*image_view];
|
|
let framebuffer_info = vk::FramebufferCreateInfo::builder()
|
|
.render_pass(*render_pass)
|
|
.attachments(attachments)
|
|
.width(width)
|
|
.height(height)
|
|
.layers(1);
|
|
|
|
unsafe {
|
|
let framebuffer = device.create_framebuffer(&framebuffer_info, None)?;
|
|
Ok(VulkanFramebuffer { framebuffer })
|
|
}
|
|
}
|
|
}
|