OpenGL系列(四)Shader

    通过VBO和VAO准备好数据后,接下来要指示GPU如何通过这些数据绘制图形。类似CPU可以通过执行程序来完成特定的任务,GPU也可以执行特定的程序来完成绘制任务,GPU执行的程序称为Shader,也叫着色器。

    GPU绘制图形分为不同的处理阶段,在顶点处理和片元

OpenGL的着色器使用GLSL语言编写

着色器程序示例

     三角形示例icon-default.png?t=N7T8https://blog.csdn.net/leesino/article/details/139093716 使用到了顶点着色器(Vertex Shader)和片元着色器(Fragment Shader),下面分别对两者进行介绍。

    首先介绍的是顶点着色器,示例中的三角形的Vertex Shader的源码如下所示:

#version 300 es
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aColor;
out vec3 outColor;
void main()
{gl_Position = vec4(aPos, 1.0);outColor = aColor;
}

    Vertex Shader的源码解析:

  1. #version 300 es 指定使用 OpenGL ES 3.0版本。
  2. aPos 声明接收顶点数据的变量,其中layout (location = 0)表示数据从0号属性取出,in表示这是一个输入变量。vec3表示这是一个3个浮点数的向量。
  3. aColor用于接收颜色数据,内容从1号顶点属性获得。
  4. 在main方法中,把aPos转成4维向量后传给gl_Position,这是个内置变量,一般用于传递顶点数据,是一个4维的浮点数向量,因此这里要把顶点从3维向量转为4维向量。
  5. outColor用于将颜色属性传递到下一个阶段,out表示输出变量。

    顶点着色器程序的执行次数与顶点数量有关,因此绘制一个三角形要执行3次顶点着色器程序。

    接下来介绍片元着色器程序,片元着色器程序用于确定每个片元的最终颜色,三角形示例的代码如下。

#version 300 es
precision mediump float;
out vec4 FragColor;in vec3 outColor;
void main()
{FragColor = vec4(outColor, 1.0);
}
  1.  precision mediump float 设置浮点数精度为中精度。
  2. FragColor,该变量声明为out,用于输出片元的最终颜色。
  3. outColor,接收顶点着色器传递过来的颜色,名称必须与顶点着色器声明的一样。

    在光栅化阶段会计算得到一个三角形的片元数量,每个片元执行一次片元着色器程序才能得到它的颜色。

使用方法

    着色器程序准备好了以后,接下来是如何使用着色器绘制图形,大体上分为以下3步:

    1、编译,使用着色器程序绘制图形,首先要对着色器进行编译,编译步骤如下。

    GLuint shader = glCreateShader(shader_type);//attach source to shader objectglShaderSource(shader, 1, &source, NULL);glCompileShader(shader);// Check for compilation errorsGLint compiled = 0;glGetShaderiv(shader, GL_COMPILE_STATUS, &compiled);

    着色器编译流程解析如下:

  1. glCreateShader,创建着色器对象,创建成功后得到着色器的句柄。参数用于指明着色器的类型,GL_VERTEX_SHADER表示创建的是顶点着色器对象,GL_FRAGMENT_SHADER表示创建的是片元着色器对象。
  2. glShaderSource,将着色器程序加载到着色器对象中
  3. glCompileShader,对着色器进行编译
  4. glGetShaderiv,第二个参数传GL_COMPILE_STATUS表示要获取编译结果。

    如果顶点着色器和片元着色器编译都没有问题,下一步可以对它们进行链接。

2、链接

    链接过程主要把不同阶段的着色器变成一个程序,主要步骤如下

GLuint program = glCreateProgram();
glAttachShader(program, shaders[i]);
glLinkProgram(program);
glGetProgramiv(program, GL_LINK_STATUS, &linked);

链接步骤解析如下。

  1. glCreateProgram,创建着色器程序对象,成功后返回程序对象的句柄。
  2. glAttachShader,将着色器添加到程序对象
  3. glLinkProgram,链接程序
  4. glGetProgramiv,通过该方法可以获取链接结果。

链接没有问题,最后可以使用着色器程序绘制图形。

