Vulkan开发实战详解 学习笔记 - 构建一个球体对象

news/2024/10/23 0:45:23/

构建一个球体对象

BallData.h

#ifndef VULKANEXBASE_BALLDATA_H
#define VULKANEXBASE_BALLDATA_H//防止重复引用
class BallData 
{
public:static float* vdata;//顶点数据数组首地址指针static int dataByteCount;//顶点数据所占总字节数static int vCount;//顶点数量static void genBallData(float angleSpan);//生成顶点数据的方法
};
#endif

BallData.cpp

#include "BallData.h"
#include <vector>
#include <math.h>
#include <string.h>float* BallData::vdata;//顶点数据数组首地址指针
int BallData::dataByteCount;//顶点数据所占总字节数
int BallData::vCount;//顶点数量//主要包括两个方法toRadians和genBallData。toRadians方法的功能为将角度转换为弧度
float toRadians(float degree) 
{//角度转换成弧度的方法return (float)(degree*3.1415926535898 / 180.0);
}
void  BallData::genBallData(float angleSpan) 
{//生成球面上各个小三角形顶点数据的方法const float r = 1.0f;//球的半径std::vector<float> alVertix;//存放顶点坐标值的vector//的angleSpan为将球面进行经纬度方向拆分的单位角度,此角度值越小,拆分得就越细,绘制出来的形状也越接近于球。//用双层for循环将球按照一定的角度跨度(angleSpan)沿经度、纬度方向进行拆分。每次循环到一组纬度、经度时都将对应顶点看作一个小四边形的左上侧点,然后按照规律计算出小四边形中其他3个顶点的坐标,最后按照需要将用于卷绕成两个三角形的6个顶点的坐标依次存入vector列表。for (float vAngle = -90; vAngle < 90; vAngle = vAngle + angleSpan) {//垂直方向切分for (float hAngle = 0; hAngle <= 360; hAngle = hAngle + angleSpan) {//水平方向切分//行首先计算出了顶点数量、顶点数据总字节数,然后将拆分的顶点坐标数据转存进数据数组中float x0 = (float)(r * cos(toRadians(vAngle)) * cos(toRadians(hAngle)));float y0 = (float)(r * cos(toRadians(vAngle)) * sin(toRadians(hAngle)));float z0 = (float)(r *sin(toRadians(vAngle)));float x1 = (float)(r * cos(toRadians(vAngle)) * cos(toRadians(hAngle + angleSpan)));float y1 = (float)(r * cos(toRadians(vAngle)) *sin(toRadians(hAngle + angleSpan)));float z1 = (float)(r * sin(toRadians(vAngle)));float x2 = (float)(r*cos(toRadians(vAngle + angleSpan)) * cos(toRadians(hAngle + angleSpan)));float y2 = (float)(r*cos(toRadians(vAngle + angleSpan)) * sin(toRadians(hAngle + angleSpan)));float z2 = (float)(r * sin(toRadians(vAngle + angleSpan)));float x3 = (float)(r * cos(toRadians(vAngle + angleSpan)) * cos(toRadians(hAngle)));float y3 = (float)(r * cos(toRadians(vAngle + angleSpan)) * sin(toRadians(hAngle)));float z3 = (float)(r * sin(toRadians(vAngle + angleSpan)));alVertix.push_back(x1); alVertix.push_back(y1); alVertix.push_back(z1);alVertix.push_back(x3); alVertix.push_back(y3); alVertix.push_back(z3);alVertix.push_back(x0); alVertix.push_back(y0); alVertix.push_back(z0);alVertix.push_back(x1); alVertix.push_back(y1); alVertix.push_back(z1);alVertix.push_back(x2); alVertix.push_back(y2); alVertix.push_back(z2);alVertix.push_back(x3); alVertix.push_back(y3); alVertix.push_back(z3);}}//首先计算出了顶点数量、顶点数据总字节数,然后将拆分的顶点坐标数据转存进数据数组中。vCount = alVertix.size() / 3;//顶点的数量为坐标值数量的1/3,因为一个顶点有3个坐标分量dataByteCount = alVertix.size() * sizeof(float);//计算顶点数据总字节数vdata = new float[alVertix.size()];//创建存放顶点数据的数组int index = 0;//辅助数组索引for (int i = 0; i<vCount; i++) {//将顶点数据存储到数组中vdata[index++] = alVertix[i * 3 + 0];//保存顶点位置X分量vdata[index++] = alVertix[i * 3 + 1];//保存顶点位置Y分量vdata[index++] = alVertix[i * 3 + 2];//保存顶点位置Z分量}
}

