下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、.在以前的仿真项目中用到了第三人称视角的移动,W、S、A、D 控制角色的前后左右移动,摄像机跟随角色移动,并且摄像机做了缓冲处理。鼠标右键长按旋转控制镜头旋转,中键滑轮控制镜头拉进拉远。分为两个脚本,CharacterThirdControl挂在角色身上, CameraThirdControl 挂在跟随摄像机身上。角色的标签设置为 Player 。跟随摄像机为主摄像机(可以根据自己需求改变)。下面直接贴代码,代码中已有注释:using UnityEngine;using System.Collections;RequireComponent( typeof (CharacterControll
2、er)publicclassCharacterThirdControl: MonoBehaviour Transform myCamera;/ 跟随摄像机privateCharacterController cc;Vector3 playerDirect;/ 角色的目标方向Vector3 correctDirect;/ 为了矫正计算方向向量的误差floatperError = 0.2f;/ 误差与摄像机缓冲存在关系floatspeed = 0.1f;/ 速度与 Update的帧数有关,同样数据帧数越多,速度越快Vector3 front;/ 前Vector3 back;/ 后Vector3 l
3、eft;/ 左Vector3 right;/ 右/ Use this for initialization void Start()myCamera = Camera.main.transform;/ 将主摄像机设置为跟随摄像机front = Vector3.zero;back = Vector3.zero;left = Vector3.zero;right = Vector3.zero;correctDirect = Vector3.zero;cc = transform.GetComponent<CharacterController>();void LateUpdate()P
4、layerControl();/ <summary>/ 计算方向向量函数/ </summary>privatevoid CalculateDirection()Vector3 temp = transform.position - myCamera.position;temp =new Vector3(temp.x, 0, temp.z);front = temp;if(correctDirect!=Vector3.zero && Mathf.Abs(correctDirect.x-front.x)< perError &&Math
5、f.Abs(correctDirect.z - front.z) < perError)/ 判断是否在误差范围内front = correctDirect;back = -front;1 / 5.left =new Vector3(-front.z, 0, front.x);right = -left;correctDirect = front;/ <summary>/ 控制角色移动/ </summary>privatevoid PlayerControl()playerDirect =new Vector3(0, 0, 0);CalculateDirection
6、();/ 计算角色的方向if(Input.GetAxis("Horizontal") < 0)/ 左playerDirect = left;if(Input.GetAxis("Horizontal") > 0)/ 右playerDirect = right;if(Input.GetAxis("Vertical") > 0)if(Input.GetAxis("Horizontal") < 0)/ 前左playerDirect = front + left;elseif(Input.GetAxi
7、s("Horizontal") > 0)/ 前右playerDirect = front + right;elseplayerDirect = front;/ 前if(Input.GetAxis("Vertical") < 0)if(Input.GetAxis("Horizontal") < 0)/ 后左playerDirect = back + left;elseif(Input.GetAxis("Horizontal") > 0)/ 后右playerDirect = back + rig
8、ht;elseplayerDirect = back;/ 后2 / 5.if(playerDirect != Vector3.zero)playerDirect += transform.position;MoveSpeed(playerDirect);/ <summary>/ 调整角色方向,控制角色移动/ </summary>privatevoid MoveSpeed(Vector3 direct)transform.LookAt(new Vector3(direct.x, transform.position.y, direct.z);cc.Move(transfo
9、rm.forward * speed);using UnityEngine;using System.Collections;publicclassCameraThirdControl: MonoBehaviourRange(0, 1)SerializeFieldfloattarget_offsety = 0.6f;/ 高度差Range(0, 90)SerializeFieldfloatinitRotate = 15f;/ 摄像机角度Range(2, 10)SerializeFieldfloatDISTANCE_DEAFULT = 3.2f;/ 设置摄像机与物体之间的距离Transform t
10、arget;/ 摄像机跟随的角色privatefloatdistance;privateVector3 playerTarget;privatefloatlastRotate;/ Use this for initialization void Start()lastRotate = initRotate;distance = DISTANCE_DEAFULT;/ 设置摄像机与角色的距离target = GameObject.FindGameObjectWithTag("Player").transform;/ 找到角色playerTarget =new Vector3(t
11、arget.position.x, target.position.y + target_offsety,target.position.z);/ 设置摄像机对着角色的位置Quaternion cr = Quaternion.Euler(initRotate, transform.eulerAngles.y, 0);/ 设置3 / 5.摄像机与角色之间的角度/ 计算摄像机的位置Vector3 positon = playerTarget; positon += cr * Vector3.back * distance; transform.position = positon; transfo
12、rm.rotation = target.rotation; transform.LookAt(playerTarget);/ Update is called once per frame void Update()/ 鼠标右键控制镜头转动if(Input.GetMouseButton(1)transform.RotateAround(playerTarget, Vector3.up, Input.GetAxis("Mouse X" )*3f);/ 更新摄像机的位置角度等信息 void LateUpdate()playerTarget =new Vector3(targe
13、t.position.x, target.position.y + target_offsety,target.position.z);Quaternion cr = Quaternion.Euler(initRotate, transform.eulerAngles.y, 0);Vector3 positon = playerTarget + (cr * Vector3.back * distance);RaycastHit hits = Physics.RaycastAll(new Ray(playerTarget, (positon -playerTarget).normalized);
14、distance = DISTANCE_DEAFULT;if(hits.Length > 0)RaycastHit stand =new RaycastHit();floatmaxDistance =float .MaxValue;foreach (RaycastHit hitin hits)if (!hit.collider.isTrigger && != && hit.distance < maxDistance)stand = hit;maxDistance = stand.dista
15、nce;if(stand.collider !=null )stringtag = stand.collider.gameObject.tag;distance = Vector3.Distance(stand.point, playerTarget);if(distance > DISTANCE_DEAFULT)distance = DISTANCE_DEAFULT;positon = playerTarget + (cr * Vector3.back * distance);transform.position = Vector3.Lerp(transform.position, positon, 0.5f);/ 用于摄像4 / 5.机的缓冲,与误差存在关系Debug.DrawRay(playerTarget, positon - playerTarget, Color.red);if(lastRotate != initRotate)transform.LookAt(playerTarget);lastRotate = initRotate;/ 鼠标中
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 宣城市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解ab卷
- 荆门市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(a卷)
- 济南市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(能力提升)
- 延庆县农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(轻巧夺冠)
- 武威市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(黄金题型)
- 邵阳市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)及答案详解(历年真题)
- 北海市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(夺分金卷)
- 九江市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)含答案详解(夺分金卷)
- 鹤壁市农村信用社联合社秋季校园招聘笔试备考题库(浓缩500题)附答案详解(a卷)
- 物业管理员考试试题附答案
- 淤地坝知识培训课件
- 保密知识培训课件
- 2025昆明幼儿师范高等专科学校引进高层次人才(6人)考试模拟试题及答案解析
- 徐志摩的诗课件
- 五年级上册体育全册教案(2025-2026学年)(表格式)
- GB/T 46225-2025柔性多孔聚合物材料层压用聚氨酯泡沫规范
- 2025年日照盐粮集团有限公司公开招聘工作人员备考考试题库附答案解析
- 2025学年第一学期江浙皖高中(县中)发展共同体高三语文10月联考试题文言文详解:《宋史·陈兢传》、王夫之《宋论》
- 2025年农村会计考试试题及答案
- 2025浙江杭州市发展和改革委员会所属事业单位招聘高层次、紧缺人才4人笔试模拟试题及答案解析
- 2025-2026学年高一生物上学期第一次月考生物试卷(江苏)
评论
0/150
提交评论