[2] 立方体(Box)图形的生成算法
顶点数据的生成
bool YfBuildBoxVertices
(
Yreal extentX,
Yreal extentY,
Yreal extentZ,
YeOriginPose originPose,
Yuint vertexStriding,
Yuint vertexPos,
void* pVerticesBuffer
)
{
if (!pVerticesBuffer)
{
return false;
} Yuint numVertices = ; // 顶点赋值
char* vertexPtr = (char*)pVerticesBuffer + vertexPos; YsVector3* curVertexPtr = NULL;
YsVector3* curNormalPtr = NULL;
YsVector2* curTexcoordPtr = NULL; Yuint nOffset = ; YsVector3 vOriginOffset(-extentX / , -extentY / , -extentZ / );
if (originPose == YE_ORIGIN_POSE_TOP)
{
vOriginOffset.y = -extentY;
}
else if (originPose == YE_ORIGIN_POSE_BOTTOM)
{
vOriginOffset.y = 0.0f;
} for (Yuint k = ; k < ; k++)
{
for (Yuint j = ; j < ; j++)
{
for (Yuint i = ; i < ; i++)
{
nOffset = (k* + j* + i) * vertexStriding;
curVertexPtr = (YsVector3*)(vertexPtr + nOffset);
curVertexPtr->x = extentX*i + vOriginOffset.x;
curVertexPtr->z = extentZ*j + vOriginOffset.z;
curVertexPtr->y = extentY*k + vOriginOffset.y;
}
}
} return true;
}
三角形索引数据的生成
bool YfBuildBoxTriIndices
(
YeIndexType indexType,
Yuint indexStriding,
Yuint indexPos,
void* pTriIndicesBuffer
)
{
if (!pTriIndicesBuffer)
{
return false;
} char* indexPtr = (char*)pTriIndicesBuffer + indexPos;
if (indexType == YE_INDEX_16_BIT)
{
YsTriIndex16* triIndexPtr[];
for (Yuint i = ; i < ; i++)
{
triIndexPtr[i] = (YsTriIndex16*)(indexPtr + i * indexStriding);
} // bottom
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // top
triIndexPtr[]->index0= ; triIndexPtr[]->index1= ; triIndexPtr[]->index2= ;
triIndexPtr[]->index0= ; triIndexPtr[]->index1= ; triIndexPtr[]->index2= ; // front side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // back side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // right side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // left side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
}
else
{
YsTriIndex32* triIndexPtr[];
for (Yuint i = ; i < ; i++)
{
triIndexPtr[i] = (YsTriIndex32*)(indexPtr + i * indexStriding);
} // bottom
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // top
triIndexPtr[]->index0= ; triIndexPtr[]->index1= ; triIndexPtr[]->index2= ;
triIndexPtr[]->index0= ; triIndexPtr[]->index1= ; triIndexPtr[]->index2= ; // front side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // back side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // right side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ; // left side
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
triIndexPtr[]->index0 = ; triIndexPtr[]->index1 = ; triIndexPtr[]->index2 = ;
} return true;
}
线框索引数据的生成
bool YfBuildBoxWireIndices
(
YeIndexType indexType,
Yuint indexStriding,
Yuint indexPos,
void* pWireIndicesBuffer
)
{
if (!pWireIndicesBuffer)
{
return false;
} char* indexPtr = (char*)pWireIndicesBuffer + indexPos;
if (indexType == YE_INDEX_16_BIT)
{
YsLineIndex16* lineIndexPtr[];
for (Yuint i = ; i < ; i++)
{
lineIndexPtr[i] = (YsLineIndex16*)(indexPtr + i * indexStriding);
} // bottom
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ; // center
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ; // top
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0= ; lineIndexPtr[]->index1= ;
lineIndexPtr[]->index0= ; lineIndexPtr[]->index1= ;
}
else
{
YsLineIndex32* lineIndexPtr[];
for (Yuint i = ; i < ; i++)
{
lineIndexPtr[i] = (YsLineIndex32*)(indexPtr + i * indexStriding);
} // bottom
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ; // center
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ; // top
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0 = ; lineIndexPtr[]->index1 = ;
lineIndexPtr[]->index0= ; lineIndexPtr[]->index1= ;
lineIndexPtr[]->index0= ; lineIndexPtr[]->index1= ;
} return true;
}
[2] 立方体(Box)图形的生成算法的更多相关文章
- [20] 鼓状物(Drum)图形的生成算法
顶点数据的生成 bool YfBuildDrumVertices ( Yreal radius, Yreal assistRadius, Yuint slices, Yuint stacks, YeO ...
- [17] 楼梯(Stairs)图形的生成算法
感觉这图形怎么看怎么像搓衣板. 顶点数据的生成 bool YfBuildStairsVertices ( Yreal width, Yreal length, Yreal height, Yuint ...
- [19] 半球形(Hemisphere)图形的生成算法
顶点数据的生成 bool YfBuildHemisphereVertices ( Yreal radius, Yuint slices, Yuint stacks, YeOriginPose orig ...
- [18] 螺旋楼梯(Spiral Stairs)图形的生成算法
顶点数据的生成 bool YfBuildSpiralStairsVertices ( Yreal radius, Yreal assistRadius, Yreal height, Yuint sli ...
- [16] 螺旋面(Spire)图形的生成算法
顶点数据的生成 bool YfBuildSpireVertices ( Yreal radius, Yreal assistRadius, Yreal height, Yuint slices, Yu ...
- [15] 星星(Star)图形的生成算法
顶点数据的生成 bool YfBuildStarVertices ( Yreal radius, Yreal assistRadius, Yreal height, Yuint slices, YeO ...
- [14] 齿轮(Gear Wheel)图形的生成算法
顶点数据的生成 bool YfBuildGearwheelVertices ( Yreal radius, Yreal assistRadius, Yreal height, Yuint slices ...
- [13] 弧面(Arc)图形的生成算法
顶点数据的生成 bool YfBuildArcVertices ( Yreal radius, Yreal degree, Yreal height, Yuint slices, Yuint stac ...
- [12] 扇形体(Fan)图形的生成算法
顶点数据的生成 bool YfBuildFunVertices ( Yreal radius, Yreal degree, Yreal height, Yuint slices, YeOriginPo ...
随机推荐
- Xposed模块开发教程
转:http://vbill.github.io/2015/02/10/xposed-1/ http://blog.csdn.net/zhangmiaoping23/article/detai ...
- 基于 Laravel 开发博客应用系列 —— 从测试开始(一):创建项目和PHPUnit
1.创建博客项目 我们将遵循上一节提到的六步创建一个新 Laravel 5.1 项目的步骤,创建本节要用到的博客项目 —— blog. 首先,在本地主机安装应用骨架: nonfu@ubuntu:~/C ...
- 2017-2018-1 20179202《Linux内核原理与分析》第十一周作业
Metasploit实现木马生成.捆绑.免杀 1.预备知识 (1)Metasploit Metasploit是一款开源的安全漏洞检测工具,全称叫做The Metasploit Framework,简称 ...
- Wannafly挑战赛9 A - 找一找
链接:https://www.nowcoder.com/acm/contest/71/A来源:牛客网 题目描述 给定n个正整数,请找出其中有多少个数x满足:在这n个数中存在数y=kx,其中k为大于1的 ...
- Cobbler图文详解安装及遇到的问题说明
一.介绍 Cobbler是一个使用Python开发的开源项目,通过将部署系统所涉及的所有服务集中在一起,来提供一个全自动批量快速建立linux系统的网络环境, Cobbler提供了DHCP管理,YUM ...
- Oracle数据库脚本中的set define off
2018年8月6日15:11:34 Oracle数据库脚本中的set define off 前言 最近在公司写需求,接触到脚本,第一句set define off;就不知道什么意思了,查询后记录之. ...
- spring中的scope详解
spring容器中的bean默认是单例模式的,改成非单例模式需要在类上加上@Scope("prototype") 1. scope概论 spring中scope是一个非常关键的概念 ...
- CF582A GCD Table
A. GCD Table time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...
- (四)静态断言(上),assert,NDEBUG, 以及通过宏定义处理文件包含关系
一.断言:运行时与预处理时 断言(assertion)是一种编程常用的手段.想必大家都见过 assert 吧.今天我们就来了解一下它. 通常情况下,断言就是将一个返回值总是需要为真的判别式放在语句中, ...
- luoguP4360 [CEOI2004]锯木厂选址
题目链接 luoguP4360 [CEOI2004]锯木厂选址 题解 dis:后缀和 sum:前缀和 补集转化,减去少走的,得到转移方程 dp[i] = min(tot - sumj * disj - ...