在王者荣耀中脸探草丛的正确姿势是什么?

引言

Cocos中躲草丛效果的实现原理。

在游戏开发中,我们经常用透视 或者半透明 效果去表现模型被遮挡的效果。

本文将介绍一下如何在Cocos 中实现王者荣耀中的躲草丛效果

本文源工程在文末获取,小伙伴们自行前往。

躲草丛效果的实现原理

要在Cocos 中实现王者荣耀中的躲草丛效果,需要以下几个点:

1.模型半透明

要实现模型的半透明效果 ,需要下面2个条件:

  • 3D物体所在的渲染队列为"透明队列";
  • 3D物体的颜色alpha值改成127(半透明);

2.触发

进入 草丛的时候触发 模型半透明离开 草丛时恢复 模型半透明 。需要下面Collider2个事件:

  • onTriggerEnter:当其他Collider进入我的Collider时触发。

  • onTriggerExit:当其他Collider离开我的Collider时触发。

话不多说,一起来做个实例。

王者小鸡躲草丛

接下来我们一步一步来 实现王者荣耀 中的躲草丛效果。

1.环境

引擎版本:Cocos Creator 3.8.1

编程语言:TypeScript

2.资源准备

首先去"菜市场 "买两把" ",有喜欢做模型 的小伙伴可以自己在3dmax 里面做一个,我们先看下草在3dmax中的效果:

然后把模型从3dmax 导出一下,包括FBXTGA,然后添加到工程:

把模型拖到场景 里面去,可以看到雪白的草:

想要把草恢复成绿色需要以下处理:

  • 修改材质的Effect,我们用builtin-unlit
  • 然后Technique选择transparent通道。
  • 设置贴图。

处理完成后效果如下:

由于草不够茂密 ,我们复制粘贴多几个:

想要草可以产生触发事件 ,需要添加一下Collider,这里直接用BoxCollider,简单快捷:

勾选Is Trigger使其变成触发器 ,否者会进不去草丛:

3.编写代码

新建一个Tussock组件,并且到王者小鸡身上。

typescript 复制代码
@ccclass('Tussock')
export class Tussock extends Component {
    start() {
    }

    update(deltaTime: number) {
    }
}

start()方法中获取CapsuleCollider组件并且监听onTriggerEnteronTriggerExit事件。

typescript 复制代码
start() {
    var collider = this.getComponent(CapsuleCollider);
    collider.on('onTriggerEnter', (event: ICollisionEvent) => {
        if (event.otherCollider.node.name == "tussock") {
            this.setModelTranslucency(true);
        }
    }, this);
    collider.on('onTriggerExit', (event: ICollisionEvent) => {
        if (event.otherCollider.node.name == "tussock") {
            this.setModelTranslucency(false);
        }
    }, this);
}

最后获取 王者小鸡的材质 ,通过material.setProperty('albedo');设置一下他的透明度

typescript 复制代码
setModelTranslucency(flag: boolean) {
    const material = this.node.getChildByName("rooster_man").getComponent(RenderableComponent)?.sharedMaterials[0]; // 0 表示第一个材质,根据您的需求修改
    material.setProperty('albedo', new Color(255, 255, 255, flag ? 127 : 255));
}

4.效果演示

一天不整活,浑身都难受。帮忙转发一下文章哦,下课!

结语

本文源工程 可通过私信发送Tussock获取。

近日,笔者受麒麟子 (深耕游戏引擎与游戏开发15年 ,每一滴干货都源自商业项目 实践)的邀请,以嘉宾 的形式加入知识星球,星球主要用于:

  • 导师教学
  • 学习问题交流
  • 新人入门与进阶
  • 招聘与就业机会分享
  • 面试题集锦
  • 面试经验分享

总的来说,星球的目标 只有一个:提供优质内容,搞学习 。感兴趣的小伙伴可以扫码 了解和捧场, 在里面等你

我是"亿元程序员",一位有着8年游戏行业经验的主程。在游戏开发中,希望能给到您帮助, 也希望通过您能帮助到大家。

AD:笔者线上的小游戏《贪吃蛇掌机经典》《重力迷宫球》《填色之旅》大家可以自行点击搜索体验。

实不相瞒,想要个在看 !请把该文章分享给你觉得有需要的其他小伙伴。谢谢!

推荐专栏:

你知道王者荣耀是怎么实现技能范围指示器的吗?

8年主程手把手打造Cocos独立游戏开发框架

和8年游戏主程一起学习设计模式

从零开始开发贪吃蛇小游戏到上线系列

相关推荐
m0_7482517218 小时前
Android webview 打开本地H5项目(Cocos游戏以及Unity游戏)
android·游戏·unity
gantengsheng19 小时前
基于51单片机和OLED12864的小游戏《贪吃蛇》
单片机·嵌入式硬件·游戏·51单片机
264玫瑰资源库19 小时前
从零开始C++棋牌游戏开发之第三篇:游戏的界面布局设计
开发语言·c++·python·游戏·pygame·源代码管理
264玫瑰资源库19 小时前
从零开始C++游戏开发之第七篇:游戏状态机与回合管理
开发语言·c++·游戏
windwind20001 天前
游戏关卡设计方法的杂感
游戏·关卡设计
白乐天_n2 天前
腾讯游戏安全移动赛题Tencent2016A
安全·游戏
这是我582 天前
C++打小怪游戏
c++·其他·游戏·visual studio·小怪·大型·怪物
tealcwu2 天前
【游戏设计原理】21 - 解谜游戏的设计
游戏·游戏策划
清梦20202 天前
经典问题---跳跃游戏II(贪心算法)
算法·游戏·贪心算法
tealcwu2 天前
【游戏设计原理】22 - 石头剪刀布
游戏·游戏策划