当前位置:
首页 > Python基础教程 >
-
Unity3D实现人物移动示例
一个是通过W、A、S、D来移动人物(示例一),另个是按屏幕上的按钮来移动人物(示例二)。很简单,只改了几行代码。
下面是“Assets”文件夹里面的资源。
示例一:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
using System.Collections; using System.Collections.Generic; using UnityEngine; public class E3_07keyboard : MonoBehaviour { //动画数组 private Object[] animUp; private Object[] animDown; private Object[] animLeft; private Object[] animRight; //地图贴图 private Texture2D map; //当前人物动画 private Object[] tex; //人物X坐标 private int x; //人物Y坐标 private int y; //帧序列 private int nowFram; //动画帧的总数 private int mFrameCount; //限制一秒多少帧 private float fps = 5; //限制帧的时间 private float time = 0; void Start() { //得到帧动画中的所有图片资源 animUp = Resources.LoadAll( "up" ); animDown = Resources.LoadAll( "down" ); animLeft = Resources.LoadAll( "left" ); animRight = Resources.LoadAll( "right" ); //得到地图资源 map = (Texture2D)Resources.Load( "map/map" ); //设置默认动画 tex = animUp; } void OnGUI() { //绘制贴图 GUI.DrawTexture( new Rect(0, 0, Screen.width, Screen.height), map, ScaleMode.StretchToFill, true , 0); //绘制帧动画 DrawAnimation(tex, new Rect(x, y, 32, 48)); //点击按钮移动人物 if (Input.GetKey(KeyCode.W)) { y -= 2; tex = animUp; } if (Input.GetKey(KeyCode.S)) { y += 2; tex = animDown; } if (Input.GetKey(KeyCode.A)) { x -= 2; tex = animLeft; } if (Input.GetKey(KeyCode.D)) { x += 2; tex = animRight; } } void DrawAnimation(Object[] tex, Rect rect) { //绘制当前帧 GUI.DrawTexture(rect, (Texture)tex[nowFram], ScaleMode.StretchToFill, true , 0); //计算限制帧时间 time += Time.deltaTime; //超过限制帧则切换图片 if (time >= 1.0 / fps) { //帧序列切换 nowFram++; //限制帧清空 time = 0; //超过帧动画总数从第0帧开始 if (nowFram >= tex.Length) { nowFram = 0; } } } } |
示例二
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
using System.Collections; using System.Collections.Generic; using UnityEngine; public class E3_07button : MonoBehaviour { //动画数组 private Object[] animUp; private Object[] animDown; private Object[] animLeft; private Object[] animRight; //地图贴图 private Texture2D map; //当前人物动画 private Object[] tex; //人物X坐标 private int x; //人物Y坐标 private int y; //帧序列 private int nowFram; //动画帧的总数 private int mFrameCount; //限制一秒多少帧 private float fps = 5; //限制帧的时间 private float time = 0; void Start() { //得到帧动画中的所有图片资源 animUp = Resources.LoadAll( "up" ); animDown = Resources.LoadAll( "down" ); animLeft = Resources.LoadAll( "left" ); animRight = Resources.LoadAll( "right" ); //得到地图资源 map = (Texture2D)Resources.Load( "map/map" ); //设置默认动画 tex = animUp; } void OnGUI() { //绘制贴图 GUI.DrawTexture( new Rect(0, 0, Screen.width, Screen.height), map, ScaleMode.StretchToFill, true , 0); //绘制帧动画 DrawAnimation(tex, new Rect(x, y, 32, 48)); //点击按钮移动人物 if (GUILayout.RepeatButton( "向上" )) { y -= 2; tex = animUp; } if (GUILayout.RepeatButton( "向下" )) { y += 2; tex = animDown; } if (GUILayout.RepeatButton( "向左" )) { x -= 2; tex = animLeft; } if (GUILayout.RepeatButton( "向右" )) { x += 2; tex = animRight; } } void DrawAnimation(Object[] tex, Rect rect) { //绘制当前帧 GUI.DrawTexture(rect, (Texture)tex[nowFram], ScaleMode.StretchToFill, true , 0); //计算限制帧时间 time += Time.deltaTime; //超过限制帧则切换图片 if (time >= 1.0 / fps) { //帧序列切换 nowFram++; //限制帧清空 time = 0; //超过帧动画总数从第0帧开始 if (nowFram >= tex.Length) { nowFram = 0; } } } } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式