角色动作——Equip, Crouch, Aim (2)

写在前面

Crouch 即蹲下, 是FPS游戏里的另一个重要动作。

角色下蹲,同时还意味着角色的碰撞体积也变小,但是好消息是,Character类已经给了我们现成的Crouch函数和UnCrouch函数了,不仅如此,它还提供了bIsCrouched状态位来告诉我们角色是否是Crouched状态,同时,这个状态做到了服务器和客户端同步,代表我们不需要额外去Replicated它了。

注意,这不仅意味着,在服务端到客户端不需要复制,从客户端1到服务端再到客户端也无需再复制,做全套了。这是不是有点像角色的移动呢,角色在客户端的移动也是多端同步的毕竟。

确定Crouch标志

首先我们先在AnimeInstance里面写上标志位:

c++ 复制代码
// header
// 是否在Crouch
UPROPERTY(BlueprintReadOnly, Category = Character, meta = (AllowPrivateAccess = "true"))
bool bIsCrouched;


// c++
bIsCrouched = BlasterCharacter->bIsCrouched; // 是否在Crouch

而在BlasterCharacter里,我们需要做两件事,一件是按键绑定,第二件是让角色开启CanCrouch

c++ 复制代码
// header
void Crouch();
void UnCrouch();


// cpp
// Sets default values
ABlasterCharacter::ABlasterCharacter()
{
  // ...

	// 设置让角色可以Crouch
	this->GetMovementComponent()->NavAgentProps.bCanCrouch = true;
}


// Called to bind functionality to input
void ABlasterCharacter::SetupPlayerInputComponent(UInputComponent *PlayerInputComponent)
{
	Super::SetupPlayerInputComponent(PlayerInputComponent);

   // ...
   // 按下键位 开始Crouch
	PlayerInputComponent->BindAction("Crouch", IE_Pressed, this, &ThisClass::Crouch);
   // 松开键位 开始Crouch
	PlayerInputComponent->BindAction("Crouch", IE_Released, this, &ThisClass::UnCrouch);
}

完成了。

动画蓝图

和之前的动作不同,Crouch动作无需再左右倾斜,所以只要有一个方向Direction即可。

我们先做1D Blend Space,

左右不分很简单,其实只要看看你的preview的方向和角色运动的方向是不是一样就可以了。

Idle -> Crouch Walk

Crouch Walk -> Idle

END

相关推荐
奶油mm6 分钟前
公司技术债堆积如山,我一人之力用 Vue3 偷换了整个前端架构
前端·vue.js
用户938515635076 分钟前
深入理解 JavaScript 中的 this 与数据存储的奥秘
前端·javascript
JNX_SEMI38 分钟前
AT2659 L1频段多模卫星导航低噪声放大器技术解析
前端·单片机·嵌入式硬件·物联网·硬件工程
Profile排查笔记2 小时前
指纹浏览器环境异常排查:Fingerprint、Profile、Proxy、Session 和 Task Log 怎么看
前端·人工智能·后端·自动化
京韵养生记2 小时前
【无标题】
java·服务器·前端
星空露珠3 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
大气的小蜜蜂3 小时前
领域层的服务
java·前端·数据库
星栈3 小时前
LiveView 的 LiveComponent:比 React 组件更轻,但我一开始真的把它用错了
前端·前端框架·elixir
林希_Rachel_傻希希3 小时前
web性能优化之延迟加载图片和<inframe>
前端·javascript·面试
maxmaxma4 小时前
Konva 从入门到实践 - day1
前端