当前位置: 首页 > news >正文

Godot学习-3D基本环境设置以及3D角色移动

文章目录

  • 一、新建项目和导入资产
  • 二、创建玩家场景
    • 1.修改模型节点类型为CharacterBody3D
    • 2.添加碰撞对象并且设置碰撞区域
    • 3.根据动画的运动状态调整碰撞区域
  • 三、使用CSGMesh3D创建地面
    • 1.设置网格尺寸
    • 2.设置网格材质
  • 四、添加3D相机和光照
  • 五、为角色移动编写代码
    • 1.基本移动和旋转
    • 2.调用角色动画
  • 总结


一、新建项目和导入资产

这里演示的是如何让角色移动起来。为此我们新建测试工程,并且导入对应的3D模型文件。并且新建一个3D场景,命名为Main。
然后我选择一个角色模型,如下图,我选择的是:Astronaut_FinnTheFrog.gltf。鼠标双击打开,如下图所示:
在这里插入图片描述
左侧分为两部分,分别是模型和动画。选择AnimationPlayer下面的idle、run、walk节点,然后点击播放,查看动画状态,然后我们选择重新导入。
在这里插入图片描述
然后我们把模型拖到Main节点下面。
值得注意的是:有些模型可能会出现褪色的情况,此时我们选择模型对应的图片,然后点击导入,勾选上高质量即可。最后重新导入。
操作步骤如下图:
在这里插入图片描述

二、创建玩家场景

1.修改模型节点类型为CharacterBody3D

然后我们选择Astronaut_FinnTheFrog节点旁边的图标,在这里插入图片描述 单机鼠标,在编辑器中打开:
在这里插入图片描述
我们选择仍然打开。
如下图所示的模型场景:
在这里插入图片描述
修改根节点类型和名称分别为:CharacterBody3D和Player。
在这里插入图片描述

在这里插入图片描述

2.添加碰撞对象并且设置碰撞区域

此时黄色警号告诉我们没有为角色设置碰撞,那么我们按照提示新建一个碰撞体。为Player创建子节点:CollisionShape3D,形状选择CapsuleShape3D。这是一个3D胶囊碰撞形状。然后我们设置好碰撞。
在这里插入图片描述
此时我们应该调整角色和胶囊的位置,让胶囊很好的包裹角色。勉强就这样吧:
在这里插入图片描述
为CollisionShape3D节点修改名称,为Player_Collider。这样更加直观

3.根据动画的运动状态调整碰撞区域

关于动画的一些基本介绍,可以参考我的文章:Godot学习-创建简单动画

因为我刚才设置的碰撞器,就是那个胶囊碰撞器针对的是空闲状态的角色,但是当跳起来、或者跑起来,或者走起来的时候,碰撞器和角色就不是很好匹配了,因此要重新设置碰撞器。
当我选择Jump的时候,如下图:胶囊没有包裹住头顶。
在这里插入图片描述
操作如下:
1、选择碰撞器节点
2、选择idle(空闲状态)
3、选择position属性右侧的小钥匙。
在这里插入图片描述
我们直接选择创建即可。
在这里插入图片描述

此时在轨道最下面就有我们的position属性轨道,并且在1那里添加关键帧:
在这里插入图片描述
然后点击编辑,选择复制轨道,弹出下面的弹框,我们选择我们的碰撞器:
在这里插入图片描述
选择Run动画状态,点击编辑,然后复制轨道。此时将最后的关键帧调整位置:
在这里插入图片描述
Walk动画状态也是同样的操作。
在这里插入图片描述
选择Jump动画状态,此时我们不用复制轨道,我们需要手动添加关键帧,并且调整胶囊的位置。
1、创建position轨道。
2、调整胶囊的位置,添加关键帧。
我点击循环播放,可以看出胶囊赶着角色上下跳动。
在这里插入图片描述
对Jump_Idle和Jump_Land都做同样的操作即可。
此时我们把场景另存为player.tscn。

此时我们回到主场景,删除模型节点。
在这里插入图片描述
然后实例化我们刚才保存的子场景:
在这里插入图片描述

三、使用CSGMesh3D创建地面

给Main节点创建子节点:CSGMesh3D
然后选择Mesh。原来是有PlaneMesh的,现在新版本没有这个了,我们选择BoxMesh。

1.设置网格尺寸

并且设置对应的尺寸:
在这里插入图片描述

在CSGShape3D里面,勾选上:Use Collision。这个是为了自动创建碰撞。(为我们的 CSG 形状向物理引擎添加碰撞形状。这样行为就始终与静态物体类似。请注意,即使 CSG 形状本身被隐藏,碰撞形状仍处于活动状态。)
在这里插入图片描述

2.设置网格材质

在这里插入图片描述
我们选择第一个材质。
然后点击这个材质,在Albedo属性里面设置对应的颜色。
在这里插入图片描述

四、添加3D相机和光照

1、为Main节点添加一个子节点,Camera3D
2、点击视图,选择多个窗口,可以预览。,我选择2个。
在这里插入图片描述
3、然后选择相机节点,通过调整坐标,观察角色位置,记得勾选预览。如下图,右边是我的预览。
在这里插入图片描述