3、使用

   使用着色器绘制图形比较简单,以下是使用着色器程序绘制图形的过程。

void onDraw(){glUseProgram(mProgram);glBindVertexArray(VAO);glDrawArrays(GL_TRIANGLES, 0, 3);glUseProgram(0);
}

    绘制流程解析如下:

  1. glUseProgram指定要使用的着色器程序
  2. glBindVertextArray指定VAO,相当于明确了顶点数据
  3. glDrawArrays开始绘制
  4. 最后glUseProgram传入0表示未指定任何着色器程序。

到此为止,三角形示例的主要代码流程基本介绍完成,通过OpenGL系列(二)EGL,OpenGL系列(三)VBO、VAO和本文的学习,基本上能理解三角形的绘制流程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/847337.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文章解读与仿真程序复现思路——电力系统自动化EI\CSCD\北大核心《考虑发用电相似性的海上风电中长期双边协商交易优化决策模》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

小鸡庄园智慧农场养殖游戏开发:科技与农业的完美结合

随着科技的进步,一种全新的游戏模式——智慧农场养殖游戏,正在逐渐崭露头角。本文将深入探讨小鸡庄园智慧农场养殖游戏的开发背景、特点、技术实现方式以及未来的发展趋势,以期为游戏产业创新和农业现代化提供新的思路和启示。 一、开发背景…

Rust 性能分析

都说Rust性能好,但是也得代码写得好,猜猜下面两个代码哪个快 . - 力扣&#xff08;LeetCode&#xff09; use std::collections::HashMap; use lazy_static::lazy_static;lazy_static! {static ref DIGIT: HashMap<char, usize> {let mut m HashMap::new();for c in …

【Nacos】docker-compose启动nacos v2.2.3,启动时修改默认密码不使用naocs

1. 背景 出于安全考虑&#xff0c;我司DevOps平台自动部署的容器化nacos密码不能是弱密码或默认值 但是nacos-v2.2.3官方镜像启动后会初始化nacos用户密码为nacos&#xff0c;修改启动时的变量并没有生效。 2. 部署验证 2.1 yml文件如下 注意将derby库的初始化文件挂载出来…

Python | Leetcode Python题解之第129题求根节点到叶节点数字之和

题目&#xff1a; 题解&#xff1a; class Solution:def sumNumbers(self, root: TreeNode) -> int:if not root:return 0total 0nodeQueue collections.deque([root])numQueue collections.deque([root.val])while nodeQueue:node nodeQueue.popleft()num numQueue.p…

产品人生(9):从“波士顿矩阵”看“个人职业规划”

波士顿矩阵&#xff08;简称BCG矩阵&#xff09;是一种战略规划工具&#xff0c;由波士顿咨询公司的创始人布鲁斯亨德森&#xff08;Bruce Henderson&#xff09;于1970年代初提出的&#xff0c;它以两个关键指标作为分析维度&#xff1a;市场增长率和相对市场份额&#xff0c;…

探索k8s集群的配置资源(secret和configmap)

目录 ConfigMap ConfigMap&#xff08;主要是将配置目录或者文件挂载到k8s里面使用&#xff09; 与Secret类似&#xff0c;区别在于ConfigMap保存的是不需要加密配置的信息。&#xff08;例如&#xff1a;配置文件&#xff09; ConfigMap 功能在 Kubernetes1.2 版本中引入&…

过期视频怎么恢复?如何从手机、电脑和其他设备中恢复?

过期视频是指那些被误删、丢失或因系统升级等原因而无法正常访问的视频文件。这些视频可能包含了我们珍贵的回忆、重要的信息或者具有商业价值的内容。过期视频的恢复可以帮助我们找回失去的数据&#xff0c;减少损失&#xff0c;提高工作效率和生活质量。过期视频怎么恢复&…

Android WebView上传文件/自定义弹窗技术,附件的解决方案

安卓内核开发 其实是Android的webview默认是不支持<input type"file"/>文件上传的。现在的前端页面需要处理的是&#xff1a; 权限 文件路径AndroidManifest.xml <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE"/&g…

