返回介绍

discard 舍弃片元

发布于 2021-07-10 18:17:39 字数 1195 浏览 1041 评论 0 收藏 0

discard关键字通常出现在片元着色器的if语句或for语句中,discard的使用语法就像for语句中的continuebreak关键字一样,直接编写discard;即可,但是discard的功能比较特殊,专门用于着色器片元处理。

如果想理解discard,你首先应该建立逐片元的概念。GPU的片元着色器在逐个处理片元的过程中,会把不符合程序条件的代码舍弃掉。

discard一个代码案例

//点绘制模式
gl.drawArrays(gl.POINTS, 0, 4);
<!-- 顶点着色器源码 -->
<script id="vertexShader" type="x-shader/x-vertex">
  //attribute声明vec4类型变量apos
  attribute vec4 apos;
  void main() {
    //点渲染的方形区域像素大小
    gl_PointSize = 100.0;
    //顶点坐标apos赋值给内置变量gl_Position
    //逐顶点处理数据
    gl_Position = apos;
  }
</script>
<!-- 片元着色器源码 -->
<script id="fragmentShader" type="x-shader/x-fragment">
  precision lowp float;// 所有float类型数据的精度是lowp
  void main() {
    // 计算方形区域每个片元距离方形几何中心的距离
    // gl.POINTS模式点渲染的方形区域,方形中心是0.5,0.5,左上角是坐标原点,右下角是1.0,1.0,
    float r = distance(gl_PointCoord, vec2(0.5, 0.5));
    //根据距离设置片元
    if(r > 0.5){
      // 距离方形中心距离大于0.5的片元剪裁舍弃掉
      discard;
    }
    gl_FragColor = vec4(1.0,0.0,0.0,1.0);
  }
</script>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文