【SHADER】Shader实例学习1:UI noise halo

Shader实例学习1:UI noise halo

  • 简介
    • 源码注释
    • 关键步骤
    • 总结

简介

又换方向做图形相关的工作了,门槛确实有一点,数学、图形什么的都要学,算轨迹用到力学什么的也是基本操作。大力出奇迹,跟着shadertoy里的众多大神学起来。本篇学习内容来自于:

UI noise halo

源码注释

// noise from https://www.shadertoy.com/view/4sc3z2
vec3 hash33(vec3 p3)
{p3 = fract(p3 * vec3(.1031,.11369,.13787));p3 += dot(p3, p3.yxz+19.19);return -1.0 + 2.0 * fract(vec3(p3.x+p3.y, p3.x+p3.z, p3.y+p3.z)*p3.zyx);
}
// 随机数
float snoise3(vec3 p)
{const float K1 = 0.333333333;const float K2 = 0.166666667;vec3 i = floor(p + (p.x + p.y + p.z) * K1);vec3 d0 = p - (i - (i.x + i.y + i.z) * K2);vec3 e = step(vec3(0.0), d0 - d0.yzx);vec3 i1 = e * (1.0 - e.zxy);vec3 i2 = 1.0 - e.zxy * (1.0 - e);vec3 d1 = d0 - (i1 - K2);vec3 d2 = d0 - (i2 - K1);vec3 d3 = d0 - 0.5;vec4 h = max(0.6 - vec4(dot(d0, d0), dot(d1, d1), dot(d2, d2), dot(d3, d3)), 0.0);vec4 n = h * h * h * h * vec4(dot(d0, hash33(i)), dot(d1, hash33(i + i1)), dot(d2, hash33(i + i2)), dot(d3, hash33(i + 1.0)));return dot(vec4(31.316), n);
}vec4 extractAlpha(vec3 colorIn)
{vec4 colorOut;float maxValue = min(max(max(colorIn.r, colorIn.g), colorIn.b), 1.0);if (maxValue > 1e-5){colorOut.rgb = colorIn.rgb * (1.0 / maxValue);colorOut.a = maxValue;}else{colorOut = vec4(0.0);}return colorOut;
}#define BG_COLOR (vec3(sin(iTime)*0.5+0.5) * 0.0 + vec3(0.0))
#define time iTime
const vec3 color1 = vec3(0.611765, 0.262745, 0.996078);
const vec3 color2 = vec3(0.298039, 0.760784, 0.913725);
const vec3 color3 = vec3(0.062745, 0.078431, 0.600000);
const float innerRadius = 0.6;
const float noiseScale = 0.65;float light1(float intensity, float attenuation, float dist)
{return intensity / (1.0 + dist * attenuation);
}
float light2(float intensity, float attenuation, float dist)
{return intensity / (1.0 + dist * dist * attenuation);
}void draw( out vec4 _FragColor, in vec2 vUv )
{vec2 uv = vUv;float ang = atan(uv.y, uv.x);float len = length(uv);float v0, v1, v2, v3, cl;float r0, d0, n0;float r, d;// ring// 生成随机数n0 = snoise3( vec3(uv * noiseScale, time * 0.5) ) * 0.5 + 0.5;// 动态变化的圆半径,呈现呼吸感,这个是灵魂r0 = mix(mix(innerRadius, 1.0, 0.4), mix(innerRadius, 1.0, 0.6), n0);// 与圆边界的距离. r0==len时为0d0 = distance(uv, r0 / len * uv);// 光线(颜色)随距离(距离圆边界)变化v0 = light1(1.0, 10.0, d0);// 裁掉 r0*1.05 距离外的颜色v0 *= smoothstep(r0 * 1.05, r0, len);// 颜色混合参数,根据时间变化cl = cos(ang + time * 2.0) * 0.5 + 0.5;// high light// 控制高亮光线顺时针变化float a = time * -1.0;// 当前高亮位置的坐标vec2 pos = vec2(cos(a), sin(a)) * r0;// 与高亮位置的距离d = distance(uv, pos);// 光线衰减,环形v1 = light2(1.5, 5.0, d);// 光线衰减,距离边界。(沿边界快速衰减)v1 *= light1(1.0, 50.0 , d0);// back decay// 实心圆v2 = smoothstep(1.0, mix(innerRadius, 1.0, n0 * 0.5), len);// hole// 圆环v3 = smoothstep(innerRadius, mix(innerRadius, 1.0, 0.5), len);// color//vec3 c = mix(color1, color2, cl);// 根据时间变化的颜色值vec3 col = mix(color1, color2, cl);// 随距离与color3颜色混合col = mix(color3, col, v0);// 高亮,交集圆环col = (col + v1) * v2 * v3 ;//col.rgb = clamp(col.rgb, 0.0, 1.0);// 调整颜色,同时将原色中rgb中最大的值作为alpha,后续作为颜色融合的参数.// 经过试验:没有这一步以及后面的颜色混合,效果也跟最终效果差不多,从前面的代码逻辑也可以看出// 如果有这一步,因为extractAlpha函数内部对rgb做了放大,反而后面必须跟mix,相当于是个逆操作_FragColor = extractAlpha(col);
}// 入口函数
void mainImage( out vec4 fragColor, in vec2 fragCoord )
{// 变换到[-1,1]范围的坐标系。(注意除的是界面x y轴短的那根轴)vec2 uv = (fragCoord*2.-iResolution.xy)/iResolution.y;vec4 col;draw(col, uv);vec3 bg = BG_COLOR;// 这里用到一个小技巧,使用col.a作为颜色融合的参数// 颜色融合,否则背景、前景界限明显fragColor.rgb = mix(bg, col.rgb, col.a); //normal blend
}

