[脚本]实现游戏对象跟随鼠标方向移动

简介: 如何实现游戏对象跟随鼠标方向移动。 效果:当点击鼠标左键时,游戏对象会朝鼠标点击的方向移动(类似魔兽争霸)。 思路:把鼠标的坐标转化成世界坐标(鼠标默认是屏幕坐标),然后当点击鼠标时,物体将朝着鼠标的世界坐标方向移动。

如何实现游戏对象跟随鼠标方向移动。

效果:当点击鼠标左键时,游戏对象会朝鼠标点击的方向移动(类似魔兽争霸)。

思路:把鼠标的坐标转化成世界坐标(鼠标默认是屏幕坐标),然后当点击鼠标时,物体将朝着鼠标的世界坐标方向移动。

<font style="color:rgb(85, 85, 85)"><font face="微软雅黑">var world:Vector3;
 
var speed:float=0;//物体的移动速度
 
function Update (){
 
var screenpos=Camera.main.WorldToScreenPoint(transform.position);//物体的世界坐标转化成屏幕坐标
 
var e:Vector3=Input.mousePosition;//鼠标的位置
 
//当点击鼠标左键时
 
if(Input.GetMouseButton(0)){
 
e.z=screenpos.z;//1.因为鼠标的屏幕 Z 坐标的默认值是0,所以需要一个z坐标
 
world=Camera.main.ScreenToWorldPoint(e);
 
speed=1;
 
}
 
if(transform.position==world){
 
speed=0;
 
}else{
 
animation.Play("walk");//这是我自身带的一个默认动画,你可以把它删了
 
}
 
transform.LookAt(world); //物体朝向鼠标
 
transform.Translate(Vector3.forward*speed*Time.deltaTime);
 
}</font></font>


上面脚本适合垂直平面,即摄像头垂直x-z平面,但一般游戏都不会垂直的。如果不垂直的话,用上面方法可能就会出现类似游戏对象穿透地面的现象,所以需要修改改一下代码。就只用把world=Camera.main.ScreenToWorldPoint(e); 改成以下这句就行了。(穿透地面现象是Y轴,所以让y轴不变,且大小等于游戏对象的y值。)


<font style="color:rgb(85, 85, 85)"><font face="微软雅黑">world.x=Camera.main.ScreenToWorldPoint(e).x;

world.z=Camera.main.ScreenToWorldPoint(e).z;
       world.y=transform.position.y;</font></font>

相关文章
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
|
9月前
Three.js开发:修改默认鼠标操控
Three.js开发:修改默认鼠标操控
124 0
|
8月前
|
机器学习/深度学习 决策智能
Baxter实战 (五)安装openNI2,NiTE-2并实现kinect 2实现动作跟随
Baxter实战 (五)安装openNI2,NiTE-2并实现kinect 2实现动作跟随
157 0
|
9月前
控制歌词滚动案例
控制歌词滚动案例
54 0
|
9月前
|
数据安全/隐私保护 iOS开发 芯片
将任意应用窗口置顶显示,这个工具太强了。
将任意应用窗口置顶显示,这个工具太强了。
|
11月前
|
开发工具 开发者
在屏幕的任意位置拖拽,控制精灵移动
在屏幕的任意位置按住拖拽,然后控制屏幕中指定的精灵移动,这个前几天@stack发过一个示例,刚好最近又有几位同学来问,说是看不懂其中的逻辑。索性就在这里详细的讲一下,原理很简单,理解透了原理,其中的积木逻辑也就很容易理解了。
80 0
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
在之前的学习内容中,我们学习了使用键盘控制我们的代码小游戏,硬件也不只有键盘吧,还缺啥?那肯定是我们的鼠标,键盘的交互,我们使用了下面这种类型的代码,进行AWSD移动操作,十分简单。而我们今天的鼠标,也同样简洁易懂。
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
|
编解码 前端开发
前端设置页面字体尺寸跟随屏幕大小而进行变化
前端设置页面字体尺寸跟随屏幕大小而进行变化
486 0
前端设置页面字体尺寸跟随屏幕大小而进行变化
|
前端开发 JavaScript 开发者
让交互更加生动!有意思的鼠标跟随 3D 旋转动效
让交互更加生动!有意思的鼠标跟随 3D 旋转动效
313 0
让交互更加生动!有意思的鼠标跟随 3D 旋转动效
|
前端开发 JavaScript
【前端三分钟】锚点自动跟随滚动定位
【前端三分钟】锚点自动跟随滚动定位
652 0