IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> How I built a wind map with WebGL 译文理解(没完) -> 正文阅读

[JavaScript知识库]How I built a wind map with WebGL 译文理解(没完)

前言: 感谢XXHolic 大佬的翻译以及部分的解读内容,接着大佬的内容补充部分不够详细的点?(大概是对纹理一无所知的人,这篇文章看到你会失声尖叫然后迷恋上我)由于仍处于学习阶段,仅作部分自己的理解拓展,说白了没啥文化,术语也不懂几个,你喜欢,那就再好不过了。

参考与感谢

译者XXHolic
How I built a wind map with WebGL译文
【译】A GPU Approach to Particle Physics

作者Clawko图形学底层探秘 - 纹理采样、环绕、过滤与Mipmap的那些事

绘制风场数据与为何使用图片存储的道理

在这里插入图片描述
根据原文中的部分,水平 即 u ,垂直为v ,对应 rgba 颜色里的 red 与 green 的值, 如何求这个值 以及渲染这个图像?

  • 别问我风场数据长什么样

/**
 *  根据 windata  绘制 风场图
 * @param {*} data 
 * @returns 
 */
function generateWindMap(data) {
    let canvas = document.createElement('canvas')

    //  init 
    let [u_obj, v_obj] = data
    let [u_header, v_header] = [u_obj.header, v_obj.header]
    let [u_data, v_data] = [u_obj.data, v_obj.data]
    let { nx, ny } = u_header
    let [u_min, u_max, v_min, v_max] = [u_header.minData, u_header.maxData, v_header.minData, v_header.maxData]

    let ctx = canvas.getContext('2d')
    canvas.width = nx
    canvas.height = ny
    let imgData = new ImageData(nx, ny)

    // 映射  return array from [u,v]
    function reflect(datau, datav) {
        // 0 - 255 min - max
        let u = (datau - u_min) / (u_max - u_min) * 255
        let v = (datav - v_min) / (v_max - v_min) * 255
        return [u, v]
    }

    for (let i = 0; i < ny; i++) {
        for (let j = 0; j < nx; j++) {
            let dataIndex = i * nx + j;
            let res = reflect(u_data[dataIndex], v_data[dataIndex])
            imgData.data[4 * dataIndex + 0] = res[0];
            imgData.data[4 * dataIndex + 1] = res[1];
            imgData.data[4 * dataIndex + 2] = 0;
            imgData.data[4 * dataIndex + 3] = 255;
        }
    }

    ctx.putImageData(imgData, 0, 0);
    console.log(canvas.toDataURL());
    return canvas.toDataURL();
}
  • 具体原理
    在这里插入图片描述
  • 为何将 u v 值 转换成rgb值 最后保存成一张图片?
    最简单、快速的理解:存7,8M的数据还是存一个80K的图片好?这张图片上面根据这个映射的规律或者说是解码 我们就可以通过纹理采样读取到原来的数据。

绘制点的顶点着色器分析

precision mediump float;

attribute float a_index;

uniform sampler2D u_particles;
uniform float u_particles_res;

varying vec2 v_particle_pos;

void main() {
   // 目前只分析这段
   vec4 color = texture2D(u_particles, vec2(
       fract(a_index / u_particles_res),
       floor(a_index / u_particles_res) / u_particles_res));

   // decode current particle position from the pixel's RGBA value
   v_particle_pos = vec2(
       color.r / 255.0 + color.b,
       color.g / 255.0 + color.a);

   gl_PointSize = 1.0;
   gl_Position = vec4(2.0 * v_particle_pos.x - 1.0, 1.0 - 2.0 * v_particle_pos.y, 0, 1);
}

假设粒子数量为 particlesNum , 我们用纹理(图片)保存他的状态,如法炮制,但首先明确的是这个只是一个数字,但我们可以对他开根号,得到一个长宽同样的空的纹理图片面积
u_particles_res 则是粒子数量开根的结果,就相当于映射的边界,统一看图。

  • vec4 color 这段有啥意义?
    texture2D 获取u_particles 这张纹理,将在此纹理坐标上的颜色取出来。
    为啥是这个计算?这个计算想表达什么?一图给你讲明白。
    在这里插入图片描述
    x轴方向上应该比较好理解,y轴上为什么还要再除一次res? 获得的整数部分 相当于只是我们在普通的xy的坐标上的位置,再除一次 才是它真实的纹理y方向上的值。
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-14 23:43:36  更:2022-04-14 23:44:27 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 0:11:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码