关键步骤

从上面的代码逻辑看,一个动态变化的光晕,有几个关键步骤:
1 动态变化的半径,细微变化。
2 动态变化的颜色,通过简单的颜色融合就能取得不错的效果。
3 逆时针或者顺时针变化的高亮区域。
4 沿圆边界或高亮区衰减的颜色。

总结

本篇shader代码整洁,很适合我这种初学者学习入门。从代码结构很容易看出关键的实现思路,里面也有些技巧,值得反复学习,比如沿边界衰减的方式、不同的衰减方法、高亮色的计算、以及圆环的实现方式等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/4202.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

zynq dcache一致性问题

使能dcahce后,写内存不正常。 http://static.stmcu.com.cn/upload/pdf_html/93bd41d6e1e3dfc64cecbea29ccdef41.html FPGA - ZYNQ Cache一致性问题 FPGA - ZYNQ Cache一致性问题-CSDN博客

Unity类银河恶魔城学习记录15-5,6 p157 Audio time limiter p158 Area sound

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili​​ AreaSound.cs using System.Collections; using System.Collections.G…

视频输入c++ 调用 libtorch推理

1、支持GPU情况 libtorch 支持GPU情况比较奇怪,目前2.3 版本需要在链接器里面加上以下命令,否则不会支持gpu -INCLUDE:?ignore_this_library_placeholderYAHXZ 2 探测是否支持 加一个函数看你是否支持torch,不然不清楚,看到…

Hive函数详解

Hive 是一个建立在 Hadoop 上的数据仓库基础架构,它提供了类似于 SQL 的查询语言,称为 HiveQL,用于对存储在 Hadoop 分布式文件系统中的数据进行查询和分析。 1.函数简介 Hive会将常用的逻辑封装成函数给用户进行使用,类似于Jav…

Web前端开发 小实训(一) 成绩分类统计

用于学生web前端开发课程实训练习,掌握基本语法和数据类型 实训目的 使用分支语句,完成分数统计与等级对比,通过输入框输入分数,可以根据分数多少划分等级。 参考思路: 分析题目:根据输入分数进行等级划分。 操作过…

springboot如何使用RedisTemplate

第一步&#xff1a;创建一个spring boot项目 第二步&#xff1a;pom导入redis相关依赖 <!--reids依赖--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </depen…

Go语言中的goroutine调度是如何实现的?

文章目录 一、M:N调度模型二、GMP模型三、调度过程四、调度优化五、示例代码 在Go语言中&#xff0c;goroutine是一种轻量级的线程&#xff0c;它使得并发编程变得更加简单和高效。而goroutine的调度则是Go运行时&#xff08;runtime&#xff09;系统负责的一个核心任务&#x…

std::remove_if

template <class ForwardIterator, class UnaryPredicate>ForwardIterator remove_if (ForwardIterator first, ForwardIterator last,UnaryPredicate pred);std::remove_if函数删除容器中满足pred的元素&#xff0c;返回最后一个没被移除的元素后面一个迭代器&#xff0…

