GLSL基础概念(绝对看得懂)

这篇具有很好参考价值的文章主要介绍了GLSL基础概念(绝对看得懂)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

简介

GLSL(OpenGL Shading Language)是一种用于描述顶点和片元着色器的语言。它是一种 C 语言的变体,专门为 OpenGL 和其他着色器渲染系统而设计。

在渲染图形时,主程序会将顶点数据发送到 GPU,然后 GPU 会使用图形着色器来计算每个像素的最终颜色。图形着色器的输入是顶点数据,输出是像素颜色。

着色器代码和主程序之间的关系就在于着色器代码是在GPU上执行的,主程序是在CPU上执行的。主程序会把数据传给着色器,例如顶点数据,着色器代码就能够处理这些数据,并将结果返回给主程序。

GLSL 着色器分为两类:

顶点着色器:处理图形中每个顶点的位置。
片元着色器:处理每个像素的颜色和透明度。
GLSL 着色器代码通常包含一个或多个函数,每个函数都有一个特定的输入和输出。例如,顶点着色器的主函数通常名为 main,它接受一个位置向量作为输入,并返回一个处理后的位置向量作为输出。

#version 330 core

in vec3 aPos;

void main()
{
  gl_Position = vec4(aPos, 1.0);
}

在这个例子中,我们定义了一个输入变量 aPos,它是一个三维向量。在函数体中,我们将 aPos 赋值给了内建变量 gl_Position。gl_Position 是一个四维向量(把它变成了齐次坐标,方便旋转平移缩放),它表示当前顶点的位置。
你可以使用 GLSL 编写自己的着色器代码,然后将其编译并附加到你的图形程序中。通常,你需要创建一个顶点着色器和一个片元着色器,然后将它们附加到一个图形程序中。例如,在 OpenGL 中,你可以使用以下代码来加载着色器(记得封装):

GLuint vertexShader = glCreateShader(GL_VERTEX_SHADER);
GLuint fragmentShader = glCreateShader(GL_FRAGMENT_SHADER);

// 加载着色器源代码
glShaderSource(vertexShader, 1, &vertexShaderSource, NULL);
glShaderSource(fragmentShader, 1, &fragmentShaderSource, NULL);

// 编译着色器
glCompileShader(vertexShader);
glCompileShader(fragmentShader);

// 创建图形程序
GLuint shaderProgram = glCreateProgram();

// 附加着色器到图形程序
glAttachShader(shaderProgram, vertexShader);
glAttachShader(shaderProgram, fragmentShader);

// 链接图形程序
glLinkProgram(shaderProgram);

// 删除着色器,因为它们已经附加到图形程序中
glDeleteShader(vertexShader);
glDeleteShader(fragmentShader);

如何在程序中使用 GLSL 着色器

首先,你需要在你的图形程序中设置顶点属性。例如,如果你的顶点着色器有一个名为 aPos 的输入变量,那么你就需要在你的程序中设置对应的顶点属性。你可以使用以下代码来设置顶点属性:

GLint posAttrib = glGetAttribLocation(shaderProgram, "aPos");
glVertexAttribPointer(posAttrib, 3, GL_FLOAT, GL_FALSE, 6 * sizeof(float), (void*)0);
glEnableVertexAttribArray(posAttrib);

在这个例子中,我们首先调用 glGetAttribLocation 函数来获取 aPos 变量的位置。然后,我们使用 glVertexAttribPointer 函数来设置顶点属性,并使用 glEnableVertexAttribArray 函数来启用顶点属性。
接着,你可以使用以下代码来使用你的着色器绘制图形:

glUseProgram(shaderProgram);
glDrawArrays(GL_TRIANGLES, 0, 3);

在这个例子中,我们首先调用 glUseProgram 函数来使用图形程序。然后,我们调用 glDrawArrays 函数来绘制。

更详细的着色器示例:

顶点着色器可能会类似于这样:

#version 330 core
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aColor;

out vec3 ourColor;

uniform mat4 model;
uniform mat4 view;
uniform mat4 projection;

void main()
{
    gl_Position = projection * view * model * vec4(aPos, 1.0);
    ourColor = aColor;
}

顶点着色器接受顶点属性 aPos 和 aColor,并将其转换为世界空间中的位置。gl_Position并不是out变量,因此直接输出,而out变量ourcolor的功能:将每个顶点的颜色从顶点着色器传递到片段着色器中

而片段着色器类似于下面这样:

#version 330 core
out vec4 FragColor;

in vec3 ourColor;

void main()
{
    FragColor = vec4(ourColor, 1.0);
}

片段着色器接受来自顶点着色器的颜色,并将其传递给输出颜色。这样,每个像素都会有一种颜色,并且图形就会显示出来。

主程序还可以使用变量和常量(称为 uniform 变量)来与着色器代码进行交互。例如,在上面的着色器代码中,主程序可以将 model, view, projection 的矩阵传递给顶点着色器以计算每个顶点的世界空间位置。

好,同学们加油文章来源地址https://www.toymoban.com/news/detail-428413.html