createDrawableObject

//创建绘制用物体
void MyVulkanManager::createDrawableObject()
{//ShaderQueueSuit_Common类中用于设置顶点着色器输入属性信息的initVertexAttributeInfo方法的相关代码BallData::genBallData(9);//生成球的顶点数据和法向量数据ballForDraw = new DrawableObjectCommonLight(BallData::vdata, BallData::dataByteCount, BallData::vCount, device, memoryroperties);//创建绘制用球
}

initVertexAttributeInfo

void ShaderQueueSuit_Common::initVertexAttributeInfo()
{//设置了所需顶点输入绑定描述结构体实例的几项属性值vertexBinding.binding = 0;//对应绑定点vertexBinding.inputRate = VK_VERTEX_INPUT_RATE_VERTEX;	//数据输入频率为每顶点//的顶点输入数据仅包含球面顶点的x、y、z位置坐标,因此每组数据的跨度字节数为3倍浮点数字节数。vertexBinding.stride = sizeof(float) * 3;//每组数据的跨度字节数//设置了顶点输入属性的绑定点、位置索引、数据格式及偏移量vertexAttribs[0].binding = 0;//第1个顶点输入属性的绑定点vertexAttribs[0].location = 0;//第1个顶点输入属性的位置索引//。同时顶点输入属性只有一个,类型为VK_FORMAT_R32G32B32_SFLOAT表示3个浮点数。vertexAttribs[0].format = VK_FORMAT_R32G32B32_SFLOAT;//第1个顶点输入属性的数据格式vertexAttribs[0].offset = 0;//第1个顶点输入属性的偏移量
}

create_pipe_line

void ShaderQueueSuit_Common::create_pipe_line(VkDevice& device, VkRenderPass& renderPass)
{//,这部分代码主要是使用了前面步骤设置好的顶点输入绑定描述结构体和顶点输入属性描述结构体实例。故这里的顶点输入绑定描述数量、顶点输入属性数量应该与前面步骤中的一致。#define NUM_DYNAMIC_STATES 1 /*Viewport + Scissor*/	                               //VkDynamicState dynamicStateEnables[VK_DYNAMIC_STATE_RANGE_SIZE];//动态状态启用标志VkDynamicState dynamicStateEnables[NUM_DYNAMIC_STATES];//动态状态启用标志memset(dynamicStateEnables, 0, sizeof dynamicStateEnables);	//设置所有标志为falsedynamicStateEnables[0] = VK_DYNAMIC_STATE_VIEWPORT;		        //视口为动态设置VkPipelineVertexInputStateCreateInfo vi;//管线顶点数据输入状态创建信息vi.sType = VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO;vi.pNext = NULL;//自定义数据的指针vi.flags = 0;//供将来使用的标志vi.vertexBindingDescriptionCount = 1;//顶点输入绑定描述数量 //这里vi.pVertexBindingDescriptions = &vertexBinding;//顶点输入绑定描述列表vi.vertexAttributeDescriptionCount = 1;//顶点输入属性数量vi.pVertexAttributeDescriptions = vertexAttribs;//顶点输入属性描述列表VkPipelineInputAssemblyStateCreateInfo ia;ia.sType = VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO;ia.pNext = NULL;ia.flags = 0;ia.primitiveRestartEnable = VK_FALSE;ia.topology = VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST;	//这里
}

vertshadertext.vert