阿米巴经营之深入解读

目录 什么是阿米巴&#xff1f; 一、阿米巴经营的来历 二、阿米巴经营的三大好处和运作方式 三、阿米巴经营常见的两大问题与解决方案 稻盛和夫被誉为日本的经营之神。上个世纪&#xff0c;他创办经营的京瓷公司、KDDI公司等&#xff0c;先后成为了世界500强企业。2010年&…

Postman,一个功能强大的API开发和测试工具

最近有小伙伴说在找 postman 的使用教程&#xff0c;案例等文章。 那么今天我就来写一个。 Postman 是一个功能强大的 API 开发和测试工具&#xff0c;它提供了丰富的功能&#xff0c;帮助开发人员更好地管理、测试和文档化 API。无论是单独开发还是团队协作&#xff0c;Postma…

[1688]jsp工资投放管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 工资投放管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0…

Java读取网址信息

Java读取网址信息 今天的需求是根据接口获取JSON数据并存入&#xff0c;之前只会前端用Ajax或者Axios去处理显示出来没想过后端也要拿&#xff0c;没有思路于是查找&#xff0c;发现都是基础以前用的还是太少了&#xff0c;特此总结&#xff0c;后续有需要再补充。 1.读取get请…

vue都有那些指令?

Vue的指令是用于在HTML模板中添加特定功能的特殊属性。Vue提供了一些内置的指令&#xff0c;同时也支持自定义指令。以下是一些常用的Vue指令&#xff1a; v-bind&#xff1a;用于动态绑定HTML元素的属性。可以将Vue实例中的数据绑定到HTML元素的属性上&#xff0c;实现数据的动…

黑马面试篇

课程地址&#xff1a;新版Java面试专题视频教程&#xff0c;java八股文面试全套真题深度详解&#xff08;含大厂高频面试真题&#xff09;_哔哩哔哩_bilibili 课程名称&#xff1a;新版Java面试专题视频教程&#xff0c;java八股文面试全套真题深度详解&#xff08;含大厂高频…

【Kotlin】Flow简介

1 前言 Flow 是 Kotlin 标准库中的一个新的异步流处理框架&#xff0c;旨在简化异步数据流的操作和处理&#xff0c;它提供了一种声明式的方式来处理数据流。 Flow 中一些接口调用有些类似 Sequence&#xff08;详见 → Sequence简介&#xff09;&#xff0c;协程的使用详见 →…

Flutter - 折叠面板

demo 地址: https://github.com/iotjin/jh_flutter_demo 代码不定时更新&#xff0c;请前往github查看最新代码 flutter 自定义折叠组件 支持三种类型和两种展示效果可自定义title和被折叠的内容 效果图 示例 import package:flutter/material.dart; import /jh_common/widge…

K8s: 从集群外部访问Service

从集群外部访问 Service 1 &#xff09;概述 在前面我们一直实践的是在集群内部访问 Service&#xff0c;之前有2种方法 方法1&#xff1a;在一个node节点上&#xff0c;通过对创建的的时候&#xff0c;对port进行一个环境变量的注册来保证Service能够正确对 不同的pod 访问到…

基于SNAP使用SAR数据做变化检测change detection

基于SNAP使用SAR数据做变化检测change detection 1. 前言2. 步骤2.1 添加数据2.2 辐射定标--散斑过滤--地形矫正2.3 裁剪2.4 变化检测 3.查看变化检测结果 1. 前言 在SNAP中&#xff0c;change detection主要通过Stack工具来完成。 SAR数据&#xff1a;Radarsat-2 SLC 其他数据…

基于FastGPT搭建知识库问答系统

什么是 FastGPT &#xff1f; FastGPT 是一个基于 LLM 大语言模型的知识库问答系统&#xff0c;提供开箱即用的数据处理、模型调用等能力。同时可以通过 Flow 可视化进行工作流编排&#xff0c;从而实现复杂的问答场景&#xff01; FastGPT 允许用户构建本地知识库&#xff0c;…

conda创建新环境

&#xff11;、创建虚拟环境&#xff1a; Anaconda创建环境&#xff1a;比如&#xff0c;创建pyhon&#xff1d;3.6的版本环境取名叫 name conda create -n name python3.6 2、删除虚拟环境操作&#xff1a;&#xff08;谨慎操作&#xff09; conda remove -n name --all &am…