html5 冒烟效果,利用HTML5实现3D火焰冒烟动画特效

特效描述:利用HTML5实现 3D火焰冒烟 动画特效。利用HTML5实现3D火焰冒烟动画特效

代码结构

1. 引入CSS

2. 引入JS

3. HTML代码

precision mediump float;

precision mediump int;

attribute vec4 color;

varying vec2 vUv;

varying float vFade;

void main(){

vUv = uv;

vec4 localPosition = vec4( position, 1);

vFade = clamp((localPosition.y + 3.0) / 6.0, 0.0, 1.0);

gl_Position = projectionMatrix * modelViewMatrix * localPosition;

}

precision mediump float;

precision mediump int;

uniform float time;

uniform float blend;

uniform sampler2D blendPattern;

varying float vFade;

varying vec2 vUv;

void main(){

vec4 startColor = vec4(1., 0.5, 0.1, 1.0);

vec4 endColor = vec4(0.2, 0.2, 0.2, 1.0);

float dissolve = texture2D(blendPattern, vUv).r * 0.5;

float spread = 0.4;

float fadeAmount = smoothstep(

max(0.0, vFade - spread),

min(1.0, vFade + spread),

blend + dissolve

);

vec4 color = mix(

startColor, endColor,

smoothstep(0.1,1., fadeAmount)

);

gl_FragColor = vec4(color.rgb, 1.-fadeAmount);

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值