位置: 编程技术 - 正文

Unity3d 赛车车辆各类性能算法(unity3d赛车游戏毕业设计)

编辑:rootadmin
欢迎来到unity学习、unity培训、unity企业培训教育专区,这里有很多Unity3D资源、Unity3D培训视频、Unity3D教程、Unity3D常见问题、Unity3D项目源码,【狗刨学习网】unity极致学院,致力于打造业内unity3d培训、学习第一品牌。   在制作前,必须先了解真实车辆的原理:  车辆分前轮驱动,后轮驱动和四驱动。动力由引擎提供,反应的力到轮胎上,因此产生转数,即RPM。  引擎的功率可以由RPM得到公式为 : RPM = 引擎功率/2pi , 这些都是模拟,只为了更好的为下面的动作服务。还有大众关心的"漂移" ,所谓 漂移就是,在后驱车辆中,前轮方向旋转大角度,地面给于一定向心力,同时后轮又给予更多动力,导致"漂移"动作。  基于上面原理,就更容易理解下面的文章。  我先说明,有非常多种方法来开发一款赛车。本人赛车版本经过无数多种方法,无数次改版后最终选了个大众接受的。这些方法,容我一个个道来。  首先,你要明白,车辆不可能整个套一个外壳,原因是在接触地面时,对车辆所使的力不可能达到你预期的目标,引起,必须在车辆轮胎以上做外壳碰撞,轮胎以下就需要有力来支持它始终保持不掉下来。  Unity3d里有个很神奇的东西 叫WheelCollider , 它是专门模拟轮胎支持力和轮胎转数,以及轮胎横向力,前进力,以及 悬架避震系统。  这个东西非常方便,只要你把这个东西套在4个轮胎上,调试下他的forwardFriction 和 sidewaysFriction  达到你想要的效果,然后对驱动轮的motorTorque进行赋&#;,你的车辆就能动了。  记得你需要无数次调试 前进摩擦力和横向摩擦力 。  至于悬架系统在你需要时也可以改变其&#;。还有,这两个摩擦力,是一个由低到高,再由高到稳定的一条曲线。  这个WheelCollider非常好用,曾一度沉迷于此。但后来发现,他有很多不合理的地方。想要得到最好的效果,还是抛弃了他。  为了支持车辆的碰撞外壳不接触地面,必须写一个悬架动态支持力,在4个轮胎位置,支持整辆车悬浮于地面之上。  关于这个悬架动态支持力在这奉献下:  void SuspensionHoldForce()  {  float fullCompressionSpringForce = this.rigidbody.mass * 0.f * 2.0f * -Physics.gravity.y;  this.OnGround = true;  foreach( GameObject item in FwheelModels )  {  RaycastHit hit;  bool onGround = Physics.Raycast( item.transform.parent.position , -item.transform.parent.InverseTransformDirection(Vector3.up), out hit, this.suspensionTravel &#; this.radius);  if (onGround hit.collider.isTrigger)  {  onGround = false;  float dist = this.suspensionTravel &#; this.radius;  RaycastHit[]  hits = Physics.RaycastAll( item.transform.parent.position , -item.transform.parent.InverseTransformDirection(Vector3.up) , this.suspensionTravel &#; this.radius );  foreach(RaycastHit test in hits)  {  if (!test.collider.isTrigger test.distance = dist)  {  hit = test;  onGround = true;  dist = test.distance;  }  }  }  if( onGround )  {  Vector3 wheelVelo = this.rigidbody.GetPointVelocity (item.transform.parent.position);  Vector3 localVelo = transform.InverseTransformDirection (wheelVelo);  Vector3 groundNormal = transform.InverseTransformDirection (hit.normal);  float damperForce = Vector3.Dot(localVelo, groundNormal) * f;  float compression = 1.0f - ((hit.distance - radius) / suspensionTravel);  Vector3 springForce = ( fullCompressionSpringForce*compression - damperForce ) * item.transform.parent.InverseTransformDirection(Vector3.up);  springForce.z = springForce.x = 0f;  this.rigidbody.AddForceAtPosition( springForce , item.transform.parent.position );  }  else  {  this.OnGround = false;  }  }  foreach( GameObject item in BwheelModels )  {  RaycastHit hit;  bool onGround = Physics.Raycast( item.transform.parent.position, -item.transform.parent.InverseTransformDirection(Vector3.up), out hit, this.suspensionTravel &#; this.radius);  if (onGround hit.collider.isTrigger)  {  onGround = false;  float dist = this.suspensionTravel &#; this.radius;  RaycastHit[]  hits = Physics.RaycastAll( item.transform.parent.position, -item.transform.parent.InverseTransformDirection(Vector3.up) , this.suspensionTravel &#; this.radius );  foreach(RaycastHit test in hits)  {  if (!test.collider.isTrigger test.distance = dist)  {  hit = test;  onGround = true;  dist = test.distance;  }  }  }  if( onGround )  {  Vector3 wheelVelo = this.rigidbody.GetPointVelocity (item.transform.parent.position);  Vector3 localVelo = transform.InverseTransformDirection (wheelVelo);  Vector3 groundNormal = transform.InverseTransformDirection (hit.normal);  float damperForce = Vector3.Dot(localVelo, groundNormal) * f;  float compression = 1.0f - ( ( hit.distance - radius ) / suspensionTravel );  Vector3 springForce = ( fullCompressionSpringForce*compression - damperForce ) * item.transform.parent.InverseTransformDirection(Vector3.up);  springForce.z = springForce.x = 0f;  this.rigidbody.AddForceAtPosition( springForce , item.transform.parent.position );  }  else  {  this.OnGround = false;  }  }  }  那么在完成悬架支撑后,就该设计车辆动力了。  这里也有2种方法:一个方向是真实车辆行驶轨迹,另一个是模拟型车辆轨迹。  前者的方法是 , 将动力点放在车辆驱动轮上,例如后轮。用rigidbody的AddForceAtPosition可以做到,前轮只需要提供横向力就可以实现转弯的轨迹。但别看说说这么容易,这里面还涉及非常多的数&#;和曲线问题。在提供车辆动力时,你需要一条曲线,以致车辆不会匀加速,因为这样很不真实,还有在前轮横向力中,你必需是条由0到最高点,然后下降到平衡点的曲线。这样你的赛车才显得更真实。这些都需要用到几个数学知识。  后者,是用算法来模拟的一种车辆轨迹。这个算法所有作用力作用在车辆的中心点。  转弯轨迹,我是用转弯半径来表示,使得车辆在转弯时有相当的真实性,必须改变车辆转弯速度。当然,用到了些数学知识。代码奉献下:  #region 计算转弯角度  void Steering( bool canSteer , Vector3 relativeVelocity )  {  if( canSteer this.OnGround )  {  if( this.shiftthrottle == 1 )  {  this.transform.RotateAround( this.transform.TransformPoint( ( this.FwheelModels[0].transform.localPosition &#; this.FwheelModels[1].transform.localPosition) * 0.5f ) , this.transform.up , this.rigidbody.velocity.magnitude *2f* this.steeringInput * Time.deltaTime * 2f );  //~ this.rigidbody.AddForceAtPosition( this.FwheelModels[0].transform.TransformDirection(Vector3.right*this.steeringInput) * 3f * this.rigidbody.mass, this.FwheelModels[0].transform.position);  //~ this.rigidbody.AddForceAtPosition( this.FwheelModels[1].transform.TransformDirection(Vector3.right*this.steeringInput) * 3f * this.rigidbody.mass, this.FwheelModels[1].transform.position);  return ;  }  if( this.throttle * this.transform.InverseTransformDirection(this.rigidbody.velocity).z 0 )  return ;  float turnRadius = 3.0f / Mathf.Sin( (f - this.steering) * Mathf.Deg2Rad );  float minMaxTurn = EvaluateSpeedToTurn(this.rigidbody.velocity.magnitude);  float turnSpeed = Mathf.Clamp(relativeVelocity.z / turnRadius, -minMaxTurn / , minMaxTurn / );  this.transform.RotateAround( this.transform.position &#; this.transform.right * turnRadius * this.steeringInput , transform.up , turnSpeed * Mathf.Rad2Deg * Time.deltaTime * this.steeringInput );  //~ Vector3 debugStartPoint = transform.position &#; transform.right * turnRadius * this.steeringInput;  //~ Vector3 debugEndPoint = debugStartPoint &#; Vector3.up * 5f;  //~ Debug.DrawLine(debugStartPoint, debugEndPoint, Color.red);  }  }  float EvaluateSpeedToTurn( float speed )  {  if(speed this.topSpeed / 2)  return minimumTurn;  float speedIndex = 1 - ( speed / ( this.topSpeed / 2 ) );  return minimumTurn &#; speedIndex * (maximumTurn - minimumTurn);  }  #endregion  这个模拟车辆轨迹,不能达到漂移的性能,但我加了一个滑动比例计算的算法,用车辆横向移动速度,和前进速度,的比例来确定,该车辆是否处于漂移状态,如处于,则启动漂移滑动程序。当然,我的赛车是很自然的,不做做。至于轮胎痕迹,就是判断是否触底后,在该点生成轮胎痕迹gameobject,如此而已。  最后,再介绍下,所有车辆都需要模拟的,行驶时,轮胎随速度旋转这个关系到车辆看起来真实性的东西。其实非常简单。不多说,发代码:  #region 轮胎滚动与旋转模拟  void WheelRoll()  {  float averageAngularVelo = ( this.rigidbody.GetPointVelocity(this.BwheelModels[0].transform.parent.position).magnitude &#; this.rigidbody.GetPointVelocity(this.BwheelModels[0].transform.parent.position).magnitude )/2f;  float engineAngularVelo = averageAngularVelo * 3f;  float rpm = engineAngularVelo * (.0f/(2*Mathf.PI)) * (this.transform.InverseTransformDirection(this.rigidbody.velocity).z 0f ? 1f : -1f );  //~ Debug.Log(this.transform.InverseTransformDirection(this.rigidbody.velocity).z);  FwheelModels[0].transform.rotation = FwheelModels[0].transform.parent.rotation * Quaternion.Euler (RotationValue, this.steering , 0);//旋转  FwheelModels[1].transform.rotation = FwheelModels[1].transform.parent.rotation * Quaternion.Euler (RotationValue, this.steering , 0);//旋转  BwheelModels[0].transform.rotation = BwheelModels[0].transform.parent.rotation * Quaternion.Euler (RotationValue, 0, 0);//旋转  BwheelModels[1].transform.rotation = BwheelModels[1].transform.parent.rotation * Quaternion.Euler (RotationValue, 0, 0);//旋转  RotationValue &#;= rpm * ( f/f ) * Time.deltaTime;  }  #endregion更多内容,请访问【狗刨学习网】unity极致学院声明:此篇文档时来自于【狗刨学习网】社区-unity极致学院,是网友自行发布的Unity3D学习文章,如果有什么内容侵犯了你的相关权益,请与官方沟通,我们会即时处理。