到了这里,关于GLSL基础概念(绝对看得懂)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【机器学习】什么是GAN 小孩都看得懂的 GAN

    以下内容来自:王圣元 王的机器 0   GAN 是什么 GAN 的全称是 Generative Adversarial Network,中文是 生成对抗网络 。 一言以蔽之,GAN 包含了两个神经网络, 生成器 (generator)和 辨别器 (discriminator),两者互相博弈不断变强,即生成器产出的东西越来越逼真,辨别器的识别能力

    2024年02月01日
    浏览(44)
  • 【可乐荐书】有趣的矩阵:看得懂又好看的线性代数

    本栏目将推荐一些经典的、有趣的、有启发性的书籍,这些书籍涵盖了各个领域,包括文学、历史、哲学、科学、技术等等。相信这些书籍不仅可以让你获得知识,还可以让你感受到阅读的乐趣和魅力。 今天给大家推荐的书籍是:《有趣的矩阵:看得懂又好看的线性代数》

    2024年02月05日
    浏览(54)
  • 看得懂的猪周期,牧原们却不一定跨得过

    2022年2月16日,全国各省三元猪均价为12.34元/公斤,较昨日下跌0.13元/公斤,较上周同期猪价(2月9日)下跌1.20元/公斤。 在供需关系的支配下,猪肉价格上涨,散户蜂拥而上,猪肉供给大增,肉价下跌,一个无解的循环就此形成。 猪周期,是一个典型的和面加水问题。在繁荣中

    2024年02月04日
    浏览(30)
  • verilog 从入门到看得懂---verilog 的基本语法数据和运算

            笔者之前主要是使用c语言和matab 进行编程,从2024年年初开始接触verilog,通过了一周的学习,基本上对verilog 的语法有了基本认知。总统来说,verilog 的语法还是很简单的,主要难点是verilog是并行运行,并且强烈和硬件实际电路相关,在设计到的时候需要考虑时序

    2024年03月18日
    浏览(47)
  • [免费专栏] Android安全之Android Xposed插件开发,小白都能看得懂的教程

    也许每个人出生的时候都以为这世界都是为他一个人而存在的,当他发现自己错的时候,他便开始长大 少走了弯路,也就错过了风景,无论如何,感谢经历 转移发布平台通知:将不再在CSDN博客发布新文章,敬请移步知识星球 感谢大家一直以来对我CSDN博客的关注和支持,但

    2024年02月09日
    浏览(41)
  • 想要成为 NLP 领域的大牛?从 ChatGPT 的 5 大自然语言模型开始了解吧(LM、Transformer、GPT、RLHF、LLM)——小白也能看得懂

      如果想在自然语言处理(Natural Language Processing,NLP)领域内脱颖而出,那么你一定不能错过 ChatGPT 的 5 大自然语言模型:LM、Transformer、GPT、RLHF 和 LLM。这些模型是 NLP 领域中最为重要的基础,涵盖了 语言模型、预训练模型、生成模型 等关键知识点。即使你是一个 NLP 小白

    2024年02月09日
    浏览(48)
  • Qt OpenGL(四十二)——Qt OpenGL 核心模式-GLSL(二)

    提示:本系列文章的索引目录在下面文章的链接里(点击下面可以跳转查看): Qt OpenGL 核心模式版本文章目录 冯一川注:GLSL其实也是不断迭代的,比如像3.3版本中,基本数据类型浮点型只支持float型,而GLSL4.0版本开始就有double型数据的支持了,所以本系列GLSL部分以GLSL4.5版

    2024年02月08日
    浏览(46)
  • OPENGL ES 2.0 知识串讲 (6)——GLSL 语法(IV)

    上面两节,主要讲解了 GLSL 中变量和函数的定义语法和使用语法,现在我们可以在 shader 中自定义一些我们所需要用到的变量和函数。但是在 shader 中, 还存在着一些内置的变量和函数。这些变量主要是用于将 Shader 计算得到的值传给 GPU,完成 Shader 在 Pipeline 中的功能。由于我们使

    2024年02月02日
    浏览(81)
  • MIPI简介(一)——基础概念介绍

    MIPI 全称Mobile Industry Processor Interface,即移动产业处理器接口。MIPI联盟在2003年由ARM, Nokia, ST ,TI等公司成立,成员包括手机设备制造商、半导体厂商、软件厂商、系统供应商、外围设备制造商、知识产权提供商、其他公司。联盟成立的目的是把手机内部的接口如摄像头、显示屏

    2024年02月09日
    浏览(35)
  • Android OpenGL ES 学习(一) -- 基本概念

    OpenGL 学习教程 Android OpenGL ES 学习(一) – 基本概念 Android OpenGL ES 学习(二) – 图形渲染管线和GLSL Android OpenGL ES 学习(三) – 绘制平面图形 Android OpenGL ES 学习(四) – 正交投屏 Android OpenGL ES 学习(五) – 渐变色 Android OpenGL ES 学习(六) – 使用 VBO、VAO 和 EBO/IBO 优化程序 Android OpenG

    2024年01月23日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包