【计算机图形学 | 基于MFC三维图形开发】期末考试知识点汇总(上)

news2025/1/21 22:10:01

文章目录

  • 视频教程
  • 第一章 计算机图形学概述
    • 计算机图形学的定义
    • 计算机图形学的应用
    • 计算机图形学 vs 图像处理 vs模式识别
    • 图形显示器的发展及工作原理
    • 理解三维渲染管线
  • 第二章 基本图元的扫描转换
    • 扫描转换
    • 直线的扫描转换
    • DDA算法
    • Bresenham算法
    • 中点画线算法
    • 圆的扫描转换
    • 中点画圆算法
    • 反走样
  • 第三章 多边形填充
    • 概念
    • 有效边表的填充思路
    • 有效边表的算法实现
    • 边缘填充
    • 种子填充算法

视频教程

孔令德 | 计算机图形学网上课堂:30个知识点的微课讲解

在这里插入图片描述

第一章 计算机图形学概述

计算机图形学的定义

定义:计算机图形学是一门研究怎样用计算机表示生成处理显示图形的学科。


分类:

  • 几何图形:基于线框模型 描述
  • 真实感图形:基于表面模型 描述

在这里插入图片描述


图形表示方法:

  • 参数法
  • 点阵法

计算机图形学就是研究 将图形的表示法从参数法转换到点阵法 的一门学科。


图形学之父:Ivan E. Sutherland


单选:计算机图形学与计算机图象学的关系是(B)

A.计算机图形学是基础,计算机图象学是其发展

B.不同的学科,研究对象和数学基础都不同,但它们之间也有可转换部分

C.同一学科在不同场合的不同称呼而已

D.完全不同的学科,两者毫不相干


计算机图形学的应用

应用领域内容
计算机游戏计算机游戏的核心技术来自于计算机图形学,如多分辨率地形生成、天空盒纹理、角色动画、碰撞检测、粒子系统、自然景物模拟、交互技术、实时绘制等。计算机游戏是计算机图形学发展的一个重要推动力。
计算机辅助设计计算机辅助设计(Computer Aided Design,CAD)和计算机辅助制造(Computer Aided Manufacture,CAM)是计算机图形学最早应用的领域,也是当前计算机图形学最成熟的应用领域,典型的代表产品为AutoCAD系统软件。现在建筑、机械、飞机、汽车、轮船、电子器件等产品的开发几乎都使用AutoCAD进行设计。Autodesk公司出版的另外两个三维建模、动画和渲染软件是3ds max和Maya,前者主要用于建筑物建模,后者主要用于角色建模。
计算机艺术计算机图形学广泛应用于美术设计中,称为计算机艺术。动画设计是其典型代表。动画是计算机艺术的典型代表。根据人眼的视觉暂留特性,将一系列的单幅静态画面(frame,帧)串接在一起,以24-30帧/秒的速度播放,形成运动的效果。
虚拟现实虚拟现实(virtual reality,VR)技术是利用计算机生成虚拟环境,逼真地模拟人在自然环境中的视觉、听觉、运动等行为的人机交互的新技术。借助于一些特殊设备,如数据手套、头盔显示器等,用户可以“沉浸”到该环境中。在虚拟现实中,感受到的是虚拟环境设备反馈的作用力,从而产生身临其境的感觉。
计算机辅助教学计算机辅助教学是利用计算机图形学技术展示抽象原理或不可见过程的一种新的教学方法。在多媒体教室,教师使用集图、文、声、像为一体的多媒体课件进行教学,有助于学生理解和接受深奥枯燥的理论。

单选:下面哪一项不属于计算机图形学的应用范围?(B)

A.计算机动画

B.从遥感图像中识别道路等线划数据

C.三维可视化技术

D.影视三维动画制作


判断题:分形技术在自然景物的模拟中发挥了重要作用。(正确)


判断题:虚拟现实技术属于计算机图形学的应用范围。(正确)


简答题:请简述计算机图形学的应用领域有哪些?请列举三个以上的应用领域。

答:

计算机图形学已经在游戏、电影、科学、艺术、商业、广告、教学、培训和军事等领域获得了广泛的应用。

应用领域包括但不限于:

  • 计算机游戏
  • 计算机动画
  • 计算机辅助设计与辅助制造
  • 计算机辅助教学
  • 虚拟现实

计算机图形学 vs 图像处理 vs模式识别

  • 计算机图形学:从抽象数据到图像的过程,主要用于图像的生成和渲染。
  • 图像处理:是在图像已经存在的基础上,通过算法对其进行加工和改善,改进图像质量或提取信息。
  • 模式识别:从图像出发,试图理解图像内容并将其转换为抽象的描述,是一种从图像到数据的过程。

计算机图形学的研究内容不包括:图像处理和模式识别


图形显示器的发展及工作原理


判断题:CRT由四部分组成:电子枪、聚焦系统、偏转系统和荧光屏。(正确)


  • 光栅扫描显示器:画点设备,即点阵单元发生器,并可控制每个点阵单元的亮度,这些点阵单元被称为像素。
  • 帧缓冲存储器(显存):帧缓冲中单元数目与显示器上的像素数目相同,而且单元与像素一一对应。要在屏幕上显示图像,首先要把图像信息写入帧缓冲,然后光栅扫描显示器访问帧缓冲,再把其中的内容显示到屏幕上。

备注:帧缓冲单元的数值决定了显示器像素的颜色。显示器颜色的种类与帧缓冲中每个单元的位数有关。

在这里插入图片描述


  • 1 个位面:每个像素的颜色只用一位(Bit)表示(其值非0即1),此时屏幕只能显示黑白二色图像,称为黑白显示器
  • 8个位面:每个像素的颜色用一个字节(Byte)表示,帧缓冲器需要用八个位面,可表示 2 8 2^{8} 28 种灰度,称为灰度显示器。
  • 24个位面:每个像素用R、G、B三原色混合表示,其中每种原色分别用一个字节表示,各对应一把电子枪,每种颜色可有256种亮度,三种颜色的组合是 2 24 2^{24} 224 颜色。

问题:对于分辨率为1024*1024的光栅系统,若每一像素用8位和12位二进制来表示存储信息,各需多大光栅存储容量以及显存?每一屏幕最多能显示多少颜色?若R,G,B灰度都占8位,其显示颜色的总数是多少?

