Cocos Creator 3.8 开发2D水面波纹Shader

2024-01-08 22:28

本文主要是介绍Cocos Creator 3.8 开发2D水面波纹Shader,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用cocos Creator 3.8做了一个游戏开中常用的2D的波浪水面,把技术点给记录一下,并提供完整的Shader代码。先上效果:

添加图片注释,不超过 140 字(可选)

2D 波浪的基本技术原理

2D 水面波纹的主要原理就是给定一个正选波的边界,在范围内的片元uv就显示,在范围外的片元uv就不显示。同时利用正弦波表达式:

y = A * sin(w * t+offset)

将片元的uv坐标uv.x 带入上面的公式offset,算出y0值。Cocos 的uv 左上角为(0, 0),我们要在图片的上方做水波纹,那么片元的uv.y < y0的片元就丢弃, uv.y >= y0的就正常显示。

对啦!这里有个游戏开发交流小组里面聚集了一帮热爱学习游戏的零基础小白,也有一些正在从事游戏开发的技术大佬,欢迎你来交流学习。

添加图片注释,不超过 140 字(可选)

为了让水波能动起来,我们就要不断的改变同一个位置offset, 对应的y0的值,那么我们加一个 w * t, 角速度*时间。这样随着时间的推移同一个uv(x, y),会得到不同的y0的值。有了不同的边界,这样就会决定不同的片元的显示和丢弃。

具体编写Shader

第001步: 新建一个标准2D Shader 模板,能正常显示图片

Cocos Creator的版本不一样,可能导致以前编写的Shader无法正常运行,这种其实很好解决,我们在开发Shader的时候,基于现在Cocos Creator的版本先创建一个现有的模板出来,然后再将关键代码移植过去。我们做一个2D的Shader,所以复制一个buildin-sprite的Shader模板。然后创建一个材质选好我们新创建的Shader文件,将材质设置到Sprite组件上,能正常显示图片。

添加图片注释,不超过 140 字(可选)

第002步: 定义好uniform给用户的控制参数:

baseLine: 基准线,该参数用于控制波浪在图片的位置(波形的基准线);

A: 振幅,该参数用于控制波浪线的高度;

wSpeed:角速度,该参数用来控制一个波形的长度;

添加图片注释,不超过 140 字(可选)

第003步: 修改Frag片元着色的Shader代码

完成基准线功能,编写代码基准线以上的片元直接丢弃,基准线一下的片元保留,代码如下:

 
 

float value = 0;

 

if(uv0.y < baseLine + value) {

 

discard;

 

}

这样基准线baseLine以上的,就不显示,baseLine以下的显示。

第004步:基于A*sin(offset)来将基准线做正弦波处理

基准线确定好后,还需给基准线加上正弦波,offset为uv.x, value = A*sin(offset), baseLine + value, 这样就把baseLine做成了正弦波的分界线。

 
 

float value = A * sin(uv0.x * 30.0);

 

if(uv0.y < baseLine + value) {

 

discard;

 

}

第005步:让正弦波动起来

为了让正弦波动起来,我们在sin加上w*t, 在cocos ccreator里面cc_time是一个vec4的向量, cc_time.x是从启动后到现在的时间,随着时间不断地变化,value = A * sin(uv0.x * 30.0 + wSpeed * cc_time.x); value地值也成周期变化,这样波形就动起来了。

 
 

float value = A * sin(uv0.x * 30.0 + wSpeed * cc_time.x);

 

if(uv0.y < baseLine + value) {

 

discard;

 

}

完整Shader代码

最后上代码(Cocos Creator 3.8.0):

 
 

// Copyright (c) 2017-2020 Xiamen Yaji Software Co., Ltd.

 

CCEffect %{

 

techniques:

 

- passes:

 

- vert: sprite-vs:vert

 

frag: sprite-fs:frag

 

depthStencilState:

 

depthTest: false

 

depthWrite: false

 

blendState:

 

targets:

 

- blend: true

 

blendSrc: src_alpha

 

blendDst: one_minus_src_alpha

 

blendDstAlpha: one_minus_src_alpha

 

rasterizerState:

 

cullMode: none

 

properties:

 

alphaThreshold: { value: 0.5 }

 

baseLine: { value: 0.5}

 

wSpeed: { value: 10.0 }

 

A: { value: 0.01}

 

}%

 

CCProgram sprite-vs %{

 

precision highp float;

 

#include <builtin/uniforms/cc-global>

 

#if USE_LOCAL

 

#include <builtin/uniforms/cc-local>

 

#endif

 

#if SAMPLE_FROM_RT

 

#include <common/common-define>

 

#endif

 

in vec3 a_position;

 

in vec2 a_texCoord;

 

in vec4 a_color;

 

out vec4 color;

 

out vec2 uv0;

 

vec4 vert () {

 

vec4 pos = vec4(a_position, 1);

 

#if USE_LOCAL

 

pos = cc_matWorld * pos;

 

#endif

 

#if USE_PIXEL_ALIGNMENT

 

pos = cc_matView * pos;

 

pos.xyz = floor(pos.xyz);

 

pos = cc_matProj * pos;

 

#else

 

pos = cc_matViewProj * pos;

 

#endif

 

uv0 = a_texCoord;

 

#if SAMPLE_FROM_RT

 

CC_HANDLE_RT_SAMPLE_FLIP(uv0);

 

#endif

 

color = a_color;

 

return pos;

 

}

 

}%

 

CCProgram sprite-fs %{

 

precision highp float;

 

#include <builtin/uniforms/cc-global>

 

#include <builtin/internal/embedded-alpha>

 

#include <builtin/internal/alpha-test>

 

in vec4 color;

 

#if USE_TEXTURE

 

in vec2 uv0;

 

#pragma builtin(local)

 

layout(set = 2, binding = 12) uniform sampler2D cc_spriteTexture;

 

#endif

 

uniform MyUniform {

 

float baseLine;

 

float wSpeed;

 

float A;

 

};

 

vec4 frag () {

 

vec4 o = vec4(1, 1, 1, 1);

 

#if USE_TEXTURE

 

o *= CCSampleWithAlphaSeparated(cc_spriteTexture, uv0);

 

#endif

 

float value = A * sin(uv0.x * 30.0 + wSpeed * cc_time.x);

 

if(uv0.y < baseLine + value) {

 

discard;

 

}

 

o *= color;

 

return o;

 

}

 

}%

关注我们,可以获取这个项目工程地源码。

这篇关于Cocos Creator 3.8 开发2D水面波纹Shader的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/585043

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3