50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

通过 OpenGL 理解前端渲染原理(1)

  • 2020-02-11
  • 本文字数:1657 字

    阅读完需:约 5 分钟

通过OpenGL理解前端渲染原理(1)

一、OpenGL

OpenGL,是一套绘制 3D 图形的 API,当然它也可以用来绘制 2D 的物体。OpenGL 有一大套可以用来操作模型和图片的函数,通常编写 OpenGL 库的人是显卡的制造者。我们买的显卡都支持特定版本的 OpenGL。


下图是用 OpenGL 做的旋转的立方体。


1554890391091076623.png

二、渲染原理

渲染管道

在 OpenGL 中,所有东西都在一个 3D 的空间里,而我们的屏幕和窗口都是 2D 的,所以 OpenGL 需要将 3D 的坐标转换成 2D 的坐标,做这件事的是 OpenGL 中的渲染管道(graphics pipeline)。


渲染管道可以分成两大部分:第一部分将 3D 坐标转换成 2D 坐标;第二部分把 2D 的坐标转换成实际的像素。

着色器

通常来说,渲染管道把一组 3D 坐标转换成屏幕上带有颜色的 2D 像素需要经过很多步。上一步的输出作为下一步的输入,所有步骤都是高度专一的,每步都有一个特定的函数,且可以很容易地并发执行。显卡有数千个处理核心来快速处理渲染管道中的数据,而这些是在每个步骤中通过运行在 GPU 上的多个小程序来处理的,这些小的程序被称之为程序着色器(shader)。


其中的一些着色器是可以配置的,开发者可以根据需求配置自己的着色器去替代已经存在的那些,这就让我们能够更自由和细粒度地控制渲染的过程。同时,因为它们运行在 GPU 上,又给我们保留了珍贵的 GPU 时间,在平时的开发中,我们也要充分利用 GPU 渲染来提高软件性能。


着色器通常使用 GLSL 来写,全称是 OpenGL Shading Language。

举个例子

下图展示了一个抽象的渲染管线中的步骤,其中蓝色部分是我们可以注入自己的着色器。


1554890403444014526.png


通过上图我们发现,要把顶点数据转换成全渲染的像素要经过很多步,接下来我们对每一个步骤和代码进行简单的解释。


我们在渲染管线中传入一组可以组成三角形的 3D 坐标数据,这组数据即顶点数据。顶点数据是顶点的集合,而一个顶点是一个 3D 坐标的集合。


渲染管线的第一步是顶点着色器(Vertex Shader)。我们这里传入的是一个简单的顶点,顶点着色器可以让我们做一些基础的处理操作,比如顶点的属性。


在初始装配阶段,也就是 Shape Assembly 阶段,从顶点着色器中输出的顶点会形成一个原始的形状。本例中,输出的顶点形成的是一个三角形。


从初始装配阶段到 geometry shader 阶段,我们可以通过发散其他顶点来形成新的图形,本例中形成了第二个三角形。


在 Tessellation Shader 阶段,可以把上一阶段给出的原型图再分割成若干个小的原型图。本例中,可以形成更多的三角形来创造一个更加平坦、顺滑的环境。这么说可能难以理解,我们结合下图来进一步阐述,这就是细分曲面着色器的作用。


细分曲面着色器的下一阶段是光栅化阶段(Rasterzation stage),在这一阶段会对最终的原型和呈现在屏幕上的对应像素做一个映射,形成 fragment,供下一阶段的 fragment shader 使用。


1554890428321016503.png


Fragment shader 最主要的使命是计算出一个像素的最终颜色,在这个阶段我们可以使用 OpenGL 中一些高级的特效。通常 fragment shader 会包含 3D 界面的多个数据,包括灯光、阴影、颜色等等。


当所有对应的颜色都确定以后,最终的原型将会被传入最后一个步骤,我们称之为 Alpha test and blending 阶段。这个阶段会判断相应的深度,比如一个物体可能在另一个物体的后面,那它可能采用其他的颜色;或者如果该物体被遮挡,可能会被裁掉。


如上文所述,我们可以看到整个渲染管线的步骤和逻辑是十分复杂的,这其中包含了很多个可以改变的步骤,但我们一般只操作 Vertex Shader 和 fragment shader,其他的着色器我们会直接采用默认的。在实际的 OpenGL 编程中,我们至少需要定义一个 Vertex Shader 和 Fragment shader。(需要说明的是,OpenGL 3.1 之前的版本包含了固定管线,从 3.1 版本开始,固定管线从核心中删掉了,因此我们必须使用着色器去工作)。

