Unity2D游戏制作教程 | 8.设置基本输入系统并实现人物移动
myzbx 2025-05-25 14:23 40 浏览
我们操作玩家的按键在新版本的unity中是可以更改的,默认是wasd,但是在新版本中可以实现更换按键,我们可以来试一下,通过代码实现玩家在按键的控制下移动。
- 在Unity中如何通过代码控制人物的基本移动,包括跳跃和跑步等,并详细讲解了代码的编写和添加到玩家身上的步骤。
- 准备写代码控制人物的基本控制,包括跳跃和跑步
- 我们为了保证项目文件的规范性,在Assets中添加一个文件夹,命名为Scripts。后续所有的脚本都在这个文件夹中创建,
- 为了更清晰,我们可以创建一个Player文件夹,将玩家相关的代码都放到这个文件夹中
- 在这个文件夹中创建一个脚本命名为PlayerController,最好将这个名字一次修改好,不然后续再修改的时候还得修改脚本里面的类名,比较麻烦。
- 如下图:
编译完成后,可以在屏幕右侧预览代码文本内容
然后将脚本添加到Player这个对象中
当然也可以直接选中Player,将脚本拖拽到Player的Inspector中
编译完成后双击脚本文件就可以在编辑器中打开代码文件了
脚本基本信息,Unity中C#编程的一些基础知识,包括变量赋值、组件获取等,
算法和检测在update中执行,变量赋值和组件获取在start中执行。
建议在写代码前查看unity官方的c#初级或中级视频,有助于快速了解C#。
做到这里以后先保存你的脚本和项目。
升级unity到新的输入系统。使用Unity全新的输入系统进行游戏开发。
打开Edit下的ProjectSettings,在左侧的player选项中的 Other Setting下找到选择新的input system系统。
也就是下图右侧的两个方框,我们设置这两个内容,第一个是C#语言的api等级,可以使用更多C#新特性,第二个Inpu System Package(New)就是新的输入系统:
注意,设置了新的Input System后项目会重启,所以在设置之前先保存你的项目。
设置完后我们还需要安装一个 Input System这个包,按照下图步骤安装
- 自动添加输入系统。
- 在Settings文件夹中创建一个文件夹命名为Input System 来保存我们后续创建的输入系统,也可以叫输入控制器,
创建完成后,会提示你还没有创建Actions,点击创建,(下面图中应该是在Input System文件夹中保存,截图里写错了。)
可以看一下自动生成的控制系统有键盘手柄等等,
然后就可以来进行控制了,
这里我们点击移除组件,生成脚本。他就会自动帮你生成一个底层的脚本逻辑,方便后续我们的PlayerController脚本来调用。我们后续编写代码使用我们之前创建的脚本来进行左右移动的控制。
下面我们修改PlayerController来实现变量的修改
先调用一下
public PlayerInputController inputControl;
//声明一个变量 playerController 用来存储PlayerController这个类的实例
//来调用我们创建的控制系统
public void Awake()
{
inputControl = new PlayerInputController();
}
//这里声明一个方法Awake() 用来创建我们的控制系统
//这个方法在游戏启动的时候执行一次
//这里声明一个方法OnEnable() 用来启用我们的控制系统
public void OnEnable()
{
inputControl.Enable();
}
//这里声明一个方法OnDisable() 用来禁用我们的控制系统
public void OnDisable()
{
inputControl.Disable();
}
public Vector2 inputDirection;
//这里声明一个变量 inputDirection 用来存储我们的输入方向
//这个变量对应输入系统中的Vector变量
在update函数中监测输入并传递给变量
这个时候运行游戏,可看到WASD可以修改Player的Input Direction值
六 、使用代码实现人物左右移动
public float speed;
//这里声明一个变量 speed 用来存储我们的速度
生成变量后我们将它的值设置为200
public Rigidbody2D rb;
//这里声明一个变量 rb 用来存储我们的刚体组件
将Unity中Player的刚体组件拖拽到生成的rb变量上、然后创建一个方法
或者使用Awake方法获取,
public void FixedUpdate()
{
//这里声明一个方法FixedUpdate() 用来更新我们的控制器
//这个方法在游戏运行过程中每帧执行一次
//这里我们通过调用我们的控制器的Move方法来移动我们的角色
Move();
}
//生成一个方法Move来实现上面的Move
七 通过修改人物Scale来实现人物左右移动是人物的朝向翻转
我们这里在Move中一个判断来实现:(如果输入的X大于0,那么朝向右,如果小于0,则朝向左)
// 这里使用变量来修改Scale实现人物翻转
上图中看到,我们之前定义了一个变量inputDirection用来保存我们输入的方向的值,如果大于0,面向右,小于0面向左
if(inputDirection.x>0)
{
transform.localScale = new Vector3(1,1,1);
}
if(inputDirection.x<0)
{
transform.localScale = new Vector3(-1,1,1);
}
- 上一篇:这是勇敢者的游戏!你不来试一下?
- 下一篇:能旋转的塔防游戏? 睡意侵袭试玩体验
相关推荐
- vue:生命周期钩子函数及顺序_列举出5个vue中常用的生命周期钩子函数
-
一、vue的钩子相关顺序Vue实例有一个完整的生命周期,在newVue()后,会初始化数据,如下://初始化的入口,各种初始化工作initMixin(Vue);//数据绑定的核心方法,包括常用...
- 最长递增子序列:从经典算法到 Vue3 运行时核心优化
-
最长递增子序列(LongestIncreasingSubsequence,LIS)正悄然成为性能分水岭。它不仅是面试的高频考点,更是Vue3快速Diff算法赖以实现O(nlogn)...
- 十分钟掌握Vue 3性能优化:实战技巧与避坑指南
-
「为什么我的Vue应用越做越卡?」这是最近团队新人最常问的问题。本文将从真实电商项目出发,手把手教你用Vue3的现代特性实现性能飞跃,文末还准备了可复用的优化检查清单!一、先看疗效:优化前后对比优...
- JavaScript学习 -- 文本节点_html 文本节点
-
什么是文本节点在HTML文档中,文本节点是一种特殊的dom节点,它包含文本内容,没有任何标记或属性。<p>这是一段文本节点</p>在上面的代码中,<p>元素包含了...
- JavaScript中this指向各种场景_javascript的this指向
-
在JavaScript中,this的指向是一个核心概念,其值取决于函数的调用方式,而非定义位置(箭头函数除外)。以下是this指向的常见场景及具体说明:1.全局作用域中的this在全局作用域(非...
- v-if和v-for的优先级是什么?_v-if和v-for的区别,什么时候用
-
#一、作用v-if指令用于条件性地渲染一块内容。这块内容只会在指令的表达式返回true值的时候被渲染v-for指令基于一个数组来渲染一个列表。v-for指令需要使用iteminitems...
- Vue插槽(Slot)深度解析:从匿名到作用域的组件复用革命
-
在Vue组件化开发中,内容分发始终是核心挑战之一。当我们需要让组件既能保持结构复用,又能灵活定制局部内容时,插槽(Slot)机制应运而生。从基础的匿名插槽到复杂的作用域插槽,Vue的插槽系统逐步解决了...
- 手摸手带你解决AI应用开发中Markdown渲染问题
-
使用Markdown-It+VueRender实现安全可控的Markdown渲染在前端项目中,Markdown的渲染经常使用markdown-it。它功能丰富、插件多,但默认的渲染方...
- Vue3 新趋势:10 个最强 X 操作!_vue.3
-
Vue3为前端开发带来了诸多革新,它不仅提升了性能,还提供了更简洁、更强大的API。以下是十个最值得学习和使用的Vue3API,它们将助力你的开发工作迈向新高度。浅层响应式API:shall...
- 25个React最佳实践小技巧_reactor设计模式
-
以下是25个React开发中实用的最佳实践与小技巧,覆盖组件设计、状态管理、性能优化、代码规范、错误处理等核心场景,每个技巧均附示例和核心原因,帮助你写出更高效、可维护的React代码。一...
- javascript函数的call、apply和bind的原理及作用详解
-
javascript函数的call、apply和bind本质是用来实现继承的,专业点说法就是改变函数体内部this的指向,当一个对象没有某个功能时,就可以用这3个来从有相关功能的对象里借用过来...
- 简单介绍一下前端各框架中的模板标签
-
在各大前端框架、小程序中,此类标签的作用主要是用来帮助我们包裹多个元素。在浏览器实际渲染中会将其移除只渲染其包裹的DOM元素,所以说不会增加额外的DOM节点在小程序中使用小程序中的模板标签是<...
- 面试官问我,后端一次性返回十万条数据,前端应该怎么处理 ?
-
问题描述面试官:后端一次性返回10万条数据给你,你如何处理?我:歪嘴一笑,马上给后端发送一百万次请求,干蹦他的服务器,让他给爷哭!问题考察点性能优化意识(能否识别出“10万条数据”会导致性能问题?是...
- React系列十 - 高阶组件以及组件补充
-
源自:coderwhy一.高阶组件1.1.认识高阶组件什么是高阶组件呢?相信很多同学都听说过,也用过高阶函数,它们非常相似,所以我们可以先来回顾一下什么是高阶函数。高阶函数的维基百科定义:至少...
- 从0开始写一个虚拟滚动组件_虚拟滚动原理
-
如果一个页面有1W+条数据,该怎么渲染比较好。不管是在我们的实际项目开发中还是在面试的过程中都会遇到类似的问题。相信很多同学会想到分页。当然这也是最传统也是最保底的解决方案了。如果有开发过electr...
- 一周热门
- 最近发表
-
- vue:生命周期钩子函数及顺序_列举出5个vue中常用的生命周期钩子函数
- 最长递增子序列:从经典算法到 Vue3 运行时核心优化
- 十分钟掌握Vue 3性能优化:实战技巧与避坑指南
- JavaScript学习 -- 文本节点_html 文本节点
- JavaScript中this指向各种场景_javascript的this指向
- v-if和v-for的优先级是什么?_v-if和v-for的区别,什么时候用
- Vue插槽(Slot)深度解析:从匿名到作用域的组件复用革命
- 手摸手带你解决AI应用开发中Markdown渲染问题
- Vue3 新趋势:10 个最强 X 操作!_vue.3
- 25个React最佳实践小技巧_reactor设计模式
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)