将 ShaderToy 上的着色器例子移植到 QML 中

将 ShaderToy 上的着色器例子移植到 QML 中

ShaderToy 是一个着色器学习网站,大牛在这个网站上分享他的 GLSL,以及炫酷的示例。

如下代码,将 ShaderToy 的一些思维进行了封装,需要考虑 GLSL ES 接口。

#ifndef GL_ES

#extension GL_EXT_shader_texture_lod : enable
#extension GL_OES_standard_derivatives : enable

precision highp float;
precision highp int;
precision mediump sampler2D;

#endif

#ifdef GL_ES
precision mediump float;
#endif

uniform lowp float qt_Opacity;
varying highp vec2 qt_TexCoord0;

uniform vec3 iResolution ;

uniform float iGlobalTime;

uniform float     iChannelTime[4];
uniform vec3      iChannelResolution[4];

uniform vec4      iMouse;
uniform sampler2D iChannel0;
uniform sampler2D iChannel1;
uniform sampler2D iChannel2;
uniform sampler2D iChannel3;
uniform vec4      iDate;

uniform float     iSampleRate;

ShaderToy 中一定会使用的 void mainImage( out vec4 fragColor, in vec2 fragCoord )

void main(void)
{
    mainImage(gl_FragColor, gl_FragCoord.xy);
}

注意,GLSL 支持函数重载,但是 GLSL 不支持隐式转换,所以参数传递时必须类型匹配。

最后看看项目 ShaderToy.qml,使用 ShaderEffect 进行显卡渲染的例子吧。


参考:

【ShaderToy】开篇

shadertoy-iOS-v2

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值