计算机图形学知识点汇总

embedded/2024/12/29 13:09:57/

一、计算机图形学定义与内容

1.图形 

        图形分为“图”和“形”两部分。

        其中,“形”指形体或形状,存在于客观世界和虚拟世界,它的本质是“表示”;而图则是包含几何信息与属性信息的点、线等基本图元构成的画面,用于表达“形”,是“形”的视觉表现,它的本质是“表现”

        “图”和“形”的关系是:“形”是“图”之源,是“图”之根本,是“图”的基础;“图”是“形”的载体,是“形”的表现

        综合理解,图形就是变现物体几何信息图画

        计算机图形学中的图形对象通常由点、变、面、环、体等基本几何元素构成。

        字符图形常见有两种表示方法,分别是矢量字符点阵字符

        描述图形数据要包括两部分,一部分是几何信息,另一部分是拓扑信息

        “图形”作为计算机图形学的基本研究内容,其表示形式通常有两种,其中更节约内存的表示形式是参数表示法

2.图像

        从广义上说,图像是对自然界的客观事物反映,也是一个不断发展的概念。

        从本质上来说,图像是记录在介质上客观对象的映像。对于计算机这种介质而言,它就是数字图像,如计算机显示器商所显示的就是数字图像,它室友像素组成的矩阵光栅来显示不同的图图像,其中每一个像素具有不同的颜色信息。

        屏幕上最小的显示单元叫做像素,它的多少叫做分辨率

3.图形、图像对比

        基本元素:图形:点、线、面等几何元素;

                          图像:像素。

        存储数据:图形:各个矢量的参数(属性);

                          图像:各个像素的灰度或颜色分量。

        处理方式:图形:旋转、扭曲、拉伸等;

                          图像:对比度增强、边缘检测等。

        缩放结果:图形:不会失真,可以适应不同的分辨率;

                          图像:放大时会失真,可以看到颗粒状像素。

        其他:图形:不是客观存在的,是根据客观事物而主观形成的;

                   图像:对客观事物的真实描述。

        图形和图像的实质是矢量图点位图的关系。

        

4.计算机图形学的定义

        国际标准化组织将其定义为:计算机图形学是研究通过计算机将数据转换成图形,并在专门显示设备上显示的原理、方法和技术的学科。

        国内常见的定义如下:计算机图形学是利用计算机研究图形的表示、生成、处理和显示的学科;计算机图形学是研究在计算机中如何构建图形,并把图形的描述数据(数学模型)通过指定的算法转化成图形显示的一门学科。

        计算机图形学的主要内容包括两方面:(1)将场景对象转换为图形(2)将转换后的图形显示出来。

5.图形学相关学科

        数据可视化、数字图像处理、机器视觉、计算几何、计算机辅助几何设计等。

        与计算机图形学的研究内容形成互逆关系的学科是图像处理

        属于计算机图形学相关学科的是:计算几何、图像处理、计算机视觉,不属于的是:人工智能。

6.计算机图形学的应用领域

        (1)计算机辅助设计与制造

        (2)科学计算可视化

        (3)虚拟现实

        (4)动画

7.计算机图形学发展简史

        (1)计算机图形学的诞生(1950--1960年)

        (2)线框图形(1960--1970年)

        伊凡.萨瑟兰(lvan E.Sutherland)首次在论文中提出了“计算机图形学”感念,确定了计算机图形学作为一个独立科学分支的地位。

        (3)光栅图形学(1970--1980年)

        (4)真实感图形学(1980--1990年)

        (5)实时图形学(1990年至今)

二、图形系统

1.图形系统组成

图形软件:(1)图形应用软件:二维--AutoCAD、Illustrator;三维--Maya、3ds Max。

                  (2)图形支撑软件:功能子程序、基本子程序、图形设备驱动程序。(OpenGL、WebGL、DirectX、java2D、java3D)

                  (3)图形应用数据结构:图形数据文件、图形基元模型、几何描述数据。

        常用的图形库OpenGL,属于图形系统的图形支撑软件部分。

        OpenGL是一个跨平台的图形API,广泛用于2D和3D图形渲染,支持Windows、Linux、macOS等操作系统。

        在OpenGL中,glPushMatrix()和glPopMatrix()用于保存和恢复当前的距阵状态。

