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


C++ ListIter::GetFarcaster方法代码示例

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


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

示例1: if

Steer
StarshipAI::SeekTarget()
{
	if (navpt) {
		SimRegion*     self_rgn = ship->GetRegion();
		SimRegion*     nav_rgn  = navpt->Region();
		QuantumDrive*  qdrive   = ship->GetQuantumDrive();

		if (self_rgn && !nav_rgn) {
			nav_rgn = self_rgn;
			navpt->SetRegion(nav_rgn);
		}

		bool use_farcaster      = self_rgn != nav_rgn && 
		(navpt->Farcast() || 
		!qdrive ||
		!qdrive->IsPowerOn() ||
		qdrive->Status() < System::DEGRADED
		);

		if (use_farcaster) {
			if (!farcaster) {
				ListIter<Ship> s = self_rgn->Ships();
				while (++s && !farcaster) {
					if (s->GetFarcaster()) {
						const Ship* dest = s->GetFarcaster()->GetDest();
						if (dest && dest->GetRegion() == nav_rgn) {
							farcaster = s->GetFarcaster();
						}
					}
				}
			}

			if (farcaster) {
				if (farcaster->GetShip()->GetRegion() != self_rgn)
				farcaster = farcaster->GetDest()->GetFarcaster();

				obj_w = farcaster->EndPoint();
				distance = Point(obj_w - ship->Location()).length();

				if (distance < 1000)
				farcaster = 0;
			}
		}
		else if (self_rgn != nav_rgn) {
			QuantumDrive* q = ship->GetQuantumDrive();

			if (q) {
				if (q->ActiveState() == QuantumDrive::ACTIVE_READY) {
					q->SetDestination(navpt->Region(), navpt->Location());
					q->Engage();
				}
			}
		}
	}

	return ShipAI::SeekTarget();
}
开发者ID:lightgemini78,项目名称:Starshatter-Rearmed,代码行数:58,代码来源:StarshipAI.cpp

示例2: if

void
NavAI::FindObjective()
{
	navpt    = 0;
	distance = 0;

	// runway takeoff:
	if (takeoff) {
		obj_w   = ship->Location()   + ship->Heading() * 10e3;
		obj_w.y = ship->Location().y + 2e3;

		// transform into camera coords:
		objective = Transform(obj_w);
		ship->SetDirectorInfo(Game::GetText("ai.takeoff"));
		return;
	}

	// PART I: Find next NavPoint:
	if (ship->GetNavSystem())
	navpt = ship->GetNextNavPoint();

	complete = !navpt;
	if (complete) return;

	// PART II: Compute Objective from NavPoint:
	Point       npt = navpt->Location();
	Sim*        sim = Sim::GetSim();
	SimRegion*  self_rgn = ship->GetRegion();
	SimRegion*  nav_rgn = navpt->Region();

	if (self_rgn && !nav_rgn) {
		nav_rgn = self_rgn;
		navpt->SetRegion(nav_rgn);
	}

	if (self_rgn == nav_rgn) {
		if (farcaster) {
			if (farcaster->GetShip()->GetRegion() != self_rgn)
			farcaster = farcaster->GetDest()->GetFarcaster();

			obj_w = farcaster->EndPoint();
		}

		else {
			obj_w = npt.OtherHand();
		}

		// distance from self to navpt:
		distance = Point(obj_w - self->Location()).length();

		// transform into camera coords:
		objective = Transform(obj_w);

		if (!ship->IsStarship())
		objective.Normalize();

		if (farcaster && distance < 1000)
		farcaster = 0;
	}

	// PART III: Deal with orbital transitions:
	else if (ship->IsDropship()) {
		if (nav_rgn->GetOrbitalRegion()->Primary() ==
				self_rgn->GetOrbitalRegion()->Primary()) {

			Point npt = nav_rgn->Location() - self_rgn->Location();
			obj_w = npt.OtherHand();

			// distance from self to navpt:
			distance = Point(obj_w - ship->Location()).length();

			// transform into camera coords:
			objective = Transform(obj_w);

			if (nav_rgn->IsAirSpace()) {
				drop_state = -1;
			}
			else if (nav_rgn->IsOrbital()) {
				drop_state = 1;
			}
		}

		// PART IIIa: Deal with farcaster jumps:
		else if (nav_rgn->IsOrbital() && self_rgn->IsOrbital()) {
			ListIter<Ship> s = self_rgn->Ships();
			while (++s && !farcaster) {
				if (s->GetFarcaster()) {
					const Ship* dest = s->GetFarcaster()->GetDest();
					if (dest && dest->GetRegion() == nav_rgn) {
						farcaster = s->GetFarcaster();
					}
				}
			}

			if (farcaster) {
				Point apt   = farcaster->ApproachPoint(0);
				Point npt   = farcaster->StartPoint();
				double r1   = (ship->Location() - npt).length();

				if (r1 > 50e3) {
//.........这里部分代码省略.........
开发者ID:The-E,项目名称:Starshatter-Experimental,代码行数:101,代码来源:NavAI.cpp


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