首页 > 其他分享 >KodeLife | Shader 实时编辑预览的强大工具使用实践

KodeLife | Shader 实时编辑预览的强大工具使用实践

时间:2022-10-13 16:31:28浏览次数:74  
标签:1.0 KodeLife 预览 float Shader vec2 vec3


公众号回复:666,领取学习资源大礼包

经常有朋友在群里面问想学习 Shader 有什么工具可以推荐?

今天它来了~~~

推荐一款强大的 Shader 实时编辑预览的工具 —— ​​KodeLife​​ 。

对,它的名字就叫做 ​​KodeLife​​​ ,可别看成 ​​KobeLife​​ 了,一个字母之差完全就是两个概念。

​KodeLife​​ 的官网地址如下:

​https://hexler.net/products/kodelife​

贴一张主页封面图:

KodeLife | Shader 实时编辑预览的强大工具使用实践_加载

需要的同学可以去官网下载安装,它是需要购买 License 的,不过可以免费使用两个月。


KodeLife 的编辑功能

它的实时编辑预览功能有多强,先来看一波视频打个鸡血~~


是不是心动了,也想做出这样的效果,接下来就体验它的编辑功能吧

首次打开 KodeLife 会加载并演示默认的 Shader 代码效果。

KodeLife | Shader 实时编辑预览的强大工具使用实践_加载_02

编辑区就是我们写 Shader 代码的地方,背后的画面就是实时预览的效果。这画面效果是会随着时间不断改变的,这里只是静态图看不到而已。

首次打开可能会被这个效果给吓唬到,毕竟这画面五颜六色而且还闪来闪去,其实很多东西都可以去掉的,一个简单的例子会更容易上手一些。

如下图:

KodeLife | Shader 实时编辑预览的强大工具使用实践_加载_03

看到这中间打钩的三个选项了嘛,它们分别是 OpenGL 渲染不同阶段对应的着色器,由于我们都是用 OpenGL ES ,它是 OpenGL 的子集,一些功能都被移除了,所以下面这些 Shader 都是用不到的。

简单介绍一下它们的名字:

  • Tess Control
  • 全名:Tessellation Control Shader
  • 中文名:曲面细分控制着色器
  • Tess Eval
  • 全名:Tessellation Evaluation Shader

  • 中文名:曲面细分计算着色器


  • Geometry


  • 全名:Geometry Shader

  • 中文名:几何着色器

抛开这三个不看,那么剩下的标签页就是 ​​Vertex​​​ 和 ​​Fragment​​ ,分别是顶点着色器和片段着色器,这应该很熟悉了。


KodeLife 使用实践

接下来我们就要新建一个 Shader 进行编写。

KodeLife | Shader 实时编辑预览的强大工具使用实践_加载_04

在 ​​File​​​ 里面有两种 ​​New​​ 新建文件的类型。

其中第二个 ​​New From Template​​​ 就会按照 ​​Shadertoy​​​ 或者 ​​The Book of Shaders​​ 的示例来加载 Shader 模板工程。

温馨提示:

Shadertoy 是非常有名的 Shader 学习网站,上面有着绚丽的 Shader 效果,并且有源码供学习,就是网站打开速度太慢了。

The Book of Shaders 是一本非常有名的 Shader 入门学习书籍,讲解的示例简单易学。

这里我们按照 ​​The Book of Shaders​​ 提供的模板新建一个工程来编写代码。

下面是工程建好后对应的代码和效果。

KodeLife | Shader 实时编辑预览的强大工具使用实践_着色器_05

它自带了三个 ​​unifrom​​ 变量:

  • u_resolution
  • 图像的分辨率
  • u_mouse
  • 鼠标点的位置

  • u_time

  • 时间

可以在 Shader 去利用这个三个变量,它们的输入值是由 KodeLife 来保证的,在右侧可以查看并修改这变量的具体值。

KodeLife | Shader 实时编辑预览的强大工具使用实践_着色器_06

  • 数字 0 区域:
  • Shader 效果的预览区域
  • 数字 1 区域:
  • 开关控制是否使用下面的属性内容

  • 查看当前的属性,比如查看并编辑图像分辨率的

  • 指定 Clear Color 时的颜色


  • 数字 2 区域:


  • 时间变量,可以在里面控制时间的开始和停止

  • 可以调整时间变化的速

  • 可以调整时间变化的起始和结束值,并在该区域内循环


  • 数字 3 区域:


  • 显示图片的分辨率


  • 数字 4 区域:


  • 设置鼠标的点击区域

  • 在数字 4 的右侧区域内点击鼠标,改变鼠标区域值

  • 可以单独设置 X 和 Y 值,也可以设置是否要归一化操作

以上就是 KodeLife 进行 Shader 编写的操作部分了,相信你也已经知道要如何操作了。

如果使用 ​​Shadertoy​​ 提供的模板,它自带的变量会多一点,但都大同小异了,而且这都不是重点,重点还是如何使用这些变量进行创作。

所以接下来就是发挥想象力进行 Shader 的开发了。


KodeLife Shader 编写实践

提供两个简单例子,演示一下在 KodeLife 中编写代码实现网格效果。