图形硬件:(1)图形输入设备。

                  (2)图形处理设备:中央处理器CPU、图形处理器GPU。

                  (3)图形输出设备:图形显示设备、图形绘制设备。

        在计算机图形系统中,负责捕捉用户输入的硬件设备是鼠标和键盘

        触摸屏是输入输出设备。

        图形程序 = 图形算法 + 图形应用数据结构

    

2.图形显示方式

        (1)随机扫描显示

        (2)光栅扫描显示

        计算机图形显示器一般使用RGB颜色模型。

        计算机绘制设备一般使用CMY颜色模型。

3.图形流水线三阶段

        应用程序阶段-----几何处理阶段-----光栅阶段(像素处理)

        图像显示与图形复杂度相关不是光栅扫描显示器的特征,画点设备、存在锯齿现象、支持真实感图形显示是光栅扫描显示器的特征。

        图形流水线的光栅化阶段的主要任务为生成最终图像的像素

4.图形流水线关键步骤

顶点----->几何处理器----->光栅化器----->片元处理器----->帧缓存----->显示

GLSL的全称(英文表达)是:OpenGL shading Language

ODBC不属于图形标准,PHIGS、OpenGL、GKS属于图形标准。

GKS是计算机图形官方标准。

三、二维基本图形光栅化与裁剪

1.数值微分算法(DDA)

        算法思想:求出斜率k,每次在x和y上,分别加上成比例的小增量xn和yn得到下一个点。

        该方法在精度无限高的情况下,可以生成精确无误的直线,但由于光栅显示器栅格的问题,导致xn和yn每次只能取单位步长。

        当k小于1时,直线在x轴上增速快,直线的下一个点取值:x1=x+1;y1=y+k。y点坐标求出小数,四舍五入,注意计算下个点y2时应:y2=y1+k。

        平面中有一条直线段,起点P1(0,0),终点P2(5,2),利用DDA算法扫描转换该直线,如果当前点亮的像素点(2,1),则下一次点亮的像素点是( 3,1)。

2.Bresenham画线法

        算法思想:直线的斜截式y=kx+b,以直线划分,F(x,y)>0点在直线上方,F(x,y)=0点在直线上,F(x,y)<0点在直线下方。

        假定0<=k<=1,x是最大位移方向,如下图,M为Pu和Pd的中点,M为直线与Pu和Pd间网格的交点,Q>M,取Pu,Q<M,取Pd。

计算方法:

例题:

 

 Bresenham画圆算法

        Bresenham画圆算法适合于生成整圆,他利用对称性,只计算出90~45度内的点,移动方向为+x,-y。

3. 中点画线算法

        和Bresenham画线算法类似,但判别规则略有不同,绘制效率完全不同。

在0<k<1情况下:

(1)起点(x0,y0)终点(xn,yn)

(2)d0=(xn-x0)- 2(yn-y1);d<0时,d=d+2(xn-x1)-2(yn-y1);d>=0时,d=d-2(yn-y1)

中点画圆法与Bresenham画圆法类似。

在直线光栅化过程中,当直线的斜率大于1时,增量变化较大的方向是Y方向

3. 多边形扫描算法

(1)求交点:计算当前扫描线与多边形所有变得交点。

(2)排序与配对:把所有交点按x值递增顺序排序,排序后的交点两两配成区间。

(3)填色:将各区内的像素值设置为目标颜色值。

另一顶点的xy(max)1/knext

例题:

        多边形扫描线填充算法四个步骤中,保证填充无误的关键步骤是交点配对 。

        多边形扫描算法为了提高算法效率,引进了一套数据结构,如活性边表,新边表等。

        x扫描线算法中的几个主要步骤的正确顺序是求交--排序--配对--填色,那么其中比较耗费时间且能优化的运算是:求交--排序

