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

简介: 经常有朋友在群里面问想学习 Shader 有什么工具可以推荐?今天它来了~~~

作者:星陨
来源:音视频开发进阶

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

今天它来了~~~
推荐一款强大的 Shader 实时编辑预览的工具 —— KodeLife

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

KodeLife 的官网地址如下:

https://hexler.net/products/kodelife

贴一张主页封面图:

image.png

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

KodeLife 的编辑功能

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

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

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

image.png

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

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

如下图:

image.png

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

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

Tess Control

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

Tess Eval

  • 全名:Tessellation Evaluation Shader
  • 中文名:曲面细分计算着色器

Geometry

  • 全名:Geometry Shader
  • 中文名:几何着色器

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

KodeLife 使用实践

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

image.png

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

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

温馨提示:

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

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

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

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

image.png

它自带了三个 unifrom 变量:

  • u_resolution
    ·图像的分辨率

  • u_mouse
    ·鼠标点的位置

  • u_time
    ·时间

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

image.png

数字 0 区域:

  • Shader 效果的预览区域

数字 1 区域:

  • 开关控制是否使用下面的属性内容
  • 查看当前的属性,比如查看并编辑图像分辨率的
  • 指定 Clear Color 时的颜色

数字 2 区域:

  • 时间变量,可以在里面控制时间的开始和停止
  • 可以调整时间变化的速
  • 可以调整时间变化的起始和结束值,并在该区域内循环

数字 3 区域:

  • 显示图片的分辨率

数字 4 区域:

  • 设置鼠标的点击区域
  • 在数字 4 的右侧区域内点击鼠标,改变鼠标区域值
  • 可以单独设置 X 和 Y 值,也可以设置是否要归一化操作

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

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

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

KodeLife Shader 编写实践

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

代码如下:

#ifdef GL_ES
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);
}
AI 代码解读

效果如下:
image.png

#ifdef GL_ES
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);
}
AI 代码解读

效果如下:

image.png

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

这两个效果的区别就是在于中间坐标轴绘制了,你能从代码中看到有何不同吗?
在后续的文章再来讲解如何编写 Shader 吧~~~

OpenGL 系列文章

「视频云技术」你最值得关注的音视频技术公众号,每周推送来自阿里云一线的实践技术文章,在这里与音视频领域一流工程师交流切磋。

阿里云社区.png

目录
打赏
0
0
0
0
72
分享
相关文章
分享一款好用的四合一缩略图生成在线工具
3M万能在线工具箱提供了一款“四合一网页设备缩略图”生成工具,可一键生成网页在台式机、笔记本、平板和手机上的缩略图,支持多种背景色选择,操作简单且安全可靠。该工具极大提升了网页设计和测试效率,适合设计师和开发者快速预览和展示网页效果。更多实用工具请访问:[3M万能在线工具箱](https://3m.panziye.com/)。
87 14
Unity编辑器神级扩展攻略:从批量操作到定制Inspector界面,手把手教你编写高效开发工具,解锁编辑器隐藏潜能
【8月更文挑战第31天】Unity是一款强大的游戏开发引擎,支持多平台发布与高度可定制的编辑器环境。通过自定义编辑器工具,开发者能显著提升工作效率。本文介绍如何使用C#脚本扩展Unity编辑器功能,包括批量调整游戏对象位置、创建自定义Inspector界面及项目统计窗口等实用工具,并提供具体示例代码。理解并应用这些技巧,可大幅优化开发流程,提高生产力。
600 1
一行命令快捷构建在线地图字体切片服务
一行命令快捷构建在线地图字体切片服务
64 2
用惯了其他人的库,自己来实现一个动图图表生成工具,真香!
用惯了其他人的库,自己来实现一个动图图表生成工具,真香!
PS工具的使用,如编辑工具栏选项,前后景色,画笔工具,缩放工具,抓手工具,矢量工具
通过本文,你就能了解到PS基本工具的使用,以及相关的背景知识!
324 0
Kakapos全平台视频导出并添加滤镜工具
Kakapos是一个视频添加过滤器工具,支持网络和本地网址以及相册视频。 同时可以简单的支持多种滤镜库,例如Harbeth、GPUImage、MetalPetal、CoreImage等等。 反正核心其实就是对`CVPixelBuffer`进行注入滤镜处理,然后再导出视频即可。 支持全平台系统,macOS、iOS、tvOS、watchOS
Kakapos全平台视频导出并添加滤镜工具
案例分享:Qt流水线图像显示控件(列刷新、1ms一次、缩放、拽拖、拽拖预览、性能优化、支持OpenGL GPU加速)
案例分享:Qt流水线图像显示控件(列刷新、1ms一次、缩放、拽拖、拽拖预览、性能优化、支持OpenGL GPU加速)
如何实现H5可视化编辑器的实时预览和真机扫码预览功能
所见即所得的设计理念在WEB IDE领域里一直是备受瞩目的功能亮点, 也能极大的提高** web coder的编程体验和编程效率. 笔者接下来就将对H5可视化编辑器的实时预览和真机扫码预览**功能做一次方案剖析, 为大家在设计类似产品的时候提供一些思路. 我们还是基于笔者开发的 H5-Dooring可视化编辑器作为案例来分析上述功能实现.
434 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等