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

简介:

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

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

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

<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实用技巧:在可视元素之前半透明覆盖一个可视元素,阻止鼠标透(界面)传(防止点击到被遮挡的按钮)
|
4天前
|
定位技术
Pyglet综合应用|推箱子游戏地图编辑器之图片跟随鼠标
Pyglet综合应用|推箱子游戏地图编辑器之图片跟随鼠标
15 0
|
9月前
Three.js开发:修改默认鼠标操控
Three.js开发:修改默认鼠标操控
126 0
|
9月前
控制歌词滚动案例
控制歌词滚动案例
54 0
|
11月前
|
开发工具 开发者
在屏幕的任意位置拖拽,控制精灵移动
在屏幕的任意位置按住拖拽,然后控制屏幕中指定的精灵移动,这个前几天@stack发过一个示例,刚好最近又有几位同学来问,说是看不懂其中的逻辑。索性就在这里详细的讲一下,原理很简单,理解透了原理,其中的积木逻辑也就很容易理解了。
80 0
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
在之前的学习内容中,我们学习了使用键盘控制我们的代码小游戏,硬件也不只有键盘吧,还缺啥?那肯定是我们的鼠标,键盘的交互,我们使用了下面这种类型的代码,进行AWSD移动操作,十分简单。而我们今天的鼠标,也同样简洁易懂。
【C语言】——实现鼠标与画布(黑框)交互,根据鼠标移动,进行你所想要的个性体验
|
iOS开发
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)
120 0
iOS开发 - 渐变导航条升级版(判断滚动的方向和改变方向时的位置)
|
前端开发 JavaScript Serverless
移动端弹出阴影遮罩的几点问题和解决方法
在做移动端的立即购买页面时,点击底部固定栏立即购买按钮需要弹出一个阴影遮罩,在遮罩顶部有一个固定在底部的页面,所以总共是3层页面:最底层浏览页->阴影遮罩页->最上层的立即购买选择规格数量页;效果如下图:
199 0
移动端弹出阴影遮罩的几点问题和解决方法
|
编解码 前端开发
前端设置页面字体尺寸跟随屏幕大小而进行变化
前端设置页面字体尺寸跟随屏幕大小而进行变化
488 0
前端设置页面字体尺寸跟随屏幕大小而进行变化
|
前端开发 JavaScript
【前端三分钟】锚点自动跟随滚动定位
【前端三分钟】锚点自动跟随滚动定位
654 0