4.种子填充算法

        种子填充算法从一个给定的 “种子点”(通常位于要填充区域的内部)开始,然后按照四联通(上、下、左、有)或八联通(上、上左、上右、下、下左、下右、左、右)规则将颜色扩展到整个区域。

实现步骤:

        (1)初始化,向堆栈压入种子点像素,当堆栈不为空时,重复执行以下步。

        (2)从包含种子像素的堆栈中推出区段内的种子像素。

        (3)沿着扫描线,对种子像素的左右像素进行填充,直至遇到边界像素为止。

        (4)区段内最左和最右像素记为xl和xr,在此区间内,检查与当前扫描线相邻的上下两条扫描线是否全为边界像素或已被填充过。

        (5)如果经测试,这些扫描线上的像素段需要填充,则在xl和xr区检范围内,把每一段的最右像素作为种子像素,并压入堆栈。

        四联通区域内的每一像素可以通过上下左右四个方向组合到达。

5.反走样技术

(1)提高分辨率

(2)简单区域采样

(3)加权区域采样

反走样技术的主要目的为减少图形中的锯齿现象

不能获得反走样效果的是:增强图像的显示亮度

6.Cohen-Sutherland编码裁剪算法

        将窗口分为九个区域,每个区域编号如下图,四个数字按照上、下、左、右顺序表示。

        取直线端点,按位与,判断直线“取之”或“弃之”。

        Cohen-Sutherland直线段裁剪算法中,按照(上下右左)给出四位编码,若线段起点编码为(1001),终点编码为(0101),则该线段属于弃之情况。

        三维Cohen-Surtherland裁剪算法中直线端点编码需要的位数是6

        

7.Liang-Barsky参数化裁剪算法

         Liang-Barsky算法的思想是把被裁剪的线段看成是有向线段。

8.多边形裁剪

        多边形裁剪不能简单地用直线裁剪算法对多边形各边进行裁剪来实现。

        主要解决两个问题:(1)一个封闭的多边形被裁剪后通常变得不再封闭,需要用窗口边界的适当部分来封闭。

(2)一个凹多边形被裁剪后可能形成几个小多边形,要正确封闭他们。

        将多边形外部一点A与某一点B用线段连接,若此线段与多边形边界相交的次数为偶数,则点B在多边形外部,若此线段与多边形边界相交的次数为奇数,则点B在多边形内部。

         任意的简单多面体,其面(F)、边(E)、顶点(V)的数目需满足的公式为:V+F-E=2

四、图形几何变换

1.其次坐标

        在图形变换中引入齐次坐标的目的是:统一表示几种变换,便于计算

二维几何的基本变换矩阵:

例题: 

        错切:是一种使对象形状发生变化的变换,经过错切的对象好像是由相互滑动的内部夹层组成。错切变换可通过旋转和缩放变换组合得到。 

        二维几何变换的基本类型包括平移、旋转、缩放、对称和错切

错切变换:可能引起图形角度改变,可能会发生图形畸变。

平移变换:不改变图形大小和形状,只改变图形位置。

旋转变换:各图形部分间的线性关系和角度关系不变,直线的长度不变。

比例变换:不改变图形的连接关系和平行关系。

2.逆变换

(1)逆平移变换

(2)逆旋转变换

(3)逆缩放变换

        齐次坐标的特点:用n+1维向量表示一个n维向量;将图形变换统一为图形的坐标矩阵与某一变换矩阵项城的形式;易于表示无穷远点。不是齐次坐标特点:一个n维向量的齐次坐标表示是唯一的。

        三维空间点p(x,y,z)的规范化齐次坐标表示为(x,y,z,1)。

二维坐标变换、二维坐标系变换、三维几何变换、三维符合变换、三维坐标系变换,不展开说了。

五、三维观察

流程:模型坐标--->世界坐标--->观察坐标--->投影坐标--->屏幕坐标

        一般情况下,片元着色器是进行模型变换、视图变换等工作的着色器。