答:

8位表示

  • 每个像素用8位(1字节)来表示。
  • 分辨率为1024*1024,即总共有1024 * 1024 = 1,048,576个像素。
  • 因此,总存储容量为1,048,576字节(即1,048,576 * 8位 = 8,388,608位)。
  • 在8位表示下,每一屏幕最多能显示的颜色数为 2 8 = 256 2^8 = 256 28=256种颜色。

12位表示

  • 每个像素用12位来表示。
  • 分辨率为1024*1024,即总共有1024 * 1024 = 1,048,576个像素。
  • 总存储容量为1,048,576 * 12位 = 12,582,912位,转换为字节为12,582,912 / 8 = 1,572,864字节。
  • 在12位表示下,每一屏幕最多能显示的颜色数为 2 12 = 4096 2^{12} = 4096 212=4096种颜色。

R,G,B各占8位时的颜色总数

  • R、G、B每种颜色有256种亮度(即 2 8 2^8 28种)。
  • 三种颜色组合的总颜色数为 2 8 ∗ 2 8 ∗ 2 8 = 2 24 = 16 , 777 , 216 2^8 * 2^8 * 2^8 = 2^{24} = 16,777,216 282828=224=16,777,216种颜色。

单选题:分辨率为 1024×1024 的显示器,需要多少位面数为8的帧缓存(A)

A.1M

B. 2M

C. 3M

D.4M

解析:

  • 分辨率为1024×1024的显示器意味着总共有1024 * 1024 = 1,048,576个像素点。
  • 如果每个像素点需要8位(即1字节)来表示其颜色信息,那么总共需要的字节数为1,048,576字节。
  • 由于1M(兆)字节等于1,048,576字节,因此需要的帧缓存大小为1M字节。

单位换算:

  • 1字节 = 8位
  • 1兆字节(MB)= 1,048,576字节 = 2 20 2^{20} 220字节

单选题:分辨率为1024×1024的显示器各需要多少位面数为16的帧缓存(B)

A.1M

B. 2M

C. 3M

D.512K

解析:

  • 分辨率为1024×1024的显示器意味着总共有1024 * 1024 = 1,048,576个像素点。
  • 如果每个像素点需要16位来表示其颜色信息,那么总共需要的位数为1,048,576像素 * 16位/像素 = 16,777,216位。
  • 将位数转换为字节数(因为1字节 = 8位),所需的字节数为16,777,216位 / 8 = 2,097,152字节。
  • 由于1M字节等于1,048,576字节,所以2,097,152字节等于2M字节。因此,需要的帧缓存大小为2M字节。

理解三维渲染管线

三维渲染管线:将三维场景转化为二维图像的过程,涉及以下阶段:

  1. 应用程序阶段

    • 任务:处理场景中的对象,包括它们的几何形状、位置、动画、物理效果等。
    • 输出:将场景中需要渲染的几何体(图元)及其属性(如摄像机位置、光照条件)输出到下一个阶段。
  2. 几何阶段

    • 模型视点变换:将模型从局部坐标系转换到世界坐标系,再从世界坐标系转换到观察者(摄像机)坐标系。
    • 顶点着色:计算顶点的光照效果,为后续的光栅化阶段提供必要的颜色信息。
    • 投影:将三维场景投射到二维视平面上,涉及透视投影或正交投影。
    • 裁剪:移除那些完全不在视野内的图元,减少后续阶段的计算量。
    • 屏幕映射:将裁剪后的图元映射到屏幕坐标系,为光栅化阶段准备。
  3. 光栅化阶段

    • 任务:将几何阶段处理后的图元转换为屏幕上的像素点,涉及插值计算(如深度、颜色、纹理坐标等)。
    • 输出:最终渲染的二维图像,包括确定哪些像素属于哪个图元,以及这些像素的具体颜色和属性。

选择题:三维渲染管线实现计算机内一个三维模型从数据到图像的转换过程。该过程包括下面的步骤,请按渲染管线的流程,选择合适的处理步骤填入空(1)~ 空(6)

三维模型加载➡️空(1)➡️空(2) ➡️ 空(3)➡️ 空(4)➡️空(5)➡️ 空(6)➡️显示在显示器上

  • A. 观察变换
  • B. 模型变换(三维几何变换)
  • C. 投影变换
  • D. 消隐
  • E. 光栅化(扫描转换)
  • F. 计算顶点光照(颜色)

答案:B A C D F E


过取样:在高于显示分辨率的较高分辨率下用点取样方法计算,然后对几个像素的属性进行平均得到较低分辨率下的像素属性。实际上是把显示器看成是比实际更细的网格来增加取样率。


单选题:在Windows中,绘图一般在视图窗口的客户区进行,使用的是MFC的设备上下文类( B )中的各种绘图函数。

A.MFC

B. CDC

C. DEC

D. PDC


单选题:MFC中的绘图一般在视图类的(屏幕/打印机)绘图消息响应函数( D )中进行。

A.paint

B. main

C. OnPaint

D.OnDraw


简答题:请简述三维渲染管线的处理流程。

答:

三维渲染管线,用于将三维场景转换为二维图像,主要有以下处理流程:

  1. 应用程序阶段:处理场景中的各种对象,包括它们的几何形状、位置、动画和物理效果等,最终输出场景中需要渲染的几何体(图元)及其相关属性,如摄像机位置和光照条件。

  2. 几何阶段:模型视点变换,将模型从局部坐标系转换到世界坐标系,然后转换到观察者(摄像机)坐标系。接着进行顶点着色,计算顶点的光照效果。之后是投影,将三维场景投射到二维视平面上,裁剪步骤移除那些完全不在视野内的图元,最后屏幕映射将裁剪后的图元映射到屏幕坐标系,为光栅化阶段做准备。

  3. 光栅化阶段:将几何阶段处理后的图元转换为屏幕上的像素点,涉及到插值计算,如深度、颜色、纹理坐标等。最终输出是渲染的二维图像,


第二章 基本图元的扫描转换