代码如下:

#ifdef
precision mediump float;
#endif

uniform vec2 u_resolution;
uniform vec2 u_mouse;
uniform float u_time;

void main(){

vec2 fragcoord = vec2(gl_FragCoord.xy / u_resolution);
vec3 bgColor = vec3(1.0,1.0,1.0);
vec3 pixelColor = bgColor;
vec3 gridColor = vec3(0.5,0.5,0.5);

const float width = 0.1;
const float minWidth = 0.003;
for(float i = 0.0; i < 1.0; i+=width){
if (mod(fragcoord.x,width) < minWidth || mod(fragcoord.y,width) < minWidth){
pixelColor = gridColor;
}
}

gl_FragColor = vec4(pixelColor,1.0);
}

效果如下:

KodeLife | Shader 实时编辑预览的强大工具使用实践_着色器_07

#ifdef
precision mediump float;
#endif

uniform vec2 u_resolution;
uniform vec2 u_mouse;
uniform float u_time;

void main(){

vec2 r = vec2(gl_FragCoord.xy - 0.5 * u_resolution);
vec2 fragcoord = 2.0 * r.xy / u_resolution;

vec3 bgColor = vec3(1.0,1.0,1.0);
vec3 pixelColor = bgColor;
vec3 gridColor = vec3(0.5,0.5,0.5);
vec3 axesColor = vec3(1.0,0.0,0.0);

const float width = 0.1;
const float minWidth = 0.008;
for(float i = 0.0; i < 1.0; i+=width){
if (mod(fragcoord.x,width) < minWidth || mod(fragcoord.y,width) < minWidth){
pixelColor = gridColor;
}
}

if (abs(fragcoord.x) < 0.008 || abs(fragcoord.y) < 0.008){
pixelColor = axesColor;
}


gl_FragColor = vec4(pixelColor,1.0);
}

效果如下:

KodeLife | Shader 实时编辑预览的强大工具使用实践_着色器_08

把代码复制粘贴到 KodeLife 中运行就能看到效果了。

这两个效果的区别就是在于中间坐标轴绘制了,你能从代码中看到有何不同吗?

在后续的文章再来讲解如何编写 Shader 吧~~~

KodeLife | Shader 实时编辑预览的强大工具使用实践_着色器_09


KodeLife | Shader 实时编辑预览的强大工具使用实践_加载_10



标签:1.0,KodeLife,预览,float,Shader,vec2,vec3
From: https://blog.51cto.com/u_12127193/5753734

相关文章

  • kkFileView 文件预览相关配置
     官网地址 http://kkfileview.keking.cn/zh-cn/docs/production.html 上传txt预览乱码问题 修改bin/startup.bat用notepad打开修改主要添加-Dfile.encoding=UT......
  • python基础-较复杂数据类型预览
    1.初识列表  列表就是队列;  列表是一种有序的,且内容可重复的数据类型;  用list代表列表,也可以用list()定义一个列表,同时定义列表可以直接使用[];  python中列......
  • python基础--简单数据类型预览
    为了适应更多的使用场景,将数据划分为多种类型,每种类型都有各自的特点和使用场景,帮助计算机高效的处理和展示数据。(比如数字用于数学运算、字符串用于信息传递、页面文字展......
  • 特牛的win资源管理器PDF预览插件
    步骤一:下载控件包后解压(废话)步骤二:32位系统:将32位控件复制到C:\Windows\System32    64位系统:将64位控件复制到C:\Windows\SysWOW64  步骤三:win徽标+X  打开Win......
  • Android开发 Jetpack_Compose_2 页面预览@Preview
    前言在学习jetpackcompose如何编写ui之前,我认为还是应该先了解与Androidstudio配合的页面预览@Preview。这样就可以立刻看到UI效果,从而方便后续学习验证代码。所......
  • 【教程】如何加入 Windows 预览体验计划
    微软已经在本月24号正式发布了“下一代Windows”操作系统——Windows11,据微软介绍,正式版的Win11可能需要今年秋季才会推送。所以目前我们只能体验到预览版的Win11,体......
  • vscode markdown WYSIWYG 所见即所得编辑和预览
    一直使用Typora编写markdown,随着vscode在工作中使用的越来越多,产生了一个想法:能不能在vscode中写markdown,减少软件的成本?可是vscode官方自带的的markdown体验却一般般,那......
  • 缺少 TPM 2.0 导致无法升级 Win11 最新 Dev 预览版的解决方案
    微软在本周四向Windows预览计划的Dev频道推送了Win11最新预览版的更新,版本号为22458.1000,但是有很多朋友在更新系统时都遇到了因缺少TPM2.0支持导致无法正常升级......
  • vue pdf预览
    用到的插件是vuepdf1、对于不能通过npminstall安装的,需要去官网下载打包好的文件,文件夹大概是这个样子的,  然后在用到的.vue文件中引入就ok了  创建一个展示pd......
  • 预览附件
    usingKingdee.BOS.ServiceHelper.FileServer;JSONObjectwebobj=newJSONObject();stringticks=DateTime.Now.Ticks.ToString();......