推荐整理分享Unity3d 赛车车辆各类性能算法(unity3d赛车游戏毕业设计),希望有所帮助,仅作参考,欢迎阅读内容。

Unity3d 赛车车辆各类性能算法(unity3d赛车游戏毕业设计)

文章相关热门搜索词:unity3d赛车游戏毕业设计,unity出品的单机游戏赛车,unity3d汽车,unity出品的单机游戏赛车,unity赛车模型,unity3d赛车游戏的制作方法,unity3d赛车游戏教程,unity3d赛车游戏的制作方法,内容如对您有帮助,希望把文章链接给更多的朋友!

TFC冯燃:手游市场细分领域新秀崛起 狗刨学习网报道/3月日上午,第十届TFC全球移动游戏大会在北京国际会议中心开幕。本届大会以寻路、跨界、融合为主题,吸引了超过位业内重量

Unity手机游戏录像、录音sdk介入(游戏陀螺WeRecSDK) 这东西不错,如果项目需要录像回放功能,可以使用。但是在介入之前建议先试试手动的

浅析游戏引擎的资源管理机制——扒一扒Unity3D中隐藏在背后的资源管理 游戏中通常有大量资源,如网、材质、纹理、动画、着色器程序和音乐等,游戏引擎作为做游戏的工具,自然要提供良好的资源管理,让游戏开发者用

