zoukankan      html  css  js  c++  java
  • 《Compress data for deferred shadering's G-Buffer》

    对于Normal而言,因为是归一化后的,所以只需要存储x和y即可,有多种算法可以进行压缩和解压,这里介绍其中一种比较不错的:

    float2 encode(float3 normal)
    {
       return normalize(normal.xy) * sqrt(normal.z * 0.5 + 0.5);
    }
    float3 decode(float2 n)
    {
       float3 normal;
       normal.z = dot(n, n) * 2 - 1;
       normal.xy = normalize(n) * sqrt(1 - normal.z * normal.z);
       return normal;
    }

    对于position的压缩,由于在PS中的像素所在位置已经提供了x和y,可以由x和y计算出z;在GBuffer中可以存储view space中的z除以far plane的值,而在lighting pass中PS拿到像素在view space的位置后计算:

    p = view_dir * ((z * far_plane) / view_dir.z);

    这样得到的P值的z分量就是真正的view space中的z深度值;其中view_dir是VS传到PS中的,在VS中计算过程是顶点乘上world*view矩阵的结果;

    参考:http://www.klayge.org/2011/01/16/klayge%E4%B8%AD%E7%9A%84%E5%BB%B6%E8%BF%9F%E6%B8%B2%E6%9F%93%EF%BC%88%E4%BA%8C%EF%BC%89/

  • 相关阅读:
    jQuery,from标签,歪路子小技巧
    UniApp随笔
    JS的一些操作
    文本环绕
    Dictionary 存储函数,方法
    GIT项目管理
    Vue2 学习记录
    VSCode + Vue 学习笔记
    Mysql,Insert,Select时自增长问题
    ASP.NET SignalR Troubeshooting
  • 原文地址:https://www.cnblogs.com/DeanWang/p/7077851.html
Copyright © 2011-2022 走看看