【AI基础】第二步:安装AI运行环境

开局一张图&#xff1a; 接下来按照从下往上的顺序来安装部署。 规则1 注意每个层级的安装版本&#xff0c;上层的版本由下层版本决定 比如CUDA的版本&#xff0c;需要看显卡安装了什么版本的驱动&#xff0c;然后CUDA的版本不能高于这个驱动的版本。 这个比较好理解&#xff…

毕业论文word常见问题

0、前言&#xff1a; 这里的问题都是以office办公软件当中的word为例&#xff0c;和WPS没有关系。 1、页眉横线删不掉&#xff1a; 解决方案&#xff1a;进入页眉编辑状态&#xff0c;在开始选项栏中选择页眉字体样式&#xff0c;清除格式。 修改方式如下&#xff1a; 2、…

Linux——简单指令汇总

Linux&#xff0c;一般指GNU/Linux&#xff0c;是一种免费使用和自由传播的类UNIX操作系统&#xff0c;其内核由林纳斯本纳第克特托瓦兹&#xff08;Linus Benedict Torvalds&#xff09;于1991年10月5日首次发布&#xff0c;它主要受到Minix和Unix思想的启发&#xff0c;是一个…

C++ | Leetcode C++题解之第130题被围绕的区域

题目&#xff1a; 题解&#xff1a; class Solution { public:const int dx[4] {1, -1, 0, 0};const int dy[4] {0, 0, 1, -1};void solve(vector<vector<char>>& board) {int n board.size();if (n 0) {return;}int m board[0].size();queue<pair<…

C++类的继承与派生概念

派生和继承是自然界普遍存在的一种现象。例如&#xff0c;“猫”和“白猫”。当人们谈及“猫”时&#xff0c;知道它有4条腿&#xff0c;1条尾巴&#xff0c;抓老鼠,为哺乳动物。如谈论“白猫”时&#xff0c;它也是猫&#xff0c;只不过增加了一个新的特征&#xff0c;即它的毛…

Redis缓存(笔记二:Redis常用五大数据类型)

目录 1、Redis中String字符串 1.1 常用命令解释&#xff1a; 1.2 原子性 1.3 具有原子性的常用命令 1.4 String数据结构 1、Redis中String字符串 概念 String 是 Redis 最基本的类型&#xff0c;可以理解成与 Memcached 一模一样的类型&#xff0c;一个 key对应一个 value…

第100天:权限提升-数据库RedisPostgre第三方软件TV向日葵服务类

目录 思维导图 案例一: 数据库-Redis 数据库权限提升-计划任务 案例二: 数据库-PostgreSQL 数据库权限提升-漏洞 PostgreSQL 提权漏洞&#xff08;CVE-2018-1058&#xff09; PostgreSQL 高权限命令执行漏洞&#xff08;CVE-2019-9193&#xff09; 案例三: 三方应用-…

【数据结构与算法 经典例题】(C语言)反转链表图文详解

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《数据结构与算法 经典例题》C语言 期待您的关注 ​ 目录 一、问题描述 二、解题思路分析 三、代码实现 一、问题描述 二、解题…

uniapp使用uQRCode页面不显示也不报错

我使用的版本是&#xff1a;4.0.6 引入到项目中后根据官方的配置教程进行配置&#xff1a; 但是页面上就是不显示&#xff0c;也不报错&#xff0c;看官网发现步骤也没问题 解决方法&#xff1a; 这句话代表的是uQrcode会被自动引用注册&#xff0c;但是你引过组件库或者别的…

QT treeWidget如何添加虚线

1、添加以下代码即可&#xff1a; ui.treeWidget->setStyle(QStyleFactory::create("windows"));2、效果如下&#xff1a;

基于 vue-element-template 框架添加 tagsview

1. 需求 vue-element-template 是一个基础模板&#xff0c;默认没有 tagsview。所以要手动添加。 参考最全面的集成方案框架 vue-element-admin &#xff0c;拷贝和修改相关文件到你的项目中。 2. 修改 复制如下文件或文件夹 \src\layout\components\TagsView\src\store\mo…