前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OpenGL 从入门到成魔-第3章- Shader 和 Program(下)

OpenGL 从入门到成魔-第3章- Shader 和 Program(下)

作者头像
瑶瑶
发布2020-06-03 15:46:36
7830
发布2020-06-03 15:46:36
举报

注:参考自bilibili系列视频,OpenGL 从入门到成魔-第3章- Shader 和 Program(下)https://www.bilibili.com/video/BV1dt4y1C7Sz

顶点输入转换为屏幕输出流程

image

1.顶点: 位置、颜色等信息 2.顶点着色器(Vertex Shader):顶点的变换,每个顶点都执行一次shader 注:顶点着色器的 每个输入变量也叫顶点属性(Vertex Attribute)。我们能声明的顶点属性是有上限的,它一般由硬件来决定。OpenGL确保至少有16个包含4分量的顶点属性可用,但是有些硬件或许允许更多的顶点属性,通常情况下它至少会返回16个,大部分情况下是够用了。 3.图元装配:顶点--》图形 4.几何着色器:目前没用到 5.光栅化:图形--》像素数据

光栅化.png

  1. 片段着色器(Fragment Shader):计算每个像素的最终颜色,有多少像素,就执行几次。这也是所有OpenGL高级效果产生的地方。

写shader时的小技巧

由于c++里直接写字符串,会很麻烦,不停的换行,读起来也不清晰,我们可以用以下方法写shader

  1. 文件开头定义两个宏
    #define STRINGIZE(x) #x
    #define SHADER(shader) "" STRINGIZE(shader)
  1. 使用,注:SHADER( )括号内需要手动换行
   //顶点着色器 
   char* vertexShaderStr = SHADER(
      #version 330\n
        layout(location = 0) in vec3 pos;
        out vec3 outPos;
        void main()
        {
            outPos = pos;
            gl_Position = vec4(pos, 1.0);
        }
    );
  
    //片段着色器
    char* fragmentShaderStr = SHADER(
        #version 330\n

        out vec4 rgbaColor;
        in vec3 outPos;
        void main()
        {
            rgbaColor = vec4(outPos, 1.0);
        }
    );
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 顶点输入转换为屏幕输出流程
  • 写shader时的小技巧
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档