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

【Godot4自学手册】第四十五节用着色器(shader)制作水中效果

本节内容,主要学习利用着色器制作水波纹效果,效果如下:
请添加图片描述

一、搭建新的场景

首先我们新建场景,根节点选择Node2D,命名为Water,给根节点添加两个Tilemap节点,一个命名为Background主要用于绘制地形图,和水中物品;另一个命名为Water,主要用于绘制水波纹。目录结构如下:
请添加图片描述

Background绘制效果如下:
请添加图片描述

Water绘制水波纹,将水覆盖的部分全部填满,效果如下:
请添加图片描述

需要素材的可以在头部点击下载源代码。

二、制作水波纹

1.新建着色器。 选择Water节点,在属性检查器中中找到CanvasItem属性,并在Material->Material后方选择下拉按钮选择新建ShaderMaterial。然后选中新建的材质球,在Shader属性选择新建着色器,如下:
请添加图片描述

2.编写代码。 在着色器内编写如下代码:

shader_type canvas_item;uniform sampler2D screen_texture:hint_screen_texture;
uniform sampler2D noise_texture:filter_nearest,repeat_enable;
uniform float distortion =0.01;
uniform vec2 speed = vec2(.5,.2);
uniform float wave_strength =0.1;void vertex() {VERTEX.y += sin(TIME);
}void fragment() {vec2 uv = UV+speed*TIME;vec2 noise =2.0 * texture(noise_texture,uv).rg - vec2(1,0);COLOR = texture(TEXTURE,UV + noise * wave_strength);COLOR *= texture(screen_texture,SCREEN_UV+noise * distortion);
}

3.配置参数。 编写完成代码保存后,检查器中会出现一些参数,noise_texture表示水波纹噪声纹理;distortion表示波动距离;speed表示波动速度;wave_strength表示波动强度。我们主要设置noise_texture,其它默认值。
Noise Texturen 选择新建NoiseTexure2D,展开属性勾选Seamless启用,表示纹理无缝连接;Noise属性选择新建FastNoiseLite,在其属性中将frequency设置为)0.001,数值越小产生的噪声越平滑。
请添加图片描述

这样配置,我们的效果就实现了,如下:
请添加图片描述

http://www.lryc.cn/news/426125.html

相关文章:

  • VMware Workstation Pro 安装 Ubuntu Server
  • 智能化包括自动化与非自动化
  • 微前端架构的容器化部署:策略、实践与优势
  • 面试题(网络、js、框架)
  • C语言典型例题40
  • 【大模型部署及其应用 】使用 Ollama 和 Ollama WebUI 在本地运行 Llama 3
  • uniapp-部分文件中文乱码
  • Day41 | 647. 回文子串 516.最长回文子序列
  • 全面解析Gerapy分布式部署:从环境搭建到定时任务,避开Crawlab的坑
  • Springboot项目中使用druid实现多数据源和动态数据源,因数据库不可用导致的项目挂起的处理方案
  • 多线程 03:知识补充,静态代理与 Lambda 表达式的相关介绍,及其在多线程方面的应用
  • 机器学习中的距离概念
  • Java 如何判断map为null或者空
  • 终端用户视角下的性能测试,体验与度量的融合
  • KCP源码解析系列(二)KCP协议结构体
  • 微软运行库全集合:一站式解决兼容性问题
  • 【 亿邦动力网-注册安全分析报告】
  • 算法笔记|Day26贪心算法IV
  • CVPR2023《DNF: Decouple and Feedback Network for Seeing in the Dark》暗光图像增强论文阅读笔记
  • 大厂进阶七:React状态管理全解析
  • 【ocr识别003】flask+paddleocr+bootstrap搭建OCR文本推理WEB服务
  • 从零开始搭建 LVS 高性能集群 (DR模式)
  • Linux环境开发工具【yum与vim】
  • laravel GuzzleHttp Client 无法获取返回的错误信息
  • XMOS 多路音频解码器
  • XSS小游戏(题目+解析)
  • 《Redis核心技术与实战》学习笔记4——AOF日志:宕机了,Redis如何避免数据丢失?
  • NextJs - 服务端/客户端组件之架构多样性设计
  • 使用 Python 进行 PDF 文件加密
  • Spring Boot集成RabbitMQ