当前位置: 首页 > news >正文

着色器语言GLSL学习

1 初步尝试

import { Scene, WebGLRenderer, OrthographicCamera, PlaneGeometry, ShaderMateria } from 'three.js'const scene = new Scene()
const camera = new OrthographicCamera(-1,1,1,-1,0.1, 10)const renderer = new WebGLRenderer()
renderer.setSize(window.innerWidth, window.innerHeight)
document.body.appendChild(renderer.domElement)// 创建一个大小为2 的平面几何容器
const geometry = new PlaneGeometry(2,2)// 设置着色器材质
const material = new ShaderMaterial()// 创建网格对象 绘制平面
const plane = new mesh(geometry, material)
scene.add(plane)//设置相机z轴以便能看到平面,注意范围为0.1 - 10,即远近裁截面
camera.position.z = 1 
renderer.render(scene, camera)

2 颜色随时间改变

const fragmentShader = {uniform float u_time;void main() {vec3 color = vec3((sin(u_time) + 1.0) /2.0, 0.0, (cos(u_time) + 1.0) /2.0);gl_FragColor = vec4(color, 1.0);}
}const uniforms = {u_time: { value: 0.0 }
}const clock =  new THREE.Clock()function animate(){requestAnimation(animate)uniforms.u_time.value += clock.getDelta()renderer.render(scene, camera)
}

3 混合

用法:mix(a,b,c)
公式:a*(1-c)+b*c, 0<=c<=1

4

http://www.lryc.cn/news/283735.html

相关文章:

  • C#: form 窗体的各种操作
  • “尔滨”宠粉再升级!百亿像素VR冰雪盛宴
  • redis原理(四)redis命令
  • FairGuard游戏安全2023年度报告
  • 进阶Docker4:网桥模式、主机模式与自定义网络
  • Qt 状态机框架:The State Machine Framework (二)
  • 【Redis】更改redis中的value值
  • 数据结构Java版(2)——栈Stack
  • tcpdump 用法
  • JavaScript SEO:如何为搜索引擎优化 JS
  • 深入探讨生产环境中秒杀接口并发量剧增、负载过高的情况该如何应对?
  • C语言再学习 -- C语言搭建TCP服务器/客户端
  • 企业远程控制如何保障安全?向日葵“全流程安全远控闭环”解析
  • 为什么需要放行回源IP
  • 2023一带一路暨金砖国家技能发展与技术创新大赛“网络安全”赛项省选拔赛样题卷②
  • C语言:预处理详解
  • 一区优化直接写:KOA-CNN-BiLSTM-Attention开普勒优化卷积、长短期记忆网络融合注意力机制的多变量回归预测程序!
  • 高防IP如何有效应对网站DDOS攻击
  • 1.6 面试经典150题 - 跳跃游戏
  • Apache安全及优化
  • 【话题】边缘计算的挑战和机遇
  • react之unpkg.com前端资源加载慢、加载不出
  • C++类与对象【对象模型和this指针】
  • 策略模式在工作中的运用
  • 【go】依赖倒置demo
  • C++ //练习 2.5 指出下述字面值的数据类型并说明每一组内几种字面值的区别:
  • 必示科技助力中国联通智网创新中心通过智能化运维(AIOps)通用能力成熟度3级评估
  • python数字图像处理基础(九)——特征匹配
  • k8s的对外服务ingress
  • [足式机器人]Part2 Dr. CAN学习笔记- Kalman Filter卡尔曼滤波器Ch05-3+4