zoukankan      html  css  js  c++  java
  • Tesselation学习

    Tesselation的作用:给低片面数模型镶嵌更多片面,让低模变高模。

    和法线贴图不同,法线本质是通过改变低模表面的颜色来模拟高模,比如在一个片面上普通diffuse是均匀的颜色分布(因为光照颜色一样,它插值顶点对应纹理色值,所以是均匀的,很多情况还是单一的,比如全是灰色等),而法线贴图通过插手光照颜色,使得该片面的色值各种变化而造成眼睛的错觉:该片面表面是凹凸不平的,是多个片面构成的。

    文:http://blog.csdn.net/qq984786645/article/details/73920811中所说的置换贴图是在顶点shader里对顶点位置进行一定的偏移而让模型变得更加凹凸,但这个其实很依赖模型的片面数,因为它是对顶点进行操作的,片面很少顶点很稀,效果就出不来,官方文档(Unity/Editor/Data/Documentation/en/Manual/SL-SurfaceShaderTessellation.html)中的“displacement in vert shader”就是这样做的。

    但如果先使用Tesselation增加片面,然后在使用置换贴图进行偏移顶点,效果就出来了。官方文档也说了,先进行tesselation,然后对所有顶点执行domain shader里的vert函数

    至于Tesselation的几个镶嵌方案可以看官方文档的例子。

    有时候制作置换贴图需要花时间,可以通过Phong Tesselation来进行默认的凹凸平滑,来代替置换贴图,具体效果可以看官方文档。

    看完官方文档后,需要知道的是:

    1.Tesselation只是在片面上增加更多片面,比如把一个三角形对半分成2个三角形,如果不做任何其他处理,直接进行surf处理,和原来的渲染结果是一样的。

    2.Displacement Mapping即置换贴图做的事情是,对每个顶点进行位置偏移。

    3.Phong Tesselation=Tesselation+Phong

    一般的方案是1+2或者单独3,Phong是一种平滑各个片面的Displacement mapping算法

    值得注意的是,Tesselation需要DX11或OPENGL Core这么高级的GPU API

  • 相关阅读:
    用友 t6 凭证http API
    vue 解决 跳转外部地址携带根路径问题
    JavaScript之assign()——对象浅拷贝 (ES6)
    JavaScript之splice 添加或删除元素
    JavaScript之“==”和“===”
    C#——获取阶乘(递归、循环)
    C#——简单的表示两个数中的(三目运算)
    JavaScript 字符串之截取字符串 ——(substring、substr、slice)
    JavaScrpit之Json实现深拷贝
    Vue之this.$forceUpdate——强制更新数据
  • 原文地址:https://www.cnblogs.com/Tearix/p/8343846.html
Copyright © 2011-2022 走看看