(1)模型变换:模型坐标系(局部坐标系)中构建的物体放到统一的世界坐标系(全局坐标系)的过程中,跟据场景的需要所进行的组合变换。

(2)观察变换:在世界坐标系中设定了观察坐标系后,物体从世界坐标系下世界坐标到观察坐标系下观察坐标的变换,也称试点变换或视图变换。

(3)投影变换:在观察坐标系中设定投影平面(观察平面)和投影最欧标系后,将三维物体的观察坐标通过投影的方式变换为投影坐标系下投影坐标的过程。

(4)视口变换:从投影坐标系中的观察窗口到设备设备坐标系中某个指定视区的变换。

        窗口到视区的映射是一个“保持比例”的映射。

        会产生变换前后维度改变的是:投影变换;不会变换的是:建模变换、观察变换、视口变换。

        在三维观察流程中,视图变换的主要目的是将物体从世界坐标系转换到观察坐标系

        三维观察流程中,坐标变换的正确次序应为:观察变换--->投影变换--->视口变换

        物体经过透视投影后可产生缩小的效果。

        透视投影比平行投影更富有立体感和真实感。

        太阳光线产生的投影为平行投影。

        投影变换可分为平行投影透视投影两大类。

        透视投影中,主灭点的个数最多有3

        

六、三维造型

1.计算机表示方法

(1)多边形网格表示:将物体表面看成由多边形网格拼接而成。

(2)曲线/曲面表示:曲面和曲线方程能表示为非参数形式或参数形式。

        刻画曲线扭曲程度的参数是挠率。

        在曲线、曲面的方程表示上,参数方程比显式、隐式方程有更多的优越性。

        参数方程又分为代数和几何两种形式。 

(3)细分表示:通过一些基本的空间元素来表示对象,主要包括体素表示法、八叉树表示法等。

         在规则造型技术中,八叉树是一种经典的技术,它属于空间分割表示造型方法。

2.多边形网格表示

(1)基本集合元素:点、边、面、环和体。

(2)几何信息和拓扑信息:几何信息-->用来描述物体的位置和大小。拓扑信息-->用来描述点、棱边及面片之间的邻接关系。

(3)常用的数据结构:翼边数据结构、对称数据结构、半边数据结构。

3.曲面/曲线造型 

(1)插值与逼近:给定一组有序的数据点,构造一条曲线顺序通过这些数据点,并用它近似已知曲线,成为对这些数据点进行插值,所构造的曲线称为插值曲线。推广到曲面,成为插值曲面。

(2)Bezier曲面/曲线

Bezier曲线的性质:端点性质、对称性、凸包性、仿射不变性

缺点:(1)曲线的阶数是由特征多边形顶点个数决定的,n个控制点产生n-1次的Bezier曲线。

          (2)由于Bernstein调和函数在[1,0]区间内均大于等于0,这使Beizer曲线不能做局部修改。

          (3)虽然可以通过在点集中插图一些点来满足多段Bezier曲线的光滑条件,但这种方法显示很不方便。

        Bezier基函数有n+1项,n+1个基函数的和等于1

(3)B样条曲线/曲面

        为了克服Bezier曲线缺点提出的。

        特点:局部调整性、凸包性、几何不变性、变差减少性、造型灵活等。

        N次B样条曲线具有N-1阶参数连续性。

(4)NURBS曲线/曲面

        改进的B样条方法,保留了它描述自由行曲线与曲面强大能力的同时,扩充其统一表示二次曲线与曲面的能力。这个方法就是有理样条方法。由于在形状描述实践中,有理样条经常以非均匀类型出现,二均匀、非均匀、准均匀、分段Bezier三种类型又可看成非均匀类型的特例,因此人们习惯称之为非均匀有理B样条方法。

        优点:

        即为自由型曲线/曲面也为初等曲线/曲面的精确表示与设计提供了一个公共的数学形式,一个统一的数据库就能够存储这两类形状信息。

        为了修改曲线/曲面的形状,即可以借助调整控制顶点,又可以利用全因子,因而具有较大的灵活性。

        计算稳定且速度快。

        有明确的几何解释,对于有良好的几何知识尤其是画法几何知识的设计人员特别有用。

        NURBS(非均匀有条理B样条)方法是一种主要用于描述任意维度的光滑曲线和曲面类型的几何形状的方法。

        曲线和曲面的表示形式有显式函数方程、隐式函数方程和参数方程三种形式。

        构造实体几何法将实体表示成立方体、长方体、圆柱体、圆锥体等基本体素的组合,可以采用并、交、差等运算构造新的形体。

        

