MOC的资料不多,目前仅限于以下几处:
http://www.ogre3d.org/tikiwiki/Minimal+Ogre+Collision&structure=Librarieshttp://www.ogre3d.org/forums/viewtopic.php?t=45267http://sourceforge.net/projects/moc-collision/http://www.ogre3d.org/forums/viewtopic.php?t=23440http://code.google.com/p/minimal-ogre-collision-toolkit/moc代码只有一个h和一个cpp文件,还算简洁的。也是很多年没有维护了,简单用用也算够了。
使用步骤
1、初始化
1
MOC::CollisionTools* mCollisionTools;
2
// init the collision handler
3
mCollisionTools = new CollisionTools(mSceneMgr, mArtifexLoader->mTerrainInfo);
4data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
5
// set how far we want the camera to be above ground
6
mCollisionTools->setHeightAdjust(4.5f);
7data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
8
// place the camera node on the ground
9
mCollisionTools->calculateY(mCamNode); 2、碰撞检测
1
// calculate the new Y position: check vs. terrain & all objects flagged with ENTITY_MASK
2
// multiple masks possible like e.g. ENTITY_MASK|MY_MASK|ETC_MASK
3
// doGridCheck casts a 2nd ray, gridWidth=2.0f ogre units away from the exact camera position to
4
// avoid falling through small wholes or gaps in hangbridges for example.
5
mCollisionTools->calculateY(mCamNode,true,true,2.0f,ENTITY_MASK);
6data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
7
// check if we are colliding with anything with a collision radius of 2.5 ogre units and we
8
// set the ray origin -1.0 lower towards the ground to get smaller obstacles too
9
if (mCollisionTools->collidesWithEntity(oldPos, mCamNode->getPosition(), 2.5f, -1.0f, ENTITY_MASK))
10data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
11
// undo move
12
mCamNode->setPosition(oldPos);
13
} 3、鼠标拾取,射线查询
1
void SampleApp::pickEntity(const OIS::MouseEvent &arg, const Ogre::uint32 queryMask)
2data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
3
Entity *tmpE = NULL;
4
Vector3 result = Vector3::ZERO;
5
float distToColl;
6
if (mCollisionTools->raycastFromCamera(mRenderWin, mCamera, arg, result, (ulong&)tmpE, distToColl, queryMask))
7data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
8
SceneNode* node = tmpE->getParentSceneNode();
9
if (node->getShowBoundingBox())
10data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
11
node->showBoundingBox(false);
12
} else
13data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
14
node->showBoundingBox(true);
15
}
16
}
17
}
18data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
19
bool SampleApp::mousePressed(const OIS::MouseEvent &arg, OIS::MouseButtonID id)
20data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
21
if ( id == OIS::MB_Left )
22data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
23
mLMouseDown = true;
24
pickEntity(arg, ENTITY_MASK);
25
}
26
} 4、清理
delete mCollisionTools;5、中文资料
http://archive.cnblogs.com/a/1914145/