最全计算机图形学面试资料整理

2023-05-16

计算机图形学面试资料整理

  • 1 什么是渲染管线
  • 2 有那几个坐标系(空间)?如何在空间之间进行转换?
  • 3 三个重要的空间变换矩阵
  • 4 视口变换是什么?
  • 5 顶点缓冲对象(Vertex Buffer Objects,VBO)
  • 6 顶点数组对象(Vertex Arrary Object,VAO)
  • 7 渲染管线的流程
  • 8 三种着色器有什么用?各完成了什么过程?
  • 9 什么是光栅化?
  • 10 OpenGL中有哪几种缓冲?都有什么用?
  • 11 为什么要用齐次坐标系
  • 12 片段和像素的区别?
  • 13 深度缓存算法(zbuffer算法)
  • 14 光照计算处理共有三个部分:
  • 15 反走样原理是什么?如何实现的
  • 16 为什么会有锯齿?抗锯齿怎么消除?
  • 17 为什么矩阵变化需要用4*4
  • 18 OpenGL渲染流水线怎样提高渲染效率?
  • 19 如何绘制一个三角形
  • 绘制半透明物体

1 什么是渲染管线

渲染管线又称渲染流水线,它是图形图像从数据一步一步形成最终输出的画面所要经历的各种操作过程。

2 有那几个坐标系(空间)?如何在空间之间进行转换?

物体坐标系(本地坐标系)Local Space 或 Model Space
世界坐标系 World Space
观察者坐标系(摄像机坐标系) View Space
裁剪空间 Clipping Space
屏幕空间 Screen Space
其中前四个矩阵之间,主要通过model, view, projection矩阵进行相关的变换, 裁剪空间到屏幕空间通过视口变换进行;前三个是三维空间,后面两个是二维空间。

3 三个重要的空间变换矩阵

  • MVP矩阵即模型矩阵,观察矩阵和投影矩阵,前两个矩阵都是由上面三种基础矩阵变换生成的。
  • Model matrix 模型矩阵。进行物体坐标系到世界坐标系的转换。控制了物体的平移、旋转、缩放。在3D建模软件中为模型坐标,导入游戏后使用model martrix进行大小、位置、角度的相关设置。
  • View matrix 观察矩阵。将世界坐标系变换到观察者坐标系,通过一些平移、旋转的组合来移动整个场景(而不是去移动摄像机,摄像机是一个虚拟的概念,事实上代码中并没有摄像机camera, 而是用view martix来表示摄像机,然后把view matrix附加到每一个物体,来模拟相关的摄像机操作),用来模拟一个摄像机。
  • projection matrix 投影矩阵。将观察者坐标系转换到裁剪坐标系。将3D坐标投影到2D屏幕上,裁剪空间外的顶点会被裁掉,投影矩阵指定了坐标的范围。

4 视口变换是什么?

视口变换发生在投影到2D屏幕后,将投影之后归一化的点映射到屏幕上指定的一块区域。在OpenGL中,是利用glViewPort函数来进行指定的。

5 顶点缓冲对象(Vertex Buffer Objects,VBO)

顶点缓冲对象VBO是在显卡存储空间中开辟出的一块内存缓存区,用于存储顶点的各类属性信息,如顶点坐标,顶点法向量,顶点颜色数据等。
在渲染时,可以直接从VBO中取出顶点的各类属性数据,由于VBO在显存而不是在内存中,不需要从CPU传输数据,处理效率更高。所以可以理解为VBO就是显存中的一个存储区域,可以保持大量的顶点属性信息。并且可以开辟很多个VBO,每个VBO在OpenGL中有它的唯一标识ID,这个ID对应着具体的VBO的显存地址,通过这个ID可以对特定的VBO内的数据进行存取操作。

6 顶点数组对象(Vertex Arrary Object,VAO)

