标签:colunm temp 创建 back Vec3f 柱元 OSG push osg
- 名词翻译:
法向量:normal vector
法线:normal
- 代码:
//分支判断start
if (_columnType == Circle1) //圆形规则
{
for (size_t i = 0; i < 120; i++)
{
osg::Vec3 Point = _temp + L * osg::Matrix::rotate(osg::inDegrees(i * 3.0), normal);
//osg::Vec3f L = osg::Vec3f(1, 0, 0) * _diameter / 2; L指某一个半径长度的向量,即单位向量(1,0,0)*直径/2
//关键点temp+向量L绕法线normal旋转i*3度(转120次是近似圆)
Point.z() = 1;
//竖坐标?
column->push_back(Point);
//压入,最终一起组成图元column
}
}
else if (_columnType == Squre) //矩形规则
{
float theHalfofLength = _length * 0.5;
float theHalfofWidth = _width * 0.5;
osg::Vec3f xDirection = _direction ^ osg::Z_AXIS; //叉乘:柱子方向^竖单位向量(0,0,1),右手法则判断方向
//辅助点
osg::Vec3f supPoint = (xDirection * theHalfofWidth) + _temp;
//点A
osg::Vec3f pointA = (_direction * theHalfofLength) + supPoint;
//点A辅助线镜像A'
osg::Vec3f pointMirrorASup = supPoint - pointA + supPoint;
//点A对角线镜像点B
osg::Vec3f pointB = _temp - pointA + _temp;
//点A'对角线镜像B'
osg::Vec3f pointMirrorBSup = _temp - pointMirrorASup + _temp;
colunm->push_back(pointA);
colunm->push_back(pointMirrorASup);
colunm->push_back(pointB);
colunm->push_back(pointMirrorBSup);
this->addCaptureLine(colunm);
}
标签:colunm,temp,创建,back,Vec3f,柱元,OSG,push,osg 来源: https://www.cnblogs.com/jessicaland/p/16535085.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。