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

简介:

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

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

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

<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>



















本文转自蓬莱仙羽51CTO博客,原文链接:http://blog.51cto.com/dingxiaowei/1366507,如需转载请自行联系原作者


相关文章
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
Qml实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
Three.js开发:修改默认鼠标操控
Three.js开发:修改默认鼠标操控
213 0
|
7月前
|
索引
消除游戏中图标下落的原理和实现
消除游戏中图标下落的原理和实现
49 1
控制歌词滚动案例
控制歌词滚动案例
78 0
|
数据安全/隐私保护 iOS开发 芯片
将任意应用窗口置顶显示,这个工具太强了。
将任意应用窗口置顶显示,这个工具太强了。
|
开发工具 开发者
在屏幕的任意位置拖拽,控制精灵移动
在屏幕的任意位置按住拖拽,然后控制屏幕中指定的精灵移动,这个前几天@stack发过一个示例,刚好最近又有几位同学来问,说是看不懂其中的逻辑。索性就在这里详细的讲一下,原理很简单,理解透了原理,其中的积木逻辑也就很容易理解了。
120 0
|
数据可视化 JavaScript 前端开发
【视觉高级篇】18 # 如何生成简单动画让图形动起来?
【视觉高级篇】18 # 如何生成简单动画让图形动起来?
94 0
【视觉高级篇】18 # 如何生成简单动画让图形动起来?
|
编解码 前端开发
前端设置页面字体尺寸跟随屏幕大小而进行变化
前端设置页面字体尺寸跟随屏幕大小而进行变化
658 0
前端设置页面字体尺寸跟随屏幕大小而进行变化
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
在之前的学习内容中,我们学习了使用键盘控制我们的代码小游戏,硬件也不只有键盘吧,还缺啥?那肯定是我们的鼠标,键盘的交互,我们使用了下面这种类型的代码,进行AWSD移动操作,十分简单。而我们今天的鼠标,也同样简洁易懂。
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
|
iOS开发
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)
138 0
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)