Unity3d物理汽车第二篇
1.第一篇留下的问题,还没有得到解答!我目前的结论就是可以赋值为负值!
2.我自己用了个方块做为车身,然后用四个轮子,把代码套了上去,车子竟然一动不动!
并且出现了以下警告:
MissingComponentException: There is no 'AudioSource' attached to the "Cube" game object, but a script is trying to access it.
You probably need to add a AudioSource to the game object "Cube". Or your script needs to check if the component is attached before using it.
PlayerCar_Script.Update () (at Assets/Scripts/Car Control/PlayerCar_Script.js:48)
我贴出来48行的代码:
audio.pitch = Mathf.Abs(EngineRPM / MaxEngineRPM) + 1.0 ;
就是audio,但是我忘了给物理车添加Audio Source(音频源),导致程序出现警告,导致后面的程序没有执行!
所以,汽车就没有开动了!当大家遇到警告的提示之后,一定要分析原因,检查问题!养成良好的分析问题的习惯,这就是积累经验的时候了!
Audio Source中一个参数pitch是音频源的音调!这里的audio.pitch的最大值是2;
3.现在贴出来车轮与地面碰撞的代码!JS语言写的!
//车轮碰撞器
var CorrespondingCollider : WheelCollider;
//车轮印
var SlipPrefab : GameObject; //车轮的旋转值
private var RotationValue : float = 0.0; //更新函数
function Update () {
//光线投射碰撞,用来获取从raycast函数中得到的信息反馈的结构。
var hit : RaycastHit;
//WheelCollider是挂在一个空物体上的Transform上,所以,要用空物体的变换去变换
WheelCollider的中心点(本地坐标的点),这样ColliderCenterPoint就是世界坐标中的点了!
var ColliderCenterPoint : Vector3 = CorrespondingCollider.transform.TransformPoint( CorrespondingCollider.center );
//最主要的部分
//光线投射,从ColliderCenterPoint的位置,向CollesponndingCollider.transform.down方向,发射一条长度为 (车轮悬挂的最大延长距离(suspensionDistance)+车轮碰撞器的半径(radius))的线段!准确的叫线段!返回hit这个信息
if ( Physics.Raycast( ColliderCenterPoint, -CorrespondingCollider.transform.up, hit, CorrespondingCollider.suspensionDistance + CorrespondingCollider.radius ) )
{
//如果这条线段碰撞到了物体!
//设置车轮物体(不是车轮碰撞器)的坐标为碰撞点的坐标+车轮碰撞器的半径
transform.position = hit.point + (CorrespondingCollider.transform.up * CorrespondingCollider.radius);
}else{//如果没有碰撞,就让车轮物体,不断下落,每帧下落(车轮悬挂的最大延长距离(suspensionDistance))的 距离
transform.position = ColliderCenterPoint - (CorrespondingCollider.transform.up * CorrespondingCollider.suspensionDistance);
} }
//车轮物体的旋转为 车轮碰撞器所附加的空物体的变换*车轮碰撞器绕x旋转RotationValue,
//绕Y轴旋转steerAngle,绕Z轴旋转0度
WheelCollider.steerAngel返回车轮碰撞器绕自身Y轴旋转的角度
//乘法的顺序很重要,这里的意思,实际中是先后面的旋转,再前面的旋转!
transform.rotation = CorrespondingCollider.transform.rotation * Quaternion.Euler( RotationValue, CorrespondingCollider.steerAngle, 0 );
// 累加RatationValue 每一帧车轮的旋转值为rpm*6*Time.deltaTime
RotationValue += CorrespondingCollider.rpm * ( 360/60 ) * Time.deltaTime; //WheelHit是有WheelCollider返回的碰撞信息
var CorrespondingGroundHit : WheelHit;
//返回WheelHit
CorrespondingCollider.GetGroundHit( CorrespondingGroundHit );
//WheelCollider.sidewaySlip是侧轮滑动的值,如果这个值大于2.0,则复制一个粒子对象,做为车轮印!
if ( Mathf.Abs( CorrespondingGroundHit.sidewaysSlip ) > 2.0 ) {
if ( SlipPrefab ) { //复制 , SlipPrefab原物体,WheelCollider.point车轮其它物体碰撞点的位置,Quaternion.identity,不进行任何旋转
Instantiate( SlipPrefab, CorrespondingGroundHit.point, Quaternion.identity );
}
}
我有理解不正确的地方,麻烦指正一下……!
下一篇总结一下,呵呵!