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


C# System.Numerics.Vector3.ToXna方法代码示例

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


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

示例1: Redraw

		public override void Redraw(float currentTime, float elapsedTime)
		{
			// update camera, tracking test vehicle
			Demo.UpdateCamera(elapsedTime, _vehicle);

			// draw "ground plane"  (make it 4x map size)
			const float S = MapDriver.WORLD_SIZE * 2;
			const float U = -0.2f;
			Drawing.DrawQuadrangle(new Vector3(+S, U, +S),
							new Vector3(+S, U, -S),
							new Vector3(-S, U, -S),
							new Vector3(-S, U, +S),
							new Color((byte)(255.0f * 0.8f), (byte)(255.0f * 0.7f), (byte)(255.0f * 0.5f))); // "sand"

			// draw map and path
			if (MapDriver.DemoSelect == 2) _vehicle.DrawPath();
			_vehicle.DrawMap();

			// draw test vehicle
			_vehicle.Draw();

			// QQQ mark origin to help spot artifacts
			const float TICK = 2;
			Drawing.DrawLine(new Vector3(TICK, 0, 0), new Vector3(-TICK, 0, 0), Color.Green);
			Drawing.DrawLine(new Vector3(0, 0, TICK), new Vector3(0, 0, -TICK), Color.Green);

			// compute conversion factor miles-per-hour to meters-per-second
			const float METERS_PER_MILE = 1609.344f;
			const float SECONDS_PER_HOUR = 3600;
// ReSharper disable InconsistentNaming
			const float MPSperMPH = METERS_PER_MILE / SECONDS_PER_HOUR;
// ReSharper restore InconsistentNaming

			// display status in the upper left corner of the window
			StringBuilder status = new StringBuilder();
			status.AppendFormat("Speed: {0} mps ({1} mph), average: {2:0.0} mps\n\n",
				   (int)_vehicle.Speed,
				   (int)(_vehicle.Speed / MPSperMPH),
				   _vehicle.TotalDistance / _vehicle.TotalTime);
			status.AppendFormat("collisions avoided for {0} seconds",
				   (int)(Demo.Clock.TotalSimulationTime - _vehicle.TimeOfLastCollision));
			if (_vehicle.CountOfCollisionFreeTimes > 0)
			{
				status.AppendFormat("\nmean time between collisions: {0} ({1}/{2})",
					   (int)(_vehicle.SumOfCollisionFreeTimes / _vehicle.CountOfCollisionFreeTimes),
					   (int)_vehicle.SumOfCollisionFreeTimes,
					   _vehicle.CountOfCollisionFreeTimes);
			}

			status.AppendFormat("\n\nStuck count: {0} ({1} cycles, {2} off path)",
				_vehicle.StuckCount,
				_vehicle.StuckCycleCount,
				_vehicle.StuckOffPathCount);
			status.Append("\n\n[F1] ");
			if (1 == MapDriver.DemoSelect) status.Append("wander, ");
			if (2 == MapDriver.DemoSelect) status.Append("follow path, ");
			status.Append("avoid obstacle");

			if (2 == MapDriver.DemoSelect)
			{
				status.Append("\n[F2] path following direction: ");
			    status.Append(_vehicle.PathFollowDirection > 0 ? "+1" : "-1");
			    status.Append("\n[F3] path fence: ");
			    status.Append(_usePathFences ? "on" : "off");
			}

			status.Append("\n[F4] rocks: ");
		    status.Append(_useRandomRocks ? "on" : "off");
		    status.Append("\n[F5] prediction: ");
		    status.Append(_vehicle.CurvedSteering ? "curved" : "linear");
		    if (2 == MapDriver.DemoSelect)
			{
				status.AppendFormat("\n\nLap {0} (completed: {1}%)",
					_vehicle.LapsStarted,
					   ((_vehicle.LapsStarted < 2) ? 0 :
						   (int)(100 * ((float)_vehicle.LapsFinished /
										 (_vehicle.LapsStarted - 1))))
					   );

				status.AppendFormat("\nHints given: {0}, taken: {1}",
					_vehicle.HintGivenCount,
					_vehicle.HintTakenCount);
			}
			status.Append("\n");
			qqqRange("WR ", MapDriver.SavedNearestWR, status);
			qqqRange("R  ", MapDriver.SavedNearestR, status);
			qqqRange("L  ", MapDriver.SavedNearestL, status);
			qqqRange("WL ", MapDriver.SavedNearestWL, status);
			Vector3 screenLocation = new Vector3(15, 50, 0);
			Vector3 color = new Vector3(0.15f, 0.15f, 0.5f);
			Drawing.Draw2dTextAt2dLocation(status.ToString(), screenLocation, new Color(color.ToXna()));

			{
				float v = Drawing.GetWindowHeight() - 5;
				const float M = 10;
				float w = Drawing.GetWindowWidth();
				float f = w - (2 * M);

				// limit tick mark
				float l = _vehicle.AnnoteMaxRelSpeed;
//.........这里部分代码省略.........
开发者ID:cupsster,项目名称:SharpSteer2,代码行数:101,代码来源:MapDrivePlugIn.cs

示例2: DrawPath

		// draw the GCRoute as a series of circles and "wide lines"
		// (QQQ this should probably be a method of Path (or a
		// closely-related utility function) in which case should pass
		// color in, certainly shouldn't be recomputing it each draw)
		public void DrawPath()
		{
			Vector3 pathColor = new Vector3(0, 0.5f, 0.5f);
			Vector3 sandColor = new Vector3(0.8f, 0.7f, 0.5f);
			Vector3 vColor = Vector3.Lerp(sandColor, pathColor, 0.1f);
			Color color = new Color(vColor.ToXna());

			Vector3 down = new Vector3(0, -0.1f, 0);
			for (int i = 0; i < Path.PointCount; i++)
			{
				Vector3 endPoint0 = Path.Points[i] + down;
				if (i > 0)
				{
					Vector3 endPoint1 = Path.Points[i - 1] + down;

					float legWidth = Path.Radii[i];

					Drawing.DrawXZWideLine(endPoint0, endPoint1, color, legWidth * 2);
					Drawing.DrawLine(Path.Points[i], Path.Points[i - 1], new Color(pathColor.ToXna()));
					Drawing.DrawXZDisk(legWidth, endPoint0, color, 24);
					Drawing.DrawXZDisk(legWidth, endPoint1, color, 24);
				}
			}
		}
开发者ID:cupsster,项目名称:SharpSteer2,代码行数:28,代码来源:MapDriver.cs


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