VBO保存了一个模型的顶点属性信息,每次绘制模型之前需要绑定顶点的所有信息,当数据量很大时,重复这样的动作变得非常麻烦。VAO可以把这些所有的配置都存储在一个对象中,每次绘制模型时,只需要绑定这个VAO对象就可以了。
VAO是一个保存了所有顶点数据属性的状态结合,它存储了顶点数据的格式以及顶点数据所需的VBO对象的引用。VAO本身并没有存储顶点的相关属性数据,这些信息是存储在VBO中的,VAO相当于是对很多个VBO的引用,把一些VBO组合在一起作为一个对象统一管理。

7 渲染管线的流程

在这里插入图片描述

  • 顶点数据是一些顶点的集合,顶点一般是3维的点坐标组成。
    基本图元(Primitives)包括点,线段,三角形等,是构成实体模型的基本单位,需要在传入顶点数据的同时通知OpenGL这些顶点数据要组成的基本图元类型。
  • 顶点着色器(Vertex Shader)包含对一些顶点属性(数据)的基本处理。
  • 基本图元装配(Primitive Assembly)把所有输入的顶点数据作为输入,输出制定的基本图元。
  • 几何着色器(Geometry Shader)把基本图元形式的顶点的集合作为输入,可以通过产生新顶点构造出新的(或是其他的)基本图元来生成其他形状。
    - 图形,创建出更加平滑的视觉效果。
  • 光栅化(Rasterization)即像素化,把细分着色器输出的基本图形映射为屏幕上网格的像素点,生成供片段着色器处理的片段(Fragment),光栅化包含一个剪裁操作,会舍弃超出定义的视窗之外的像素。
  • 片段着色器(Fragment Shader)的主要作用是计算出每一个像素点最终的颜色,通常片段着色器会包含3D场景的一些额外的数据,如光线,阴影等。
  • 测试与混合是对每个像素点进行深度测试,Alpha测试等测试并进行颜色混合的操作,这些测试与混合操作决定了屏幕视窗上每个像素点最终的颜色以及透明度。
    在整个渲染管线中需要自定义处理的主要是顶点着色器和片段着色器。

8 三种着色器有什么用?各完成了什么过程?

  • 顶点着色器:计算顶点的位置,并将顶点投影在二维屏幕上。
  • 几何着色器:将形状(图元)划分为更多的形状(图元),影响后面的插值结果,例如可以将一个复杂的图形,转换为一个大规模旋转三角面片的组合图形,然后进行一个几何着色器的分片过程。
  • 片段着色器:根据顶点着色器和几何着色器输出的插值,计算每一个片元的颜色。之后进行测试和混合后生成最终的像素。

9 什么是光栅化?

光栅(栅格化或者像素化)把矢量图形转化成像素点儿的过程

10 OpenGL中有哪几种缓冲?都有什么用?

  • 帧缓冲 Frame Buffer, 用于创建零时的渲染上下文,帧缓冲是一些二维数组和OpenGL 所使用的存储区的结合:颜色缓存、深度缓存、模板缓存和累计缓存。默认情况下,OpenGL 将帧缓冲区作为渲染的最终目的地。此帧缓冲区完全有window系统生成和管理。这个默认的帧缓存被称作“window系统生成”(window-system-provided)的帧缓冲区。
  • 颜色缓冲 Color Buffer, 包含每个像素的颜色信息。颜色信息可以是颜色的索引(在颜色索引方式下),也可以是颜色的红、绿、蓝3个分量(在RGBA方式下),还可以存放表示物体透明程度的Alpha值。
  • 深度缓冲 Depth Buffer, 包含每个像素的深度值。深度值与z轴坐标有关,描述物体上某点距离观察点的远近,也可以称之为Z缓存(Z Buffer)。
    模板缓冲 Stencil Buffer, 包含物体的模板值。模板值具有屏蔽的作用,用于控制绘制的区域,使屏幕上某些区域可画,某些区域不可画。
  • 累计缓存 Accumulation Buffer 包含颜色信息,其可以合成一系列的挥之效果,实现某些特殊效果。
  • 顶点缓冲 Vertex Buffer , 用于缓存顶点数据
  • 元素缓冲 Element Buffer, 用于缓存顶点序号数据