三、总结

本文为该系列文章的第一篇,先简单介绍 OpenGL 的一些原理,后续文章中会添加新的代码分析,包括着色器(Shader)、纹理(Textture)、变形(transformation)、坐标系统(Coordinate systems)、相机(Camera)等。


本文转载自宜信技术学院网站。


原文链接:http://college.creditease.cn/detail/232


2020-02-11 20:232339

评论

发布
暂无评论
发现更多内容

视频下载出来为网页格式?如何将视频转换为mp4格式?

Rose

视频格式转换 Mac视频格式转换 视频下载出来为网页

MobTech 秒验|防控羊毛党

MobTech袤博科技

龙蜥白皮书精选:面向异构计算的加速器 SDK

OpenAnolis小助手

开源 sdk 异构计算 加速器 龙蜥白皮书

最全金融数据安全政策汇编,你应该需要它!( 附下载 )

极盾科技

数据安全

mac电脑能恢复安卓手机丢失的数据吗?

Rose

mac电脑 安卓数据恢复

MobTech MobLink|场景分享的原理

MobTech袤博科技

Linux 的 TCP 连接数量最大不能超过 65535?

Java你猿哥

Java Linux 后端 ssm

灵魂拷问:你写的SQL一般有几个JOIN ?​

Java你猿哥

Java sql 后端 ssm join

面试必问:JVM 如何确定死亡对象?

Java 面试 JVM

官方文档 | 【JVM调优体系】「GC底层调优实战」XPocket为终结性能问题而生—开发指南

码界西柚

Java JVM 3月日更 XPocket 技术 优化体系

在GitHub首页3分钟被下架!爱奇艺《高并发网关设计》笔记被盗?

Java 负载均衡 高并发 网关设计

DaVinci Resolve Studio 18(达芬奇调色剪辑)中文版

Rose

达芬奇18破解版

GitHub上架即巅峰!《Spring Cloud微服务架构实战》标星已超30k

Java 架构 微服务 Spring Cloud

解密COUNT(*)与COUNT(1):SQL查询你选哪个更高效?

Java你猿哥

Java sql 后端 ssm Java工程师

苹果发布macOS Ventura 13.3正式版更新

Rose

mac系统 苹果最新系统 macOS Ventura 13.3

开源即巅峰!《Java程序性能优化实战》GitHub三小时标星已超34k

Java 性能优化 性能调优

如何使用责任链默认优雅地进行参数校验?

Alibaba官方上线!Java并发编程全彩图册(终极版)GitHub已置顶

Java 并发编程 多线程 高并发

基础篇丨链路追踪(Tracing)其实很简单

阿里巴巴云原生

阿里云 云原生 Tracing

Mac版cad2024发布 AutoCAD 2024 注册机

Rose

Mac软件 cad cad2024激活版 Autodesk AutoCAD

阿里P7架构师的独家分享——SpringCloud 微服务实战笔记

Java你猿哥

Java 架构 微服务 Spring Boot 面经

一文告诉你如何一键复现“TSBS 时序数据库性能基准测试报告”测试结果

TDengine

tdengine 性能测试 时序数据库

夜莺n9e监控配置支持电话短信报警

外滩运维专家

夜莺监控 电话报警 短信报警 夜莺监控电话

互联网工程师1480道Java面试题及答案整理( 2023年 整理版)

Java你猿哥

Java 面试 面经 春招 Java八股文

IM跨平台技术学习(七):得物基于Electron开发客服IM桌面端的技术实践

JackJiang

即时通讯 即时通讯IM

Nautilus Chain 首个生态基础设施 Poseiswap,公布空投规则

鳄鱼视界

Github上获赞59.8K的面试神技—1658页《Java面试突击核心讲》

Java你猿哥

Java 架构 面试 面经 春招

玩转 ChatGPT+极狐GitLab|分分钟丝滑迁移Jenkins到极狐GitLab CI

极狐GitLab

ci DevOps jenkins CI/CD 极狐GitLab

警惕看不见的重试机制:为什么使用RPC必须考虑幂等性

连接 AI,NebulaGraph Python ORM 项目 Carina 简化 Web 开发

NebulaGraph

Python ORM 图数据库

通过OpenGL理解前端渲染原理(1)_文化 & 方法_崔晓迪_InfoQ精选文章