[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 ...
随机推荐
- Ionic实战七:Ionic 音乐以及社交页面
Ionic 音乐以及社交页面,可以用于二次开发,也可以用于社交或者音乐app页面模板,但是不足的是图片没法预览.      
- 部署 LAMP
部署 LAMP https://help.aliyun.com/document_detail/50774.html?spm=a2c4g.11186623.6.773.Em8xVc 文档提供方:上海驻 ...
- Python实现代码行数统计工具
我们经常想要统计项目的代码行数,但是如果想统计功能比较完善可能就不是那么简单了, 今天我们来看一下如何用python来实现一个代码行统计工具. 思路:首先获取所有文件,然后统计每个文件中代码的行数,最 ...
- C++实现平衡二叉树
1.概念 平衡二叉树(AVL Tree)首先要满足二叉树的定义,如下 二叉排序树或者是一棵空树,或者是具有下列性质的二叉树: 若左子树不空,则左子树上所有结点的值均小于它的根结点的值: 若右子树不空, ...
- collection 和 collections
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha collection 是集合的意思. 集合 是 集合类的上级接口, 比如 set 和 l ...
- chinese hacker-----WriteUp
原题地址:http://ctf5.shiyanbar.com/web/2/ 提示下载一个数据库 下载下来后发现是加密的 有密码,但发现密码不是4648 这里用到“DbView” 直接破解密码进入 发 ...
- 自顶向下学搜索引擎——北大天网搜索引擎TSE分析及完全注释[1]寻找搜索引擎入口
转自:http://blog.csdn.net/jrckkyy/article/category/402818 由于百度博客http://hi.baidu.com/jrckkyy发表文章字数有限,以后 ...
- web文件上传组件比较jQuery File Upload和Fine Uploader
jQuery File Upload: https://blueimp.github.io/jQuery-File-Upload/ Fine Uploader: http://fineuploader ...
- Codeforces Round #283 (Div. 2) B. Secret Combination 暴力水题
B. Secret Combination time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- JS字符串相关操作
01.插入 参数说明:str表示原字符串变量,flg表示要插入的字符串,sn表示要插入的位置 function insert_flg(str,flg,sn){ var newstr="&qu ...