11 为什么要用齐次坐标系

  • 方便进行平移变换
  • 能够简化透视投影的计算

12 片段和像素的区别?

  • 片段是渲染一个像素需要的全部信息,所有片段经过测试与混合后渲染成像素。
  • 片段是三维定点光栅化后的数据集合, 还没经过深度测试,而像素是片段经过深度测试、模板测试、alpha 混合之后的结果。
  • 片段的个数远远多于像素, 因为有的片段会在测试和混合阶段被丢弃, 无法被渲染成像素。

13 深度缓存算法(zbuffer算法)

需要一个空间保存每个像素的深度,绘制前初始化所有深度为无限远,绘制时当前片段如果比zbuffer中的值大(说明更远),则跳过此片段,保留原来的渲染结果;否则,绘制此片段,并更新zbuffer
可以处理对透明物体的消除

14 光照计算处理共有三个部分:

环境光
漫反射
镜面反射

15 反走样原理是什么?如何实现的

1.增加分辨率
2.先模糊后 采样
采样方法 例如将 增加采样数(一个像素点内)

16 为什么会有锯齿?抗锯齿怎么消除?

用有限离散的像素点去逼近连续的三角形,那么自然会出现这种锯齿走样的现象,因为这种近似是不准确的
抗锯齿方法
1.1 超采样反走样(Super Sampling AA)
SSAA的想法其实是非常直观的,如果有限离散像素点逼近结果不好,那么我们用更多的采样点去逼近不就会得到更好的结果了吗?所以根据这个思想我们可以把原来的每个像素点进行细分,比如下例中,我们讲每个像素点细分成了4个采样点
1.2 多采样反走样(Multi-Sampling AA)
MSAA其实是对SSAA的一个改进,显然SSAA的计算量是非常大的,每个像素点分成4个采样点,我们就要进行4次的shading来计算颜色,额外多了4倍的计算量,如何降低它呢?

MSAA的做法也很容易理解,我们依然同样会分采样点,但是只会去计算究竟有几个采样点会被三角形cover,计算颜色的时候只会利用像素中心坐标计算一次颜色(即所有的信息都会被插值到像素中心然后取计算颜色)

17 为什么矩阵变化需要用4*4

矩阵是用于表示变换而不是坐标
请添加图片描述

18 OpenGL渲染流水线怎样提高渲染效率?

尽量减少Draw Call。抛弃glBegin/glEnd这种立即模式,因为这个属于历史残留,画一个全屏矩形这种没什么问题,如果指望画许多三角形,那还是废了。从数据来说,优先使用VBO,其次是Client模式,最后还是立即模式。

19 如何绘制一个三角形

//需要使用的库
#include "GLShaderManager.h" // 着色器管理器
#include "GLTools.h"
#include <GLUT/GLUT.h>
//首先定义 着色器管理类、三角形批次容器
GLShaderManager shaderManager;
GLBatch triangleBatch;
//到main函数里面进行一系列初始化,然后注册函数
//初始化GLUT库,这个函数只是传说命令参数并且初始化glut库  
 glutInit(&argc, argv);
glutInitDisplayMode(GLUT_DOUBLE|GLUT_RGBA|GLUT_DEPTH|GLUT_STENCIL);     
    //GLUT窗口大小、窗口标题    
glutInitWindowSize(800, 600);    
glutCreateWindow("Triangle");
  //注册重塑函数
   glutReshapeFunc(changeSize);
    //注册显示函数
    glutDisplayFunc(RenderScene);
//设置渲染环境
    setupRC();
//开启事件循环
    glutMainLoop();
//在setupRC里面初始化着色器,设置顶点数据
//设置清屏颜色(背景颜色)
    glClearColor(0.98f, 0.40f, 0.7f, 1);
    shaderManager.InitializeStockShaders();