七、真实感图形技术

1.消隐算法

(1)后相面消除

工作原理

  1. 确定面的朝向:在三维空间中,每个三角形面都有一个法向量(Normal Vector),它垂直于该面。法向量的方向可以用来确定面的朝向。通过计算三角形面的法向量与从观察者到该面中心的向量之间的夹角,可以判断该面是前向面还是后向面。
  2. 剔除后向面:如果夹角大于 90 度,说明该面的法向量背向观察者,这个面就是后向面,可以被剔除,不进行渲染;如果夹角小于等于 90 度,则该面是前向面,需要进行渲染。

(2)深度缓冲器算法(z缓存算法)

算法原理

  1. 深度缓冲器的概念:深度缓冲器是一个与屏幕像素点一一对应的二维数组,其大小与屏幕分辨率相同。每个元素存储了对应像素点处物体表面到视点(观察者位置)的距离,通常用  值表示。初始时,深度缓冲器中的所有值被设置为一个很大的数(表示无穷远)。
  2. 颜色缓冲器:同时存在一个颜色缓冲器,用于存储每个像素最终显示的颜色。
  3. 渲染过程:在渲染场景时,对于每个要绘制的多边形(或三角形),计算多边形上每个像素点的  值(即该点到视点的距离)。然后将这个  值与深度缓冲器中对应像素点的当前  值进行比较:

        如果计算得到的  值小于深度缓冲器中的值,说明该像素点对应的多边形表面更靠近视点,当前多边形的颜色应该显示在该像素上。此时,更新深度缓冲器中对应像素点的  值为计算得到的较小值,并将颜色缓冲器中对应像素点的颜色更新为当前多边形的颜色。

        如果计算得到的  值大于或等于深度缓冲器中的值,说明该像素点对应的多边形表面在后面,不需要更新深度缓冲器和颜色缓冲器。

        在多边形面片数量非常大的情况下,消隐算法速度最快的是深度缓存算法(Z-Buffer)

        在Z缓冲器消隐算法中,Z缓冲器每个段元存储的信息是每一个像素点的深度值

(3)画家算法

算法原理

        画家算法的灵感来源于画家绘画的过程。画家在画布上作画时,会先画远处的物体,然后逐渐画近处的物体,这样近处的物体就会自然地覆盖远处的物体。在计算机图形学中,我们可以将场景中的物体按照它们到视点(观察者)的距离进行排序,距离远的物体先绘制,距离近的物体后绘制,这样在绘制过程中,近处的物体就会覆盖远处的物体,从而正确地解决可见性问题。

        适用于固定视点的消隐。

        消隐算法按照消隐空间的不同分为物体空间消隐算法和图像空间消隐算法。

        

2.光照明模型

(1)环境光:物体和环境间多次反射,最终达到平衡时的一种光。

(2)漫反射光:全局漫反射光照效果的一种近似。

(3)镜面反射光:反射光集中在一个反向,并遵守反射定律。

Phong光照明模型:第一个有影响的光照明模型。

Whitted光照明模型:第一次给出光线追踪算法的范例。

        当观察光照下的光滑物体表面时,在某个方向上看到高光或强光,这个现象称为镜面反射

        在真实感显示过程中,不属于简单光照明模型中光线类型的是:透射光线。属于的是:环境反射光线、漫反射光线、镜面反射光线。

        在光线跟踪(Ray Tracing)算法中,应继续跟踪光线的情况是:光线与到某一物体

