当前位置: 首页>>代码示例>>C++>>正文


C++ BoundingBox::addPoint方法代码示例

本文整理汇总了C++中BoundingBox::addPoint方法的典型用法代码示例。如果您正苦于以下问题:C++ BoundingBox::addPoint方法的具体用法?C++ BoundingBox::addPoint怎么用?C++ BoundingBox::addPoint使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在BoundingBox的用法示例。


在下文中一共展示了BoundingBox::addPoint方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: addGeometry

	void addGeometry(SPGeometry geometry)
	{
		mBB.addPoint(geometry->getBB().min());
		mBB.addPoint(geometry->getBB().max());

		mGeometries.push_back(geometry);
	}
开发者ID:bernhardfritz,项目名称:FortgeschritteneComputergrafik,代码行数:7,代码来源:Scene.hpp

示例2: getBoundingBox

BoundingBox CsgRegularPolygon::getBoundingBox()
{
	BoundingBox ret;
	Matrix33f mat = getMatrix();
	Vec3f v;

	v = mat * Vec3f(-0.5, -0.5, 1);
	ret.addPoint(v);
	v = mat * Vec3f(-0.5, +0.5, 1);
	ret.addPoint(v);
	v = mat * Vec3f(+0.5, -0.5, 1);
	ret.addPoint(v);
	v = mat * Vec3f(+0.5, +0.5, 1);
	ret.addPoint(v);

	return ret;
}
开发者ID:SnqKe,项目名称:CPOA,代码行数:17,代码来源:csgRegularPolygon.cpp

示例3: buildCollision

    void buildCollision()
    {
        if (!mChanged)
            return;

        mChanged = false;

        mBoundingBoxes.clear();
        m_BB.reset();

        for (size_t div = 0; div < mVertices.size() / mDivCount; div++)
        {
            BoundingBox<Vector> bb;

            for (auto i = div*mDivCount; i < mVertices.size(); i++)
            {
                if (i > div*mDivCount + mDivCount)
                    break;

                bb.addPoint(mVertices[i]);
                m_BB.addPoint(mVertices[i]);
            }

            mBoundingBoxes.push_back(bb);
        }



        if (mVertices.size() % mDivCount != 0)
        {
            BoundingBox<Vector> bb;

            auto start = mVertices.size() - mVertices.size() % mDivCount;
            auto end = mVertices.size();

            for (auto i = start; i < end; i++)
            {
                bb.addPoint(mVertices[i]);
                m_BB.addPoint(mVertices[i]);
            }

            mBoundingBoxes.push_back(bb);
        }
    }
开发者ID:bernhardfritz,项目名称:FortgeschritteneComputergrafik,代码行数:44,代码来源:TriangleMesh.hpp

示例4: getPoints

void Mesh
  ::getBoundingBox(BoundingBox &b) const
{
  b.setEmpty();

  // iterate over positions
  for(PointList::const_iterator p = getPoints().begin();
      p != getPoints().end();
      ++p)
  {
    b.addPoint(*p);
  } // end for p
} // end Mesh::getBoundingBox()
开发者ID:Aantonb,项目名称:gotham,代码行数:13,代码来源:Mesh.cpp

示例5: CreateBoundingBox

osg::Node* OSGVisualizationFactory::CreateBoundingBox(osg::Node *model, bool wireFrame)
{
	if (!model)
		return NULL;

	const osg::MatrixList& m = model->getWorldMatrices(); 
	osg::ComputeBoundsVisitor cbv; 
	model->accept( cbv ); 
	osg::BoundingBox bboxOSG = cbv.getBoundingBox(); 
	osg::Vec3 minV = bboxOSG._min * m.front(); 
	osg::Vec3 maxV = bboxOSG._max * m.front(); 

	BoundingBox bbox;
	Eigen::Vector3f minPoint(minV[0],minV[1],minV[2]);
	Eigen::Vector3f maxPoint(maxV[0],maxV[1],maxV[2]);
	bbox.addPoint(minPoint);
	bbox.addPoint(maxPoint);
	return CreateBoundingBoxVisualization(bbox,wireFrame);
}
开发者ID:TheMarex,项目名称:simox,代码行数:19,代码来源:OSGVisualizationFactory.cpp

示例6: recomputeBoundingBox

void PointSetNode::recomputeBoundingBox() 
{
	CoordinateNode *coordinate = getCoordinateNodes();
	if (!coordinate) {
		setBoundingBoxCenter(0.0f, 0.0f, 0.0f);
		setBoundingBoxSize(-1.0f, -1.0f, -1.0f);
		return;
	}

	BoundingBox bbox;
	float		point[3];

	int nCoordinatePoints = coordinate->getNPoints();
	for (int n=0; n<nCoordinatePoints; n++) {
		coordinate->getPoint(n, point);
		bbox.addPoint(point);
	}

	setBoundingBox(&bbox);
}
开发者ID:x414e54,项目名称:CyberX3D4CC,代码行数:20,代码来源:PointSetNode.cpp


注:本文中的BoundingBox::addPoint方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。