//指定顶点
    GLfloat vVerts[] = {
        -0.5f,0.0f,0.0f,
        0.5f,0.0f,0.0f,
        0.0f,0.5f,0.0f
    };
    triangleBatch.Begin(GL_TRIANGLES, 3);
    triangleBatch.CopyVertexData3f(vVerts);
    triangleBatch.End();
//在changeSize设置视口大小(在初始化窗口和窗口大小发生改变时调用)
void changeSize(int w,int h) {
//接收新的宽度&高度。
glViewport(0, 0, w, h);
}
//在渲染是调用RenderScene
//1.清除一个或者一组特定的缓存区
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT|GL_STENCIL_BUFFER_BIT);
//2.设置一组浮点数来表示红色
    GLfloat vRed[] = {1.0,0.0,0.0,1.0f};
//传递到存储着色器
    shaderManager.UseStockShader(GLT_SHADER_IDENTITY,vRed);
//提交着色器
    triangleBatch.Draw();
//将后台缓冲区进行渲染,然后结束后交换给前台
    glutSwapBuffers();

绘制半透明物体

  1. 先绘制所有不透明的物体,将深度设为只读。
  2. 对所有透明的物体排序。
  3. 按顺序绘制所有透明的物体,将深度设置为可读可写。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

最全计算机图形学面试资料整理 的相关文章

  • 指针传参的深入思考

    对指针传参的深入思考 xff0c 很重要的一点还是需要看指针是否指向新的地址 1 如果指向新的空间 xff0c 那么对形参处理后不会影响实参 xff0c 即参数没有传回 xff0c 因为实参的指针地址和形参指针的地址不同 xff0c 对不同
  • 建立二叉树

    一颗二叉树 创建结点 typedef struct node int data node lchild node rchild node lchild NULL rchild NULL Tree tree 建树 tree bulid tre
  • 学习STL的历程——关联容器

    STL模板库包括了容器 算法 迭代器 仿函数 适配器 分配器 主要谈谈容器 STL中的容器有序列容器和关联容器 xff0c 容器适配器等 1 xff09 序列容器 xff08 以线性序列的方式存储元素 xff0c 没对元素进行排序 xff0
  • STL三角网格模型体积计算

    float STLVolume float vols 61 0 for int i 61 0 i lt Tmesh gt faces size i 43 43 vec p1 61 Tmesh gt vertices Tmesh gt fac
  • Abaqus齿轮有限元分析

    齿轮啮合模拟 整理好的文件放在资源里了 xff0c 直接解压即可齿轮有限元分析 保姆级步骤如下 xff08 废话少说直接看图片设置 xff09 xff1a 首先先对齿轮模型划分网格 xff0c 该分析所用的前处理软件为Hypermesh x
  • const成员函数

    const成员函数 const修饰的类成员函数称为const成员函数 xff0c const修饰类成员函数 xff0c 实际修饰该成员函数隐含的this指针 xff0c 表明在该成员函数中不能对类的任何成员进行修改 如下图所示 xff1a
  • 设计模式——单例模式

    为什么单例模式中的成员函数都是静态的 xff1f 你只要弄明白单例模式是如何实现的 xff0c 就能从本质上理解这个问题 xff1b 单例模式实现过程如下 xff1a 首先 xff0c 将该类的构造函数私有化 xff08 目的是禁止其他程序
  • c/c++链表学习

    链表学习持续更新 这边设置链表的节点 xff0c 里面包含两个信息分别是数据域 xff08 可以用自己写的类或者基本数据结构 xff0c 为了简便这边直接使用基本数据类型 xff09 和指向下一节点的指针 struct SeqList in
  • c++面试知识整理

    C 43 43 基础部分 1 基础知识1 1 内存1 1 0 内存四区1 1 1 简述C C 43 43 程序编译的内存分配情况1 1 2 分配函数与释放函数 1 2 预编译1 2 1 头文件 lt gt lt gt
  • Windows中使用Netsh Winsock Reset命令解决网络连接问题

    有人反馈电脑无法联网 xff0c Chrome IE TIM等无法正常使用 xff0c 我检查后发现了以下情况 xff1a 1 电脑网络适配器设置处显示网络连接正常 xff0c 并且正确获取到了内网域的名称 xff1b 网络的IP 掩码 D
  • 深浅拷贝问题

    深浅拷贝 指针释放两次深浅拷贝补充解决方法 指针释放两次 再讲深浅拷贝之前先谈一谈如果对开辟内存的指针同时释放两次会发生什么情况 span class token keyword int span span class token oper
  • STL模型渲染

    渲染 xff08 render xff09 STL模型渲染 齿轮 龙 通过离线渲染获得的模型和场景
  • 树的一些题目持续整理

    树 树的最大深度合并二叉树 树的最大深度 输入一棵二叉树的根节点 xff0c 求该树的深度 从根节点到叶节点依次经过的节点 xff08 含根 叶节点 xff09 形成树的一条路径 xff0c 最长路径的长度为树的深度 span class
  • C++四种强制转换

    c 43 43 类型转换 1 static cast 静态类型转换 2 dynamic cast 动态类型转换 3 const cast xff08 去const属性 xff09 4 reinterpret cast 不相关类型的转换 1
  • TCP/IP基础知识

    TCP IP OSI七层模型 Open System Interconnect 数据链路层网络层TCP UDPDNSTCP连接的建立与终止三次握手为什么要三次握手 xff1f 四次挥手为什么要四次挥手 xff1f OSI七层模型 Open
  • 材料力学的一些东西

    力学属性 强度刚度弹性模量柔度韧性脆性 强度 强度是指表示工程材料抵抗断裂和过度变形的力学性能之一 常用的强度性能指标有拉伸强度和屈服强度 xff08 或屈服点 xff09 铸铁 无机材料没有屈服现象 xff0c 故只用拉伸强度来衡量其强度
  • 操作符重载一些细节

    操作符重载一些注意事项 不能重载操作符只在类的成员函数中重载的操作符只在友元函数中重载的操作符补充 不能重载操作符 34 34 xff08 类成员访问运算符 xff09 34 34 xff08 类成员指针访问运算符 xff09 34 34
  • 容器学习历程——容器适配器

    容器适配器 stack 栈 xff09 queue 队列 xff09 priority queue 优先队列 xff09 stack 栈 xff09 FILO 先进后出 xff09 底层通过deque实现 span class token
  • 坐标位置实时显示

    MFC程序实时显示鼠标坐标位置 在MFC单文档中快速实现坐标点附上代码 xff1a span class token keyword void span span class token class name CVoronoi2View s