标签: unity3d赛车游戏毕业设计

本文链接地址:https://www.jiuchutong.com/biancheng/383601.html 转载请保留说明!

上一篇:Unity3D研究之角色控制器组件研究(unity 设置物体角度)

下一篇:TFC360冯燃:手游市场细分领域新秀崛起

  • 计提坏账为什么是递延所得税资产
  • 进口货物增值税纳税人是谁
  • 小规模纳税人一般纳税人区别
  • 其他项目工会筹备金怎么报税
  • 金税盘服务费能抵税吗
  • 用库存现金支付职工医药费用69元,会计人员
  • 企业新增固定资产流程图
  • 计算错误多缴税怎么处理
  • 投资收益可以计入营业收入吗
  • 去年发生的成本但今年9月份才开票付款
  • 残料的会计分录
  • 什么是城镇土地使用税
  • 增值税税控系统技术维护费计入什么科目
  • 不能远程补报之前的税款所属期
  • 发票密码区出来了一点
  • 收益性支出包括哪些科目
  • 存货跌价准备转销
  • 保洁属于劳务报酬吗
  • 投资基金是什么科目
  • 3联收据
  • 印花税纳税申报表填写范本
  • 代扣代缴个人工会经费 企业所得税
  • 银行存款期末调汇吗
  • php字符串型数据的定义方式
  • 怎么开通公众号微信公众平台
  • php浮点数四舍五入
  • 不抵扣的进项税怎么做账
  • node与nodejs
  • 网络命令traceroute
  • 开发票纸巾属于什么编码
  • 小规模纳税人研发费用加计扣除优惠政策
  • 支付兼职工资账务处理
  • 开票显示税收分录怎么办
  • 勾选认证客户端不成功怎么办
  • 存货盘盈盘亏处理会计分录
  • 开具红字增值税普通发票
  • 工资发放用现金
  • 营业外收入如何纳税
  • mysql数据库sid
  • 购买礼品送客户取得普票怎么做账
  • 转让无形资产或其他资产
  • 住房公积金指的是什么意思
  • 幼儿园财务科目明细表
  • 电子承兑汇票接收流程
  • 增值税怎么开
  • 如何冲减计提费用
  • 没有发票会怎样
  • 关联企业费用分摊账务
  • 开发票货款未公对公转如何做账?
  • 房屋租赁违约金比例
  • 收到错误发票已入账跨月重新开会计分录
  • 省外出差
  • 自产商品无偿赠送是否确认收入
  • 其他业务收入如何开票
  • 2021年异地转账还收费吗
  • 营改增之后还有营业税金及附加吗
  • 原材料会计科目
  • 总分类账户与明细分类账户的关系
  • sqlserver数据导出导入脚本
  • 用OpenBSD 3.8 release自带的FTPD架设FTP服务器
  • linux系统输入法锁定了怎么解开
  • sm56hlpr.exe - sm56hlpr是什么进程
  • AquariumDesktop.exe进程危险吗 AquariumDesktop是什么进程
  • win101909玩dnf怎么样
  • synchost.exe - synchost是什么进程 有什么作用
  • 手把手教您安装软件
  • 电脑迅雷影音在哪个文件夹
  • js观察者模式和发布订阅
  • 应用web标准实例是什么
  • 怎样用div css制作网页
  • css教程大全
  • 欢迎使用城市供水信息服务平台
  • unity3d apk
  • 各种手机ui大全
  • Python黑魔法手册
  • 三水水厂热线电话号码
  • 所得税季度报表收入成本怎么填
  • 国地税合并人员瘦身
  • 报纸的增值税税率
  • 税务筹划前景
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设