扫描转换

  • 概念:确定最佳逼近图形的像素集合,并用指定属性写像素的过程称为图形的扫描转换,也称为光栅化。
  • 作用:将矢量图形转换为像素阵列,以在光栅图形显示器上显示。

单选题:多边形扫描转换可以将( A )。

A.多边形由顶点表示转换成点阵表示

B. 多边形由区域表示转换成边界表示

C.多边形转换为显示器的扫描线

D.多边形的填充属性改变


简答题:请简述什么是扫描转换?

答:

确定最佳逼近图形的像素集合,并用指定属性写像素的过程称为图形的扫描转换或光栅化。


直线的扫描转换

定义:在帧缓冲器有限的像素中,寻找一组能最接近真实直线的像素点,对这些像素进行写操作。


直线的斜截式方程如下:

y = k x + b y = kx + b y=kx+b

其中:

  • k k k —— 直线的斜率
  • b b b —— 直线在 y y y轴的截距

给定两点 ( x 1 , y 1 ) (x_1, y_1) (x1,y1) ( x 2 , y 2 ) (x_2, y_2) (x2,y2),则直线的斜率 k = y 2 − y 1 x 2 − x 1 k = \frac{y_2 - y_1}{x_2 - x_1} k=x2x1y2y1,其中主位移 Δ \Delta Δ 定义为:

Δ = max ⁡ ( Δ x , Δ y ) \Delta = \max(\Delta x, \Delta y) Δ=max(Δx,Δy)

在直线扫描转换过程中,根据主位移方向执行加 1 1 1或者减 1 1 1操作,以确定直线上的像素点。


DDA算法

已知过端点 ( x 1 , y 1 ) (x1, y1) (x1,y1) ( x 2 , y 2 ) (x2, y2) (x2,y2) 的直线段 y = k x + b y=kx+b y=kx+b,斜率 k k k y 2 − y 1 x 2 − x 1 \frac{y_2 - y_1}{x_2 - x_1} x2x1y2y1

DDA算法

  • ∣ k ∣ ≤ 1 |k| \le 1 k1:当 x x x每递增 1 1 1 y y y 递增 k k k (即直线斜率)
  • ∣ k ∣ > 1 |k| > 1 k>1:当 y y y每递增 1 1 1 x x x 递增 k k k (即直线斜率)

大题:请用DDA直线扫描转换算法,计算(0,0)(6,4)直线上的点,将下面的表格填写完整:

xy
00
【】【】
【】【】
【】【】
【】【】
【】【】
64

答:

对于直线(0,0)到(6,4),我们首先计算斜率 k k k

  • k = y 2 − y 1 x 2 − x 1 = 4 − 0 6 − 0 = 2 3 k = \frac{y_2 - y_1}{x_2 - x_1} = \frac{4 - 0}{6 - 0} = \frac{2}{3} k=x2x1y2y1=6040=32

由于 ∣ k ∣ ≤ 1 |k| \le 1 k1,我们将从 ( x 1 , y 1 ) = ( 0 , 0 ) (x1, y1) = (0, 0) (x1,y1)=(0,0) 开始,每次 x x x 递增 1 1 1 y y y 递增 k k k,直到 x = x 2 x = x2 x=x2

计算过程中, y y y 的值需要四舍五入到最近的整数。

xy
00
11
21
32
43
53
64

解释:

  • ( 0 , 0 ) (0, 0) (0,0) 开始。
  • 每次 x x x 递增 1 1 1 y y y 递增 k = 2 3 k = \frac{2}{3} k=32
  • y y y 的值在每一步都四舍五入到最近的整数。

单选题:直线DDA算法,当斜率m<1时,x方向的增量△x和y方向的增量△y分别是?( C )

A. ±m 和 ±1

B. ±1 和 ±1/m

C. ±1 和 ±m

D. ±1/m 和 ±1


判断题:在DDA算法中,当斜率大于1时,则y方向为主步进方向。(正确)


Bresenham算法

Bresenham 算法的基本思想:主位移方向每次递增一个像素,另一个方向的增量是 0 0 0 1 1 1 ,取决于像素点与理想直线的距离。这个距离称之为误差项,用 d d d 表示

x x x 主位移方向为例, x i + 1 = x i + 1 x_{i+1} = x_i + 1 xi+1=xi+1,则:

y i + 1 = { y i + 1 ,    ( d ≥ 0.5 ) y i ,    ( d < 0.5 ) y_{i+1} = \begin{cases} y_i + 1, ~~ (d \ge 0.5) \\ y_i, ~~ (d < 0.5) \end{cases} yi+1={yi+1,  (d0.5)yi,  (d<0.5)

e i + 1 = d i + 1 − 0.5 e_{i+1} = d_{i+1} - 0.5 ei+1=di+10.5,则:

y i + 1 = { y i + 1 ,    ( e ≥ 0 ) y i ,    ( e < 0 ) y_{i+1} = \begin{cases} y_i + 1, ~~ (e \ge 0) \\ y_i, ~~ (e < 0) \end{cases} yi+1={yi+1,  (e0)yi,  (e<0)


单选题:Bresenham直线扫描转换法中,从理想直线到位于直线上方的像素的距离为t,到位于直线下方的像素的距离为s,s-t>=0的时候,选择如下哪个点?(A)

A.直线上方的点

B. 直线下方的点

C.理想直线上的点

D.不确定


整数化的 bresenham 算法描述如下:

int e = -dx;
for(i = 0; i <= dx; i++) {
    drawpixel(x, y, color);
    x++;
    e += 2 * dy;
    if(e >= 0) {
        y++;
        e -= 2 * dx;
    }
}

也就是说, e e e 初始化为 − Δ x - \Delta x Δx,然后循环 Δ x \Delta x Δx 次,其中每次:

  • x x x 都是加 1 1 1 e e e 2 Δ y 2\Delta y y
  • 一旦 e ≥ 0 e \ge 0 e0 了, y y y 就可以加 1 1 1,然后将 e e e 减掉 2 Δ x 2 \Delta x x

单选题:使用 Bresenham 直线扫描转换法,绘制直线段 P 0 ( 0 , 0 ) P_0(0,0) P0(0,0) —— P 1 ( 5 , 2 ) P_1(5,2) P1(5,2),在 x = 3 x=3 x=3 时, y y y 应该是?(A)

A.1

B. 0

c. 2

D. 3

解析:

根据上面【整数化的 bresenham 算法代码描述】,我们将数值代入,很容易计算出答案。

在这里插入图片描述

首先,我们需要确定 Δ x \Delta x Δx Δ y \Delta y Δy 的值。对于直线段 P 0 ( 0 , 0 ) P_0(0,0) P0(0,0) P 1 ( 5 , 2 ) P_1(5,2) P1(5,2)

  • Δ x = 5 − 0 = 5 \Delta x = 5 - 0 = 5 Δx=50=5
  • Δ y = 2 − 0 = 2 \Delta y = 2 - 0 = 2 Δy=20=2

此时 x x x 为主位移方向,根据 bresenham 算法, e e e 初始化为 − Δ x = − 5 - \Delta x = -5 Δx=5。然后,我们将按照算法步骤进行迭代:

x x x y y y e e e 初始值 e e e 2 Δ y 2\Delta y y条件 e ≥ 0 e \ge 0 e0 是否成立?如果 e ≥ 0 e \ge 0 e0,请给出 e e e 2 Δ x 2\Delta x x 后的结果
00 − 5 -5 5 − 1 -1 1
10 − 1 -1 1 3 3 3 − 7 -7 7
21 − 7 -7 7 − 3 -3 3
31 − 3 -3 3 1 1 1 − 9 -9 9

因此,在 x = 3 x = 3 x=3 时, y y y 应该是 1 1 1


中点画线算法

中点算法原理: x x x 方向上每次加 1 1 1 y y y 方向上加不加 1 1 1 取决于中点误差项的值。

整数化的中点画线算法流程如下:

public void drawLine(int x0, int y0, int x1, int y1) {
    int dx = x1 - x0;
    int dy = y1 - y0;
    int d = dx - 2 * dy;	// 关键
    int x = x0;
    int y = y0;

    while (x <= x1) {
    	// 绘制点(x, y)
        plot(x, y);
       
        if (d > 0) { 
            d -= 2 * dy;
            x++;
        } else {
            d += 2 * (dx - dy);
            x++;
            y++;
        }
    }
}

大题:请用整数化的中点画线算法计算直线(0,0)(5,3)的扫描转换结果,并给出计算流程表

答:

根据整数化的中点画线算法,我们首先计算初始值:

  • d x = 5 − 0 = 5 dx = 5 - 0 = 5 dx=50=5
  • d y = 3 − 0 = 3 dy = 3 - 0 = 3 dy=30=3
  • d = d x − 2 d y = 5 − 2 ∗ 3 = − 1 d = dx - 2 dy = 5 - 2*3 = -1 d=dx2dy=523=1

然后,我们根据算法步骤逐步更新 x x x y y y,和 d d d 的值:

xydd是否大于0?更新操作
00-1 d = d + 2 d x − 2 d y = − 1 + 10 − 6 = 3 d = d + 2dx - 2dy = -1 + 10 - 6 = 3 d=d+2dx2dy=1+106=3
113 d = d − 2 d y = 3 − 6 = − 3 d = d - 2dy = 3 - 6 = -3 d=d2dy=36=3
21-3 d = d + 2 d x − 2 d y = − 3 + 10 − 6 = 1 d = d + 2dx - 2dy = -3 + 10 - 6 = 1 d=d+2dx2dy=3+106=1
321 d = d − 2 d y = 1 − 6 = − 5 d = d - 2dy = 1 - 6 = -5 d=d2dy=16=5
42-5 d = d + 2 d x − 2 d y = − 5 + 10 − 6 = − 1 d = d + 2dx - 2dy = -5 + 10 - 6 = -1 d=d+2dx2dy=5+106=1
53---

注意:在每一步中, x x x 都会增加 1 1 1,但 y y y 是否增加取决于 d d d 的值。


圆的扫描转换

考虑以坐标系原点为圆心,半径为 r r r 的圆。则圆周上各点满足 x 2 + y 2 = r 2 x^2+y^2=r^2 x2+y2=r2,也就是说:

F ( x , y ) = x 2 + y 2 − r 2 = 0 F(x, y) = x^2+y^2 - r^2 = 0 F(x,y)=x2+y2r2=0

这也称为圆的隐方程
在这里插入图片描述
圆分平面成三个区域:

  • 对于圆上的点, F ( x , y ) = 0 F(x,y)=0 F(xy)0
  • 对于圆外的点, F ( x , y ) > 0 F(x,y)>0 F(xy)0
  • 对于圆内的点, F ( x , y ) < 0 F(x,y)<0 F(xy)0

圆的八对称性:只要扫描转换八分之一圆弧,
就可以求出整个圆弧的像素集。

因为圆关于坐标轴和对角线对称

在这里插入图片描述


中点画圆算法

中点画圆算法流程如下:

int x = 0;
int y = r;
double d = 1.25 - r;

while (x < y) { // 当 x = y 时结束
    plotCirclePoints(x, y);
    if (d >= 0) {
        d += 2 * (x - y) + 5;
        y--;
    } else {
        d += 2 * x + 3;
    }
    x++;
}

填空题:根据圆的八对称性,我们在扫描转换半径为R的圆形的时候,选择扫描转换圆心在【】,以(【】,【】)为起点,以【】为结束条件的圆弧,并且在扫描转换过程中,每一步画点的时候,一次画出【】个点。

答:

  • 【原点】
  • 【0】
  • 【R】
  • 【x=y】
  • 【8】

大题:使用中点画圆的扫描转换算法,扫描转换圆心在(0,0),半径为6的圆,按照算法流程给出每一步计算的误差D和Y坐标。

答:

根据中点画圆算法的描述,我们可以逐步计算每一步的 x x x y y y 坐标和误差 d d d 的值。

在这里插入图片描述

圆的半径 r = 6 r = 6 r=6,所以初始值为:

  • x = 0 x = 0 x=0
  • y = r = 6 y = r = 6 y=r=6
  • d = 1.25 − r = 1.25 − 6 = − 4.75 d = 1.25 - r = 1.25 - 6 = -4.75 d=1.25r=1.256=4.75

接下来,我们将按照算法步骤进行迭代。每次 d d d 的更新依赖于它是正还是负:

  • 如果 d ≥ 0 d \ge 0 d0,则 d = d + 2 ( x − y ) + 5 d = d + 2 (x - y) + 5 d=d+2(xy)+5,此时 y y y 1 1 1
  • 如果 d < 0 d < 0 d<0,则 d = d + 2 x + 3 d = d + 2 x + 3 d=d+2x+3,此时 y y y 不变

因此:

x x x y y y d d d d d d 是否 ≥ 0 \ge 0 0更新操作
0 0 0 6 6 6 − 4.75 -4.75 4.75 d = d + 2 x + 3 = − 4.75 + 3 = − 1.75 d = d + 2x + 3 = -4.75+ 3 = -1.75 d=d+2x+3=4.75+3=1.75
1 1 1 6 6 6 − 1.75 -1.75 1.75 d = d + 2 x + 3 = − 1.75 + 2 × 1 + 3 = 3.25 d = d + 2x + 3 = -1.75 + 2×1 + 3 = 3.25 d=d+2x+3=1.75+2×1+3=3.25
2 2 2 6 6 6 3.25 3.25 3.25 d = d + 2 ( x − y ) + 5 = 3.25 + 2 ( 2 − 6 ) + 5 = 0.25 d = d + 2(x - y) + 5 = 3.25 + 2(2-6) + 5 = 0.25 d=d+2(xy)+5=3.25+2(26)+5=0.25,同时 y = y − 1 y = y - 1 y=y1
3 3 3 5 5 5 0.25 0.25 0.25 d = d + 2 ( x − y ) + 5 = 0.25 + 2 ( 3 − 5 ) + 5 = 1.25 d = d + 2(x - y) + 5 = 0.25 + 2(3 - 5) + 5 = 1.25 d=d+2(xy)+5=0.25+2(35)+5=1.25,同时 y = y − 1 y = y - 1 y=y1
4 4 4 4 4 4

x = y x = y x=y 时,算法结束。


单选题:Bresenham圆扫描转换法中,初始误差 d 为?(B)

A.2-r

B. 3-2*r

C. 1-r

D. r


单选题:Bresenham圆的扫描转换算法的算法结束条件是( A)。

A.x==y

B. x=1

C. y=1

D. x!=y


反走样

  • 走样】:在连续空间中的物体映射到图像空间带来的各种各样的失真。
  • 反走样】:用于减少和消除各种走样的方法

反走样的技术:

硬件:提高显示器的分辨率

在这里插入图片描述

软件:改进软件算法。比如下面这个【加权区域采样】:

在这里插入图片描述

加权区域采样(距离,面积,体积),原理是利用人眼视觉特性,即人眼对某一区域颜色的识别是这个区域颜色的平均值。
通过加权平均的方法,调节像素的亮度和灰度,以产生模糊的边界,从而达到较好的视觉效果以消除“锯齿”。

另外还有【Wu反走样】:

武筱林于1991年在computer Graphics上提出 “Efficient Antialiasing Technique”。

Wu反走样算法原理是对于理想直线上的任一点,同时以两个不同亮度级别的相邻像素来表示。


单选题:下列不属于走样现象的有?(D)

A.阶梯现象

B.动画闪烁

C.亮度不均

D.深度丢失


单选题:下面关于反走样的方法中论述错误的是( D )

A.提高分辨率

B.把像素当作平面区域进行采样

C.采用特定形状的滤波器进行加权区域采样

D. 增强图像的显示亮度


单选题:如果背景颜色为(100,0,100),直线颜色为(200,200,100),反走样算法计算的前景色比率为0.2,则像素点的颜色?(C)

A.(180,160,100)

B.(150,100,100)

C.(120,40,100)

D.以上都不对

解析:

  1. 定义背景颜色 C b g = ( R b g , G b g , B b g ) C_{bg} = (R_{bg}, G_{bg}, B_{bg}) Cbg=(Rbg,Gbg,Bbg)
  2. 定义前景颜色 C f g = ( R f g , G f g , B f g ) C_{fg} = (R_{fg}, G_{fg}, B_{fg}) Cfg=(Rfg,Gfg,Bfg)
  3. 定义前景色比率为 α \alpha α,则背景色比率为 1 − α 1 - \alpha 1α
  4. 最终颜色 C = ( R , G , B ) C = (R, G, B) C=(R,G,B)

则:

C = C b g ⋅ ( 1 − α ) + C f g ⋅ α C = C_{bg} \cdot (1 - \alpha) + C_{fg} \cdot \alpha C=Cbg(1α)+Cfgα

也就是说:

  • R = R b g ⋅ ( 1 − α ) + R f g ⋅ α R = R_{bg} \cdot (1 - \alpha) + R_{fg} \cdot \alpha R=Rbg(1α)+Rfgα
  • G = G b g ⋅ ( 1 − α ) + G f g ⋅ α G = G_{bg} \cdot (1 - \alpha) + G_{fg} \cdot \alpha G=Gbg(1α)+Gfgα
  • B = B b g ⋅ ( 1 − α ) + B f g ⋅ α B = B_{bg} \cdot (1 - \alpha) + B_{fg} \cdot \alpha B=Bbg(1α)+Bfgα

对于给定的问题,将数值代入:

  • R = 100 ⋅ ( 1 − 0.2 ) + 200 ⋅ 0.2 = 120 R = 100 \cdot (1 - 0.2) + 200 \cdot 0.2 = 120 R=100(10.2)+2000.2=120
  • G = 0 ⋅ ( 1 − 0.2 ) + 200 ⋅ 0.2 = 40 G = 0 \cdot (1 - 0.2) + 200 \cdot 0.2 = 40 G=0(10.2)+2000.2=40
  • B = 100 ⋅ ( 1 − 0.2 ) + 100 ⋅ 0.2 = 100 B = 100 \cdot (1 - 0.2) + 100 \cdot 0.2 = 100 B=100(10.2)+1000.2=100

因此,最终颜色 C = ( 120 , 40 , 100 ) C = (120, 40, 100) C=(120,40,100)


单选题:产生走样的根本原因是( D )。

A.显示分辨率太低

B. 图像数据量太大

C. 显存太小

D .像素是有大小的,离散的,不是理想的数学上的点


判断题:确定最佳逼近图形的像素集合,并用指定属性写像素的过程称为图形的扫描转换或光栅化。(正确)


判断题:图形学中的直线是没有宽度和端点的。(正确)


简答题:走样的现象能不能完全消除?反走样的概念是什么?

答:

不能完全消除。

将定义在连续空间中的物体映射到图像空间带来的各种各样的失真称为走样,用于减少和消除各种走样的方法叫做反走样。


第三章 多边形填充

概念

多边形填充的定义:将一个多边形区域内每个像素点绘制上某种颜色的过程。


多边形的表示方法:

  • 顶点表示:用多边形的顶点序列来表示多边形
  • 点阵表示:用位于多边形内的像素点的集合来刻画多边形

在这里插入图片描述


多边形扫描转换的基本思想:

  • 对于一个多边形,用一组水平或垂直的扫描线进行扫描,求出每条扫描线与多边形的交点.
  • 这些交点将扫描线分割线段
  • 将落在多边形内的所有线段上的每个像素点赋以给定的多边形填充色。

在这里插入图片描述


区域是指相互连通的一组像素的集合,一般由封闭的区域边界定义。

区域填充一般采用种子填充算法,从区域内给定的种子像素出发,按填充颜色填充种子的相邻像素,直到边界为止。


单选题:多边形扫描转换可以将(A )。

A. 多边形由顶点表示转换成点阵表示

B.多边形由区域表示转换成边界表示

C.多边形转换为显示器的扫描线

D.多边形的填充属性改变


有效边表的填充思路

算法思路:

  1. 确定多边形所占有的最大扫描线数,得到多边形顶点的最小和最大y值( y m i n y_{min} ymin y m a x y_{max} ymax
  2. y = y m i n y = y_{min} y=ymin y = y m a x y = y_{max} y=ymax 进行扫描,每一次用一条扫描线进行填充
  3. 对一条扫描线填充的过程可分为四个步骤:
    • 求交:扫描线与多边形各边的交点
    • 排序:把扫描线上所有交点按x递增顺序进行排序
    • 交点配对:将排序后的交点进行两两配对,每对交点代表扫描线与多边形的一个相交区间
    • 区间填色:把区间内的像素置为填充色

在这里插入图片描述


单选题:在X-扫描线算法中,每次用一条扫描线进行填充,对一条扫描线填充的过程可以分为哪四个步骤?(A)

A.求交,排序,配对,填色

B.排序,求交,配对,填色

C.求交,配对,排序,填色

D.排序,填色,求交,配对


有效边表的算法实现

有效边表填充算法用 ET 边表和 AET 活动边表来实现。

边表(ET)是用来对除水平边外的所有边进行登记,来建立边的记录,内容如下:

x / y m i n x/y_{min} x/ymin y m a x y_{max} ymax 1 / k 1/k 1/knext

其中:

  • x / y m i n x/y_{min} x/ymin:边的最小的 y y y对应的 x x x
  • y m a x y_{max} ymax:边的最大 y y y
  • 1 / k 1/k 1/k:边斜率的倒数

在这里插入图片描述

比如在上述图形中,对于 P 0 P 1 P_0P_1 P0P1 边的ET表来说,边的最小的 y y y对应的 x x x值为 1 1 1,边的最大 y y y值为 7 7 7,边斜率的倒数就是 1 / 2 1/2 1/2

那么,当知道怎么求ET 表建立以后,就可以开始扫描转换了。

y = y m i n y = y_{min} y=ymin y = y m a x y = y_{max} y=ymax 进行扫描,每一次用一条扫描线进行填充。

对不同的扫描线,与之相交的边线也是不同的。

当对某一条扫描线进行扫描转换时,我们只需要考虑与它相交的那些边线,为此需要建立一个只与当前扫描线相交的边记录链表,称之为活动边表(AET表)。

AET 表的建立过程就是有效地进行填充的操作。

举个例子吧:

在这里插入图片描述
y = y m i n = 1 y = y_{min} = 1 y=ymin=1 开始,扫描到 y = y m a x = 7 y = y_{max} = 7 y=ymax=7,如果一条边的最低点第一次落到扫描边上,那么,就把该边添加到 AET 活动边表中。

因此上图生成的 AET 表如下:

在这里插入图片描述

注意:当扫描线与多边形相交,同时交点又是顶点时:

  1. 普通连接点的顶点个数计数为1
  2. 局部最低点的顶点个数计为2
  3. 局部最高点的顶点个数计为0

大题:使用有效边表的填充算法填充下面的多边形。

  • 问题1:请问,各顶点处会与水平扫描线产生几个交点?
  • 问题2:给出多边形的边 P 6 P 7 P_6P_7 P6P7 的边表信息。

在这里插入图片描述
答:

问题1:

P 1 P_1 P1 P 2 P_2 P2 P 3 P_3 P3 P 4 P_4 P4 P 5 P_5 P5 P 6 P_6 P6 P 7 P_7 P7
0202021

问题2:

3 3 3 7 7 7 − 2 5 - \frac{2}{5} 52next

大题:使用有效边表填充算法对下面的多边形进行填充,填写空(1)~ 空(15):

在这里插入图片描述

ET表:
在这里插入图片描述
问题1:请问 y = 2 y = 2 y=2 扫描线上的填充区间是(空(10),2) ~ (空(11), 2)

问题2:下图是 y = 3 y = 3 y=3 时的 AET 表,请填充其中缺少的空:

在这里插入图片描述
问题3:算法在 P 1 P_1 P1 点处计算 空(15) 个交点。

答:

  • 空1:【6】
  • 空2:【5】
  • 空3:【1/2】
  • 空4:【2】
  • 空5:【6】
  • 空6:【0】
  • 空7:【8】
  • 空8:【7】
  • 空9:【-1】
  • 空10:【4】
  • 空11:【7】
  • 空12:【7】
  • 空13:【5】
  • 空14:【1/2】
  • 空15:【0】

单选题:边表应记录的内容不包括下面哪一项?( C )

A.最小的y对应的x值

B. 最大的y

C. 最小的y

D. 斜率的倒数


单选题:对下图进行基于扫描线的区域填充,在扫描线5上要填充的区间为?(B)

在这里插入图片描述

A.(1,5)到(8,5)

B. (2,5)到(8,5)

C(1.7,5)到(8,5)

D.以上都不对


单选题:对下图进行基于扫描线的区域填充,在扫描线6上要填充的区间为?(A)

在这里插入图片描述
A.(2,6)到(6,6)

B(1,6)到(6,6)

C(2,6)到(5,6)

D.以上都不对


单选题:如下图所示,对 cd 边建立边表对应的三项内容应该是?(A)
在这里插入图片描述
A. 6,3,-2/3

B. 6,2,-2/3

C. 6,3,-3/2

D. 6,2,-3/2


判断题:有效边表填充算法中边表(ET)里的 x / y m i n x/y_{min} x/ymin 表示x的最小值。(错误)


边缘填充

  • 算法思路:利用取补运算代替交点排序、配对、构造填充区间。
  • 算法原理:
    • 像素点颜色值经过偶数次取补运算后保持不变
    • 像素点颜色值经过奇数次取补运算后变为其补数
  • 算法分类:
    • 以扫描线为中心的边填充算法:对于每一条扫描线和每条多边形边的交点 ( x 1 , y 1 ) (x1,y1) (x1,y1) ,将该扫描线上交点右方的所有像素取补,对每条扫描线做此处理,交点处理的顺序随意。
    • 以边为中心的边填充算法:将每条非水平边右侧的像素取补,边的处理顺序随意。

单选题:关于边缘填充算法,描述正确的是:(B)

A.一个像素经过偶数次的取补会变成它的补色

B.一个像素经过奇数次的取补会变成它的补色

C.一个像素是前景色经过取补运算保持不变

D.取补运算是对像素的坐标进行变换


判断题:关于边缘填充算法里的取补运算,一个像素经过偶数次的取补会变成它的补色。(错误)


种子填充算法

  • 连通区域:
    • 4连通区域是指从区域内一点出发,通过上、下、左、右四种运动可到达区域内的任一像素点。
    • 8连通区域是指从区域内一点出发,通过上、下、左、右以及对角线方向的八种运动可到达区域内的每一像素点。
      在这里插入图片描述

以四连通区域的填充为例,种子填充算法的思路是:

  1. 初始化:将种子像素压入栈中。
  2. 循环检查
    • 如果栈为空,则算法结束。
    • 如果栈不为空,执行以下步骤:
      a. 从栈中弹出一个像素。
      b. 将该像素置为填充色。
      c. 检查该像素相邻的四连通像素是否为边界色或已经置为填充色。如果不是,将这些像素压入栈中。
  3. 重复步骤2,直到栈为空。
  4. 结束:所有可达的非边界且未填充的像素都已被填充。
public void floodFill(int[][] image, Point seed, int fillColor, int boundaryColor) {
    Stack<Point> stack = new Stack<>();
    stack.push(seed); // 初始化:将种子像素压入栈中

    while (!stack.isEmpty()) { // 循环检查
        Point current = stack.pop(); // 从栈中弹出一个像素
        int x = current.x;
        int y = current.y;

        // 检查当前像素是否越界或已经是填充色或边界色
        if (x < 0 || x >= image[0].length || y < 0 || y >= image.length || 
            image[y][x] == fillColor || image[y][x] == boundaryColor) {
            continue;
        }

        image[y][x] = fillColor; // 将该像素置为填充色

        // 检查相邻的四连通像素并压入栈中
        stack.push(new Point(x + 1, y));
        stack.push(new Point(x - 1, y));
        stack.push(new Point(x, y + 1));
        stack.push(new Point(x, y - 1));
    }
    // 结束:所有可达的非边界且未填充的像素都已被填充
}

单选题:种子填充算法中,正确的叙述是?(C)

A.它是按扫描线的顺序进行像素点的填充

B. 四连接算法可以填充八连接区域

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

D.八连接算法不能填充四连通区域。


对下图实施四连通种子填充,其中 S 点为种子。将种子出栈后接下来需要将以下哪些元素入栈?(C)

在这里插入图片描述

A.2,4

B.7,9

C. 2,4,7,9

D.以上都不对


大题:如下图所示的多边形区域,使用四连通种子填充算法进行填充,按照上右下左的顺序遍历邻接像素点:

在这里插入图片描述

下面是该算法在运行过程中的堆栈信息:

在这里插入图片描述

请给出算法下一步执行过程堆栈的内容(按顺序从栈顶元素开始回答)。

其中, S S S 像素点是选取的种子点,用像素的编号代表像素。

答:

题目说了,按照上右下左的顺序遍历邻接像素点。由于此时栈顶元素为 11 11 11,把 11 11 11 弹出来之后,标记为已经访问,然后按照上右下左的顺序,看看有没有哪个像素点还没有访问过:

在这里插入图片描述
此时发现, 6 6 6 16 16 16都没有访问过,所以 6 6 6先压入栈、然后再压入 16 16 16。答案为:

在这里插入图片描述

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

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

相关文章

安全和加密常识(6)Base64编码方式

文章目录 什么是 Base64编码原理编解码示例应用什么是 Base64 Base64 是一种用于将二进制数据编码为仅包含64种ASCII字符的文本格式的编码方法,注意,它不是加密算法。它设计的目的主要是使二进制数据能够通过只支持文本的传输层(如电子邮件)进行传输。Base64常用于在需要处…

音频接口电路的PCB设计

Audio接口是音频插孔&#xff0c;即音频接口&#xff0c;可分为Audio in接口和Audio out接口。音频接口是连接麦克风和其他声源与计算机的设备&#xff0c;其在模拟和数字信号之间起到了桥梁连接的作用。对于平台的数字音频接RK3588口&#xff0c;需遵循《Rockchip RK3588 High…

RTMP推流到SRS流媒体服务器消息处理

RTMP推流到SRS流媒体服务器消息处理 SRS和客户端是怎么交换消息的&#xff1f;各个消息有什么作用&#xff1f;握手成功后&#xff0c;SRS和客户端进行消息交换&#xff0c;对应wiresharek这部分截图&#xff1a; 流程图&#xff08;之前画的&#xff0c;可能不够详细&#xf…

Linux文件系统与设备文件

一、Linux文件操作 Linux的文件系统API主要涉及创建、打开、读写、定位、关闭文件 创建 int creat(const char *filename, mode_t mode);mode: 代表新建文件的存取权限&#xff0c;需要和umask相与才能确定最终权限(mode&umask)。 umask代表文件在创建时需要去掉的存取…

Zookeeper:Zookeeper JavaAPI操作与分布式锁

文章目录 一、Zookeeper JavaAPI操作1、Curator介绍2、创建、查询、修改、删除节点3、Watch事件监听 二、Zookeeper分布式锁原理 一、Zookeeper JavaAPI操作 1、Curator介绍 Curator是Apache Zookeeper的Java客户端。常见的Zookeeper Java API&#xff1a; 原生Java API。ZkC…

[深入理解DDR] 总目录

依公知及经验整理&#xff0c;原创保护&#xff0c;禁止转载。 专栏 《深入理解DDR》 蓝色的是传送门&#xff0c;点击链接即可到达指定文章。 图。 DDR 分类 导论 [RAM] DRAM 导论&#xff1a;DDR4 | DDR5 | LPDDR5 | GDRR6 | HBM 应运而生 运存与内存&#xff1f;内存与存…

【每日刷题】Day77

【每日刷题】Day77 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. LCR 159. 库存管理 III - 力扣&#xff08;LeetCode&#xff09; 2. LCR 075. 数组的相对排序 - 力…

RedisAtomicInteger并发案例

&#x1f370; 个人主页:__Aurora__ &#x1f35e;文章有不合理的地方请各位大佬指正。 &#x1f349;文章不定期持续更新&#xff0c;如果我的文章对你有帮助➡️ 关注&#x1f64f;&#x1f3fb; 点赞&#x1f44d; 收藏⭐️ RedisAtomicInteger 提供了对整数的原子性操作&a…

策略模式在金融业务中的应用及其框架实现

引言 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为设计模式&#xff0c;它允许在不修改客户端代码的情况下&#xff0c;动态地改变一个类的行为。它通过定义一系列算法并将它们封装在独立的策略类中&#xff0c;使这些算法可以互相替换&#xff0c;而不会影响…

PyTorch使用GPU进行Tensor及模型计算

文章目录 1. 计算设备&#xff1a;GPU/CPU2. Tensor的GPU计算3. 模型的GPU计算 对复杂的神经网络和大规模的数据来说&#xff0c;使用CPU来计算可能不够高效。这里&#xff0c;我们将介绍如何使用单块NVIDIA GPU来计算。 首先&#xff0c;需要确保已经安装好了PyTorch GPU版本…

ThreadPoolExecutor 工作线程Worker自身锁设计

个人博客 ThreadPoolExecutor 工作线程Worker自身锁设计 | iwts’s blog 总集 想要完整了解下ThreadPoolExecutor&#xff1f;可以参考&#xff1a; 基于源码详解ThreadPoolExecutor实现原理 | iwts’s blog Worker-工作线程管理 线程池设计了内部类Worker&#xff0c;主…

谷歌个人号,20人连续封测14天所需设备该怎么解决?

现在&#xff0c;在Google Play上架应用&#xff0c;对于大部分开发者来说&#xff0c;真的是不小的挑战&#xff0c;因为目前谷歌上架政策越来越严格了。特别是从2023年11月13日起&#xff0c;新政策要求个人开发者账号的应用必须经过20个独立用户连续14天的封闭测试&#xff…

人工智能 (AI) 在能源系统中应用的机会和风险

现代文明极度依赖于电力的获取。电力系统支撑着我们视为理所当然的几乎所有基本生活功能。没有电力的获取&#xff0c;大多数经济活动将是不可能的。然而&#xff0c;现有的电网系统并未设计来应对当前——更不用说未来的——电力需求。与此同时&#xff0c;气候变化迫切要求我…

基于STM32的智能家用安全监控系统

目录 引言环境准备智能家用安全监控系统基础代码实现&#xff1a;实现智能家用安全监控系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统实现4.4 用户界面与数据可视化应用场景&#xff1a;安全监控管理与优化问题解决方案与优化收尾与总结 1. 引言 智能家用安全监控系…

【C++深度探索】继承机制详解(一)

hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#xff1a;大耳朵土土垚的博客 &#x1…

git客户端工具之Github,适用于windows和mac

对于我本人&#xff0c;我已经习惯了使用Github Desktop,不同的公司使用的代码管理平台不一样&#xff0c;就好奇Github Desktop是不是也适用于其他平台&#xff0c;结果是可以的。 一、克隆代码 File --> Clone repository… 选择第三种URL方式&#xff0c;输入url &…

汽车电子行业知识:什么是车载智能座舱

1.什么是车载智能座舱 车载智能座舱是指搭载在汽车内部的一种智能系统&#xff0c;它集成了各种功能和技术&#xff0c;旨在提升驾驶体验、增加安全性和提供更多的便利。这种系统可以包括诸如智能驾驶辅助、信息娱乐、智能语音控制、车内环境控制、车辆健康监测等功能。通过车…

使用Java连接数据库并且执行数据库操作和创建用户登录图形化界面(3)专栏里有上两步的源代码

创建用户登录程序&#xff0c;验证用户账号和密码信息是否在数据库student中的用户表tb_account中存在。用户登录界面如下图所示&#xff1a; 当单击“登录”按钮时&#xff0c;处理以下几种情况&#xff1a; &#xff08;1&#xff09;用户名未输入&#xff0c;提示用户名不能…

Java_日志

日志技术 可以将系统执行的信息&#xff0c;方便的记录到指定的位置(控制台、文件中、数据库中) 可以随时以开关的形式控制日志启停&#xff0c;无需侵入到源代码中去进行修改。 日志技术的体系结构 日志框架&#xff1a;JUL、Log4j、Logback、其他实现。 日志接口&#xf…

搭建ragflow的步骤

前提条件 CPU > 4 核 RAM > 16 GB Disk > 50 GB Docker > 24.0.0 & Docker Compose > v2.26.1 如果你并没有在本机安装 Docker&#xff08;Windows、Mac&#xff0c;或者 Linux&#xff09;, 可以参考文档 Install Docker Engine 自行安装。 启动服务器 …