3.着色

(1)均匀着色:恒定光强对多边形着色。

(2)平滑着色(Gouraud着色):双线性插值着色。

(3)Phong着色:保留双线性插值,对多边形边上的点和区域内的点,采用增量法。

        Gouraud明暗处理采用双线性光强插值算法.

4.纹理映射技术

(1)颜色纹理映射

(2)几何纹理映射 

(3)环境映射

        在纹理映射中,常用的纹理坐标范围是[0,1]

        在真实感纹理技术中,纹理类型主要有颜色纹理几何纹理两种。

课程推荐:mooc华中科技大学,计算机图形学计算机图形学_华中科技大学_中国大学MOOC(慕课)

 附加练习题:计算机图形学3套卷含答案_计算机图形学3套试卷含答案csdn-CSDN博客


http://www.ppmy.cn/embedded/148927.html

相关文章

List反转的方法

1.list循环 List<String> strsnew ArrayList<>();for (int i 0; i <100 ; i) {strs.add("a"i);}List<String> fzstrsnew ArrayList<>();for (int i strs.size()-1; i >0 ; i--) {fzstrs.add(strs.get(i));}System.out.println(fzstr…

Clickhouse 集群配置

前提 需要一个Zookeeper集群需要三个节点部署ClickHouse config.xml基础配置 vi config.xml 通常要检查xml里面这几个&#xff1a; listen_host # 改成<listen_host>::</listen_host> tcp_port # 要改端口这里http 和 tcp http_port …

路由器做WPAD、VPN、透明代理中之间一个

本文章将采用家中TP-Link路由器 路由器进行配置DNS DNS理解知识本文DNS描述参考&#xff1a;网络安全基础知识&中间件简单介绍_计算机网络中间件-CSDN博客 TP LINK未知的错误&#xff0c;错误编号&#xff1a;-22025 TP-LINK 认证界面地址&#xff1a;https://realnam…

探索鸿蒙的蓝牙A2DP与访问API:从学习到实现的开发之旅

完成了鸿蒙系统中一系列的学习与实际应用后&#xff0c;我的开发旅程逐渐走向了更复杂的领域。这次&#xff0c;我决定挑战蓝牙相关功能。蓝牙技术是现代设备互联的核心之一&#xff0c;而鸿蒙系统提供的Bluetooth A2DP API和Bluetooth Access API为开发者带来了便捷的接口。不…

springMVC-请求响应

springmvc——一 站式web框架&#xff0c;核心是处理http请求响应。 前后端分离&#xff1a;需要序列化&#xff0c;服务端把数据序列化成字符串或者流给前端&#xff0c;前端又把json转成对象&#xff0c;前端的叫反序列化。前端把数据序列化转成字符串给服务器&#xff0c;服…

【阅读记录-章节7】Build a Large Language Model (From Scratch)

系列文章目录 【阅读记录-章节1】Build a Large Language Model (From Scratch) 【阅读记录-章节2】Build a Large Language Model (From Scratch) 【阅读记录-章节3】Build a Large Language Model (From Scratch) 【阅读记录-章节4】Build a Large Language Model (From Scr…

SDL3 GPU编程探索

目录 前言 总体印象 一般流程 创建窗口 创建设备 准备资源 1.VBO&#xff0c;IBO 2.图像 3.资源转储 4.采样器 5.着色器 6.渲染管线 绘制 插曲 1.忘记初始化 2.关于数学库 3.SDL3_image 结语 前言 几天前冲浪才得知SDL有了一下代&#xff0c;而且还支持GPU编程…

Hive其五,使用技巧,数据查询,日志以及复杂类型的使用

目录 一、关于Hive使用的一些技巧 二、表的数据查询 三、Hive默认的日志 四、复杂数据类型 1、Array的使用 2、展开函数的使用 explode 3、Map的使用 4、Struct结构体 一、关于Hive使用的一些技巧 1、可以直接不进入hive的情况下执行sql语句 通过shell的参数 -e 可以执…