此时我们运行游戏,选择当前节点,如下图所示:
在这里插入图片描述
整个场景是暗黑的,我们需要加上太阳光和环境光。
在这里插入图片描述
再次运行,如下图所示:
在这里插入图片描述

五、为角色移动编写代码

1.基本移动和旋转

1、切换到Player场景,为其创建脚本,命名为play.gdscript
2、关于输入动作我们使用内置的,也可以绑定其他的。我这里使用内置的绑定。
在这里插入图片描述

extends CharacterBody3D
@export var speed : = 4.0var movement
var directionfunc _physics_process(delta: float) -> void:# 基本移动输入操作var movement := Input.get_vector("ui_left", "ui_right", "ui_up", "ui_down")var direction := (transform.basis * Vector3(movement.x, 0, movement.y)).normalized()if direction:velocity.x = direction.x * speedvelocity.z = direction.z * speedelse:velocity.x = move_toward(velocity.x, 0, speed)velocity.z = move_toward(velocity.z, 0, speed)move_and_slide()

此时发现角色不能旋转,而CharacterArmature节点控制旋转,因此我们要修改下代码:
在这里插入图片描述

extends CharacterBody3D@export var speed : = 4.0
@onready var player_body=$CharacterArmature
var angular_speed=10
var movement
var directionfunc _physics_process(delta: float) -> void:# 基本移动输入操作var movement := Input.get_vector("ui_left", "ui_right", "ui_up", "ui_down")var direction := (transform.basis * Vector3(movement.x, 0, movement.y)).normalized()if direction:velocity.x = direction.x * speedvelocity.z = direction.z * speedplayer_body.rotation.y=lerp(player_body.rotation.y,atan2(velocity.x,velocity.z),delta * angular_speed)else:velocity.x = move_toward(velocity.x, 0, speed)velocity.z = move_toward(velocity.z, 0, speed)move_and_slide()

此时可以旋转了,但是我们还需要调用动画。

2.调用角色动画

修改后的代码:

extends CharacterBody3D@export var speed : = 4.0
@onready var player_body=$CharacterArmature
@onready var player_anim=$AnimationPlayer
var angular_speed=10
var movement
var directionfunc _physics_process(delta: float) -> void:# 基本移动输入操作var movement := Input.get_vector("ui_left", "ui_right", "ui_up", "ui_down")var direction := (transform.basis * Vector3(movement.x, 0, movement.y)).normalized()if direction:player_anim.play("Walk")velocity.x = direction.x * speedvelocity.z = direction.z * speedplayer_body.rotation.y=lerp(player_body.rotation.y,atan2(velocity.x,velocity.z),delta * angular_speed)else:player_anim.play("Idle")velocity.x = move_toward(velocity.x, 0, speed)velocity.z = move_toward(velocity.z, 0, speed)move_and_slide()

在这里插入图片描述


总结

以上就是今天要讲的内容,本文仅仅简单介绍了模型导入、动画设置、地面创建、光照创建和角色基本移动。但是相机跟着角色旋转和移动这块还是有点问题,下次再看。

相关文章:

  • 叶面温度传感器选清易高精度电热感应器 叶片温度变送器
  • OpenGL学习笔记(Blinn-Phong、伽马矫正、阴影)
  • 第一章:基于Docker环境快速搭建LangChain框架的智能对话系统:从langchain环境搭建到多轮对话代码实现(大语言模型加载)
  • 【专题刷题】滑动窗口(四):
  • 介绍 IntelliJ IDEA 快捷键操作
  • HCIP-OSPF综合实验
  • 通过智能分块策略、动态分块、多路召回与重排序融合、异构数据关联与溯源提升Ragflow与LangChain提升RAG的召回率
  • 【高频考点精讲】JavaScript中的访问者模式:从AST解析到数据转换的艺术
  • windos端远程控制ubuntu运行脚本程序并转发ubuntu端脚本输出的网页
  • 开发NESMA辅助工具版本之需求匹配
  • 【KWDB 创作者计划】_上位机知识篇---PlatformIO
  • 深入详解Java中的@PostConstruct注解:实现简洁而高效初始化操作
  • 量子计算浪潮下的安全应对之法
  • 一个关于相对速度的假想的故事-7
  • 迅为RK3562开发板ARM四核A53核心板多种系统适配全开源
  • 汽车免拆诊断案例 | 2013款大众辉腾车发动机抖动
  • PHP 反序列化CLI 框架类PHPGGC 生成器TPYiiLaravel 等利用
  • 设计模式之策略模式
  • nginx实现同一个端口监听多个服务
  • 用Python爬取B站热门视频并自动保存到本地
  • 杨靖︱“一笔糊涂账”:博马舍与美国革命
  • 大理洱源4.8级地震致442户房屋受损,无人员伤亡
  • 官宣一起打造智能汽车品牌后,华为喊话上汽要准备好足够产能
  • 荣盛发展:拟以酒店、代建等轻资产板块业务搭建平台,并以其股权实施债务重组
  • 从“龙队”到“龙副主席”,国乒这批退役球员为何不当教练了
  • 杨国荣丨《儒耶对话与中国现代思想的生成和发展》序