随机推荐

  • ABAQUS自定义载荷分布

    ABAQUS自定义载荷分布 用abaqus进行模拟足底压力时遇到了一个问题 xff0c 足底压力传感器测出来的数据每块区域的数值都不同 xff0c 如果对每块区域都一个个选中然后赋值那效率太低太低了 xff0c 若是直接选中某块区域 xff
  • 域控之DNS转发器

    系统环境 xff1a Windows Server 2012 R2 Datacenter 现象 xff1a 将域环境中的主机的DNS服务器地址指向网关时 xff0c 访问外网正常 xff1b 将DNS服务器地址指向指向域控后 xff0c 可
  • cmd 运行main函数

    C m a k e Cmake C m a k e 文件大多数由控制台程序运行 xff0c 由于
  • 入栈,出栈顺序

    入栈 xff0c 出栈顺序 在刚开始做到栈的出栈入栈时还是蛮有疑惑的 xff0c 搞不清楚出入栈的排序重新整理之后终于明白 xff0c 具体如下所示 xff1a 例如有一个为 A B C D E
  • MFC键盘交互

    MFC键盘交互 首先设置键盘按键消息响应 span class token keyword void span span class token class name CFeatureReuseView span span class to
  • 手撕字符串函数

    实现 s t r c p y strcpy s t r c p y 函数 span class token key span
  • 牛客编程输入输出

    牛客笔试编程输入输出 首先需要把该包含的头文件包含进来 结构类型类似于 span class token macro property span class token directive hash span span class toke
  • VS检查内存泄露的方法

    Visual Studio检查内存泄露方法 CrtDumpMemoryLeaks函数Visual Leak Detector xff08 VLD xff09 插件VS2015内存快照 CrtDumpMemoryLeaks函数 系统自带的 C
  • 计算机图形学中的渲染管线

    渲染管线 具体流程图顶点着色器光栅化片段着色器测试混合阶段 具体流程图 步骤 xff1a 1 首先输入了1 xff0c 2 xff0c 3 xff0c 4四个顶点的数据 2 Vertex Processing 经过变换 投影等操作 xff0
  • 计算机图形学中的几何

    计算机图形学中的几何 几何表示方法1 显示表示1 1 显示几何 Explicit Representations 2 隐式表示 几何表示方法 1 显示表示 理解为能够通过参数映射的方法来定义几何形状 xff0c 可以很轻易的采样到所有的点
  • 计算机图形学中的曲线曲面

    计算机图形学中的曲线曲面 1 曲线1 1 Bezier curves xff08 贝塞尔曲线 xff09 1 2 B spline B样条 1 3 NURBS 非均匀有理B样条 xff09 2 曲面2 1 Bezier Surfaces x
  • Docker停电事件未解之谜

    事件简介 xff1a 周末出现了一次偶然的停电事故 xff0c 供电恢复后 xff0c 按照惯例重启服务器 xff0c 并重新运行各项服务 然而 xff0c 一台Ubuntu 16 04服务器的Docker容器无法启动了 1 启动容器报错
  • 布尔运算(Boolean Operators)

    布尔操作 xff08 Boolean Operators xff09 1 构造实体几何 CSG 2 布尔操作类型3 布尔操作部分代码 1 构造实体几何 CSG 构造实体几何允许建模者通过使用布尔运算符组合更简单的对象来创建复杂的曲面或对象
  • 八叉树的相关内容

    根据点云数据构建八叉树 span class token macro property span class token directive hash span span class token directive keyword prag
  • VS+git+CMake实现代码运行

    git 43 CMake实现代码运行 1 获取 github 仓库中的代码2 CMake 基本步骤3 CMake 遇到问题1 没提供xxx cmake 在路径中 4 ALL BUILD ZERO CHECK INSTALL 1 获取 git
  • CPU和GPU及CUDA入门基础概念

    CPU与GPU 1 CPU与GPU的关系 smile 1 1 CPU与GPU各自特点 2 一些零碎的CUDA入门知识 blush 2 1 函数修饰符2 2 线程 线程快 线程格2 3 什么是核函数 smiley 2 4 常用的GPU内存函数
  • 原始三维格子点内部实现小范围格子重建

    在原始N M的数组A中 xff08 该数组可以理解为规则格子 xff0c 各维度的增量均为常数 xff09 内部构建一个比其小的数组B xff0c 要求数组B与A格子点重合 xff0c 如图所示 xff1a 对于三维空间的数组来讲 xff0
  • csdn Markdown样式

    CSDN markdown样式 1 文字样式2 段落格式3 图片样式4 公式样式5 分享一些表情 1 文字样式 x1f449 字体样式 span class token operator lt span font span class to
  • Java入门基础知识

    JAVA基础知识记录 1 基础内容2 相关知识链接 写在最前面 xff1a 之前自学Java用的是 Eclipse 1 基础内容 常量 final相当于c 43 43 中的const 数组 int number 61 new int 100
  • 最全计算机图形学面试资料整理

    计算机图形学面试资料整理 1 什么是渲染管线2 有那几个坐标系 xff08 空间 xff09 xff1f 如何在空间之间进行转换 xff1f 3 三个重要的空间变换矩阵4 视口变换是什么 xff1f 5 顶点缓冲对象 xff08 Verte