#version 400
#extension GL_ARB_separate_shader_objects : enable//启动GL_ARB_separate_shader_objects
#extension GL_ARB_shading_language_420pack : enable//启动GL_ARB_shading_language_420packlayout (push_constant) uniform constantVals {			 //推送常量块mat4 mvp;
} myConstantVals;
layout (location = 0) in vec3 pos;					//传入的物体坐标系顶点坐标
layout (location = 1) in vec3 color;					//传入的顶点颜色
layout (location = 0) out vec3 vcolor;					//传到片元着色器的顶点颜色
//增加了将顶点位置通过out变量vposition传递给片元着色器的相关代码
out gl_PerVertex { vec4 gl_Position;};				//输出接口块
void main() {									//主函数gl_Position = myConstantVals.mvp * vec4(pos,1.0);	//计算顶点最终位置vcolor=color;//传递顶点颜色给片元着色器
}

的commonTexLight.frag˙ȼ

#version 400
#extension GL_ARB_separate_shader_objects : enable//启动GL_ARB_separate_shader_objects
#extension GL_ARB_shading_language_420pack : enable//启动GL_ARB_shading_language_420pack
layout (location = 0) in vec3 vcolor;//顶点着色器传入的顶点颜色数据
layout (location = 0) out vec4 outColor;//输出到渲染管线的片元颜色值
void main() 
{outColor=vec4(vcolor.rgb,1.0);//将顶点着色器传递过来的颜色值输出
}

在这里插入图片描述


http://www.ppmy.cn/news/653706.html

相关文章

安装oracle10g32,Windows7旗舰版32位安装oracle10g方法

Windows7旗舰版32位安装oracle10g方法 首先要下载支持Vista版本的Oracle 10g 下载完成后解压出来&#xff1a; http://www.doczj.com/doc/816ed069b84ae45c3b358c7a.html/otn/nt/oracle10g/10203/10203_vista_w2k8_x86_production_d b.zip安装的第一步就是要修改安装文件目录中…

oracle11g32位安装流程_Oracle11g R2 安装图解(win7 32位)

1.首先去网址&#xff1a;http://www.oracle.com/technetwork/cn/database/enterprise-edition/downloads/112010-win32soft-098630-zhs.html 下载安装包&#xff0c;解压的时候一定要放在一起解压 2、找到解压的database文件夹中的Setup.exe直接双击安装。 3、安装环境检测 4.…

oracle11g32位安装流程_Oracle 11g下载

多多为大家免费提供Oracle 11g下载&#xff0c;包含64位/32位官方版本&#xff0c;并附详细的Oracle 11g安装图解教程&#xff0c;同时希望能帮助到刚接触到Oracle数据库的朋友。安装过程稍需一段时间&#xff0c;具体时间决取于你的电脑配置&#xff0c;请大家稍安勿躁。 Orac…

D3D计算着色器入门

1.对计算着色器的理解&#xff1a; 计算着色器跟他的名字一样&#xff0c;就是进行计算的着色器。但是它的用途不仅局限于图形的运算&#xff0c;也可以进行通用的运算。计算着色器的计算能力非常强&#xff0c;这就使得在gpu进行通用运算后再传输回cpu&#xff0c;比直接在cpu…

G16、G24、G32、G36、G60

请输入置换次数N&#xff1a;51 请输入置换m&#xff1a;1,3,16,21,36,45,51,2,4,5,6,7,8,9,10,11,12,13,14,15,17,18,19,20,22,23,24,25,26,27,28,29,30,31,32,33,34,35,37 ,38,39,40,41,42,43,44,46,47,48,49,50 置换m^-1&#xff1a;1,8,2,9,10,11,12,13,14,15,16,17,18,19,…

ssm+jsp计算机毕业设计毕业论文管理系统的设计与实现m7g32(程序+LW+源码+远程部署)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行环境配置&#xff1a; Python3.7.7DjangoMysql5.7pip listHBuilderX&#xff08;Vscode也行&#xff09;VuePychram社区版。 项目技术&#xff1a; Django Vue PythonMysql 等等组成&#xff0c;…

[附源码]JSP+ssm计算机毕业设计大学生助学贷款管理系统46g32【源码、数据库、LW、部署】

项目运行 项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1…

SSM毕设项目公安行政法律文书收集管理9g32h(java+VUE+Mybatis+Maven+Mysql)

SSM毕设项目公安行政法律文书收集管理9g32h&#xff08;javaVUEMybatisMavenMysql&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&am…