ULRE/example/Vulkan/VKCommandBuffer.cpp

105 lines
2.8 KiB
C++
Raw Normal View History

#include"VKCommandBuffer.h"
2019-04-18 22:10:24 +08:00
#include"VKRenderPass.h"
#include"VKFramebuffer.h"
#include"VKPipeline.h"
#include"VKPipelineLayout.h"
2019-04-18 22:10:24 +08:00
#include"VKVertexInput.h"
#include"VKDescriptorSets.h"
VK_NAMESPACE_BEGIN
2019-04-20 02:28:57 +08:00
CommandBuffer::CommandBuffer(VkDevice dev,const VkExtent2D &extent,VkCommandPool cp,VkCommandBuffer cb)
2019-04-18 22:10:24 +08:00
{
device=dev;
pool=cp;
cmd_buf=cb;
clear_values[0].color.float32[0] = 0.2f;
clear_values[0].color.float32[1] = 0.2f;
clear_values[0].color.float32[2] = 0.2f;
clear_values[0].color.float32[3] = 0.2f;
clear_values[1].depthStencil.depth = 1.0f;
clear_values[1].depthStencil.stencil = 0;
2019-04-20 02:28:57 +08:00
render_area.offset.x=0;
render_area.offset.y=0;
render_area.extent=extent;
2019-04-18 22:10:24 +08:00
}
CommandBuffer::~CommandBuffer()
{
2019-04-18 22:10:24 +08:00
VkCommandBuffer cmd_bufs[1] = {cmd_buf};
vkFreeCommandBuffers(device, pool, 1, cmd_bufs);
}
2019-04-18 22:10:24 +08:00
bool CommandBuffer::Begin(RenderPass *rp,Framebuffer *fb)
2019-04-18 22:10:24 +08:00
{
2019-04-20 02:28:57 +08:00
VkCommandBufferBeginInfo cmd_buf_info = {};
cmd_buf_info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO;
cmd_buf_info.pNext = nullptr;
cmd_buf_info.flags = 0;
cmd_buf_info.pInheritanceInfo = nullptr;
if(vkBeginCommandBuffer(cmd_buf, &cmd_buf_info)!=VK_SUCCESS)
return(false);
2019-04-18 22:10:24 +08:00
VkRenderPassBeginInfo rp_begin;
rp_begin.sType = VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO;
rp_begin.pNext = nullptr;
rp_begin.renderPass = *rp;
rp_begin.framebuffer = *fb;
rp_begin.renderArea = render_area;
rp_begin.clearValueCount = 2;
rp_begin.pClearValues = clear_values;
vkCmdBeginRenderPass(cmd_buf, &rp_begin, VK_SUBPASS_CONTENTS_INLINE);
return(true);
}
bool CommandBuffer::Bind(Pipeline *p)
{
if(!p)return(false);
2019-04-18 22:10:24 +08:00
vkCmdBindPipeline(cmd_buf, VK_PIPELINE_BIND_POINT_GRAPHICS, *p);
return(true);
}
bool CommandBuffer::Bind(PipelineLayout *pl)
{
if(!pl)return(false);
2019-04-20 02:28:57 +08:00
if(pl->GetDescriptorSetCount()>0)
vkCmdBindDescriptorSets(cmd_buf, VK_PIPELINE_BIND_POINT_GRAPHICS, *pl, 0, pl->GetDescriptorSetCount(),pl->GetDescriptorSets(), 0, nullptr);
2019-04-18 22:10:24 +08:00
return(true);
}
bool CommandBuffer::Bind(VertexInput *vi,const VkDeviceSize offset)
2019-04-18 22:10:24 +08:00
{
if(!vi)
return(false);
const List<VkBuffer> &buf_list=vi->GetBufferList();
if(buf_list.GetCount()<=0)
return(false);
2019-04-20 02:28:57 +08:00
vkCmdBindVertexBuffers(cmd_buf,0,buf_list.GetCount(),buf_list.GetData(),&offset);
2019-04-18 22:10:24 +08:00
return(true);
}
void CommandBuffer::Draw(const uint32_t vertex_count)
{
vkCmdDraw(cmd_buf,vertex_count,1,0,0);
}
void CommandBuffer::Draw(const uint32_t vertex_count,const uint32_t instance_count,const uint32_t first_vertex,const uint32_t first_instance)
{
vkCmdDraw(cmd_buf,vertex_count,instance_count,first_vertex,first_instance);
}
2019-04-20 02:28:57 +08:00
bool CommandBuffer::End()
{
vkCmdEndRenderPass(cmd_buf);
2019-04-20 02:28:57 +08:00
return(vkEndCommandBuffer(cmd_buf)==VK_SUCCESS);
}
VK_NAMESPACE_END