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


C++ PhysicsBody::getOffset方法代码示例

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


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

示例1: processEntities

void RocketControllerSystem::processEntities(const vector<Entity*>& p_entities)
{
	float dt = m_world->getDelta();
	float waitUntilActivation = 0.5f;
	float rocketMaxAge = 15.0f;
	for (unsigned int i = 0; i < p_entities.size(); i++)
	{
		StandardRocket* rocket = static_cast<StandardRocket*>(p_entities[i]->getComponent(ComponentType::StandardRocket));

		if (rocket->m_age == 0)
		{
			//Align with movement direction
			MeshOffsetTransform* meshOffset = static_cast<MeshOffsetTransform*>
				( p_entities[i]->getComponent( ComponentType::MeshOffsetTransform) );

			PhysicsBody* pb = static_cast<PhysicsBody*>(p_entities[i]->getComponent(ComponentType::PhysicsBody));
			PhysicsSystem* ps = static_cast<PhysicsSystem*>(m_world->getSystem(SystemType::PhysicsSystem));
			RigidBody* body = static_cast<RigidBody*>(ps->getController()->getBody(pb->m_id));
			AglMatrix world = body->GetWorld();

			world = meshOffset->offset.inverse()*world;
			world = pb->getOffset()*world;
			body->setTransform(world);
		}

		rocket->m_age += dt;
		//Check collision
		if (rocket->m_age > waitUntilActivation && rocket->m_age <= rocketMaxAge)
		{
			//Start targeting ships
			PhysicsBody* pb = static_cast<PhysicsBody*>(p_entities[i]->getComponent(ComponentType::PhysicsBody));
			PhysicsSystem* ps = static_cast<PhysicsSystem*>(m_world->getSystem(SystemType::PhysicsSystem));
			RigidBody* body = static_cast<RigidBody*>(ps->getController()->getBody(pb->m_id));

			if (rocket->m_target >= 0)
			{
				ShipManagerSystem* shipManager = static_cast<ShipManagerSystem*>(m_world->getSystem(SystemType::ShipManagerSystem));

				Entity* ship = m_world->getEntity(rocket->m_target);

				Transform* from = static_cast<Transform*>(p_entities[i]->getComponent(ComponentType::Transform));
				Transform* to = static_cast<Transform*>(ship->getComponent(ComponentType::Transform));

				//START APPLY IMPULSE

				MeshOffsetTransform* meshOffset = static_cast<MeshOffsetTransform*>
					( p_entities[i]->getComponent( ComponentType::MeshOffsetTransform) );

				AglVector3 imp = to->getTranslation() - from->getTranslation();
				float distance = imp.length();
				imp.normalize();

				AglMatrix world = meshOffset->offset * pb->getOffset().inverse() * body->GetWorld();

				AglVector3 rotAxis = AglVector3::crossProduct(imp, -world.GetForward());
				rotAxis.normalize();

				//Compute fraction of turn power that should be applied
				AglVector3 angVel = body->GetAngularVelocity();

				float angVelAxis = max(AglVector3::dotProduct(angVel, rotAxis), 0);

				float amountToRotate = min(1.0f - AglVector3::dotProduct(imp, world.GetForward()), 1.0f); //0 -> 1

				float frac = 1.0f;
				if (amountToRotate / angVelAxis < 0.25f)
				{
					frac = (amountToRotate / angVelAxis) / 0.25f;
				}

				rotAxis *= m_turnPower * dt * frac;

				frac = 1-frac;

				AglVector3 impulse = imp*0.25f + world.GetForward();
				impulse.normalize();
				impulse *= dt*m_enginePower*frac;

				ps->getController()->ApplyExternalImpulse(pb->m_id, impulse, rotAxis);
			}
			else
			{
				MeshOffsetTransform* meshOffset = static_cast<MeshOffsetTransform*>
					( p_entities[i]->getComponent( ComponentType::MeshOffsetTransform) );

				AglMatrix world = meshOffset->offset * pb->getOffset().inverse() * body->GetWorld();
				AglVector3 impulse = world.GetForward() * m_enginePower * dt;
				ps->getController()->ApplyExternalImpulse(pb->m_id, impulse, AglVector3(0, 0, 0));
			}


			//END APPLY IMPULSE

			//Check collision	
			vector<unsigned int> cols = ps->getController()->CollidesWith(pb->m_id);
			bool staticCol = ps->getController()->CollidesWithStaticEnvironment(pb->m_id);
			if (cols.size() > 0 || staticCol)
			{
				explodeRocket(ps, pb, body, p_entities[i]);
			}
//.........这里部分代码省略.........
开发者ID:MattiasLiljeson,项目名称:Amalgamation,代码行数:101,代码来源:RocketControllerSystem.cpp


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