计算机图形学DDA画线算法及具体程序实现

计算机图形学DDA画线算法及具体程序实现
计算机图形学DDA画线算法及具体程序实现

数学与软件科学学院 实验报告

学期: 2010 至 2011 第 一 学期 2010年 9月20 日 课程名称: 计算机图形学 专业:信息与计算科学 2007级5班 实验编号: 01 实验项目: DDA 画线 指导教师 庞朝阳 姓名: 学号:200706005 实验成绩:

一、实验目的及要求

1) 理解直线的生成算法; 2) 掌握直线生成算法——数值微分(DDA )法,并用C++程序实现;

二、实验内容

1) 用C++实现DDA 画线程序;

2) 用C++实现按y=ax+b 画直线;

3) 每个取10万次循环,对比运行时间。

三、主要仪器设备及软件环境

1) 计算机;

2) Vc++6.0。

四、具体实验内容:

1.算法的基本思想:

已知过端点0P (0x ,0y )和()1,11y x P 的直线段L(0P

,1P ),斜率为 k=0

101x x y y --. 画线过程:从x 的左端点0x 开始,向x 右端点步进,步长=1(像

素),计算y=ax+b ,取像素点(x ,round(y))作为当前点的坐标, 计算 x k b kx b kx y i i i ?++=+=++11;

若令 1=?x ,则 k y y i i +=+1,即当x 每递增1,y 递增k 。

综上,DDA 算法的本质在于利用数值方法解微分方程,通过同时对x 和y 各增加一个小增量,计算下一步的x,y 值。

2. DDA 算法的优缺点

优点:与基本算法相比,在扫描过程中减少了浮点运算,提高了效率。缺点:由于x与

d,y与y d必须用浮点来表示,且每一步都要进行四

x

舍五入取整,不利于硬件实现,故效率有待提高。

3.程序代码

#include

#include "math.h"

#define TRUE 1

using namespace std;

class DDA

{

public:

void DDALine(int x0,int y0,int x1,int y1,COLORREF color, CDC *pDC)

{

float dx, dy, length, x, y;

if(abs(x1-x0) >= abs(y1-y0))

length = abs(x1-x0);

else

length = abs(y1-y0);

dx = (x1-x0)/length;

dy = (y1-y0)/length;

int i = 1;

x = x0;

y = y0;

while(i<=length)

{

pDC->SetPixel((int)(x+0.5),(int)(y+0.5),color); x = x + dx;

y = y + dy;

i++;

}

}

}

4.程序结果:

计算机图形学实验

实验1 直线的绘制 实验目的 1、通过实验,进一步理解和掌握DDA和Bresenham算法; 2、掌握以上算法生成直线段的基本过程; 3、通过编程,会在TC环境下完成用DDA或中点算法实现直线段的绘制。实验环境 计算机、Turbo C或其他C语言程序设计环境 实验学时 2学时,必做实验。 实验内容 用DDA算法或Besenham算法实现斜率k在0和1之间的直线段的绘制。 实验步骤 1、算法、原理清晰,有详细的设计步骤; 2、依据算法、步骤或程序流程图,用C语言编写源程序; 3、编辑源程序并进行调试; 4、进行运行测试,并结合情况进行调整; 5、对运行结果进行保存与分析; 6、把源程序以文件的形式提交; 7、按格式书写实验报告。 实验代码:DDA: # include # include

void DDALine(int x0,int y0,int x1,int y1,int color) { int dx,dy,epsl,k; float x,y,xIncre,yIncre; dx=x1-x0; dy=y1-y0; x=x0; y=y0; if(abs(dx)>abs(dy)) epsl=abs(dx); else epsl=abs(dy); xIncre=(float)dx/(float)epsl; yIncre=(float)dy/(float)epsl; for(k=0;k<=epsl;k++) { putpixel((int)(x+0.5),(int)(y+0.5),4); x+=xIncre; y+=yIncre; } } main(){ int gdriver ,gmode ;

计算机图形学实验--橡皮筋技术(完整代码,准确无误)

计算机图形学上机实验报告 橡皮筋技术 计算机科学与技术学院 姓名: xxx 完成日期: 2010-12-7

实验:橡皮筋技术 一、实验目的与要求 实验目的:1.学会使用OpenGL,进一步掌握基本图形的绘制方法, 2.理解glut程序框架 3.理解窗口到视区的变换 4.理解OpenGL实现动画的原理 5.学会基于鼠标和键盘实现交互的实现方法 二、实验内容: 利用OpenGL实现折线和矩形的皮筋绘制技术,并采用右键菜单实现功能的选择 实现方法:1.橡皮筋技术的实现采用双缓存技术,绘制图形时分别绘制到两个缓存,交替显示。 2.右键菜单控制选择绘制折线还是绘制矩形,实现方法:通过菜单注册函数创建一个弹出式菜单,然后使用函数加入菜单项,最后使用函数讲菜单与鼠标右键关联起来,GLUT通过为菜单提供一个整数标识符实现对菜单的管理,在main主函数通过标识符用函数指定对应的菜单为当前的菜单。 2. 折线的橡皮筋绘制技术实现:鼠标所在位置确定一个点,移动鼠标时,每次移动时将点的信息保存在数组中,连接当前鼠标所在点和前一个点的直线段。 3.矩形的橡皮筋绘制技术:每个矩形由两个点唯一确定,鼠标当前点为第一个点,移动鼠标确定第二个点的位置,由这两点的坐标绘制出举行的四条边(直线段),矩形即绘制完毕。 三、实验结果

图鼠标右键菜单 图绘制矩形 四、体会 1> 经过这次实验,逐步对opengl软件有了一定的了解,而且对于理论知识有了很好的巩固,并非仅仅会C语言就能编写画图程序,gult程序有自己特殊的框架与实现过程.在这次试验中,虽然没有完全理解其原理,但在一定程度上已经为我们今后的学习应用打下了基础. 2>初步了解了如何在OpenGL实现基本的绘图功能,以及鼠标和键 盘灯交互设备的实现,还有如何由初始生成元绘制分形物体。在这个过 程中遇到了很多问题,程序的调试也是困难重重,通过自己看书思考和 老师、同学的帮助最终完成了程序的调试,在这一过程中加深了对理论 知识的理解,以及理清了理论到实践转换的一点点思路,再一次体会到 理论与实践的结合的重要性,今后要多多提高提高动手能力。

计算机图形学课程设计——扫雷游戏程序设计

计算机图形学课程设计——扫雷游戏程序设计

《计算机图形学》课程设计报告 VC++扫雷游戏的程序设计 专业班级: 小组成员:

指导老师: 日期:2012年12月24日 1、需求分析 本课程设计实现类似于Windows XP操作系统自带的扫雷游戏。该设计以V isual C++ 6.0为开发环境, Windows 7/XP为程序运行平台。在程序设计中,把整个雷区看成一个二维数组,把雷方块定义为具有所在雷区二维数组的行和列、当前状态、方块属性、历史状态的结构体,采用了MFC机制解决问题的方法。整个游戏程序包括了布雷、扫雷过程和结果三个阶段,在处理鼠标响应事件中伴随着GDI绘图。程序通过调试运行,实现简单的设计目标,满足扫雷游戏初学者的需要。 通过本课程设计,以便更好的巩固计算机图形学相关知识,掌握课程设计基本的方法和技巧,同时增加同学之间的团队合作精神以及培养分析问题、解决问题的能力。 2.总体设计 2.1 功能概述 扫雷游戏的游戏界面如图1所示。在这个界面中,由众多面积均等的小方块所组成的区域称之为雷区,雷区的大小由用户设置的游戏等级决定。

图1 游戏开始时,系统会在雷区中随机布下若干个地雷。安放地雷的小方块称之为雷方块,其他的称之为非雷方块。部署完毕后,系统会在其他非雷方块中填充一些数字。某一个具体数字表示与其紧邻的8个方块 中有多少雷方块。玩家可以根据这些信息去判断是否可以鼠标点击方块, 并把认为是地雷的方块打上标识。当玩家将所有地雷找出后,其余的非雷方块区域都已打开,此时游戏结束。在游戏过程中,一旦错误地打开了雷方块则立即失败,游戏结束。 游戏规则总结: ●开始:按左键开始游戏,按按钮或菜单重新开始。 ●左键:按下时,是雷则结束,非雷则显示数字。 ●数字:代表此数字周围一圈八格中雷的个数。 ●右键:奇次按下表示雷,偶数按下表示对上次的否定。 ●结束:左键按到雷结束,找出全部雷结束。 在游戏开始后,雷区上方有两个计数器。右边的计数器显示用户扫

常用的几种画线方法

常用的几种画线方法成功总结操盘程序 (一)结合均线的金叉点和死叉点画线 以金叉点或者死叉点为基准画水平线。 均线死叉点如果伴随较大的成交量,那么均线死叉点将成为重要压力位。今后股价第一次上升到此时会有阻力。此时应减仓观望。反之,均线金叉点如果伴随较大的成交量,那么均线金叉点将成为重要支撑位。今后股价第一次下跌到此时获得支撑的可能性较大,此时不宜再抛股票。股价向上突破均线死叉点,回落调整时,此均线死叉点位又转变成支撑位。可在死叉点和金叉点处画水平直线,以观察股价走势。 (二)黄金分割法 一般软件画线工具中都有黄金分割画线工具,使用很简单,这里我不再多说。 利用黄金分割画线的关键是找基准点,常用的是最高点和最低点。 (三)股价高点低点连线 (四)跳空缺口处水平线 (五)前期支撑位连线及压力位连线

A线是高点之间连线与地点之间连线的平行线。 B线是点1的水平线(支撑线),股价跌破B线后反弹到点2处受阻回落B线转变成压力线,在点3处突破(30分钟K线回调确认)又变成支撑线。 C线是下跳空缺口处的水平线。 D线是前期高点之间的连线。 E线(黄线)是点6的水平线(支撑线),股价跌破E线后反弹到点8处受阻回落B线转变成压力线。 F线是4,5,6的连线(支撑线),股价跌破F线后反弹到点8处受阻回落F线转变成压力线。 (六)关键K线的黄金点处水平线

2)头肩顶形态 头肩顶形态是有非常大杀伤力的头部形态之一。在实际操盘过程中宁可信其有不可信其无,股票卖了还能再买,套牢就只能做旁观者。研判头肩顶形态要和成交量结合起来。一般情况下,左肩量最大,头部量次之,右肩量最小。

计算机图形学基础教程实验报告

湖北民族学院信息工程学院实验报告 (数字媒体技术专业用) 班级:0312413姓名:谌敦斌学号:031241318实验成绩: 实验时间:2013年10 月14 日9、10 节实验地点:数媒实验室课程名称:计算机图形学基础教程实验类型:设计型 实验题目:直线与圆的绘制 一、实验目的 通过本次实验,熟练掌握DDA、中点、Bresenham直线绘制方法和中点、Bresenham圆的画法,能够在vc环境下独立完成实验内容,逐渐熟悉opengl的语法特点,提高程序基本绘图的能力。 二、实验环境(软件、硬件及条件) Microsoft vc++6.0 多媒体计算机 三、实验内容 1.从DDA、中点、Bresenham画线法中任选一种,完成直线的绘制。 2.从中点、Bresenham画圆法中任选一种,完成圆的绘制。 四、实验方法与步骤 打开vc++6.0,新建一个工程,再在工程里面建一个.cpp文件,编辑程序,编译连接后执行即可。

程序如下 bresenham画线法: #include #include int bresenham(int x0,int y0,int x1,int y1,int color) { int x,y,dx,dy,e,i; dx=x1-x0; dy=y1-y0; e=-dx; y=y0; for(x=x0;x<=x1;x++) { putpixel(x,y,color); e+=2*dy; if(e>=0) { y++; e-=2*dx; } } return 0; } int main() { initgraph(640,480); bresenham(0,0,500,200,255); while(!kbhit()) { } closegraph(); return 0; } Bresenham画圆法: #include #include int circlepoints(int x,int y,int color) { putpixel(255+x,255+y,color); putpixel(255+y,255+x,color); putpixel(255-x,255+y,color);

计算机图形学实验C++代码

一、bresenham算法画直线 #include #include #include void draw_pixel(int ix,int iy) { glBegin(GL_POINTS); glVertex2i(ix,iy); glEnd(); } void Bresenham(int x1,int y1,int xEnd,int yEnd) { int dx=abs(xEnd-x1),dy=abs(yEnd-y1); int p=2*dy-dx; int twoDy=2*dy,twoDyMinusDx=2*dy-2*dx; int x,y; if (x1>xEnd) { x=xEnd;y=yEnd; xEnd=x1; } else { x=x1; y=y1; } draw_pixel(x,y); while(x

} void myinit() { glClearColor(0.8,1.0,1.0,1.0); glColor3f(0.0,0.0,1.0); glPointSize(1.0); glMatrixMode(GL_PROJECTION); glLoadIdentity(); gluOrtho2D(0.0,500.0,0.0,500.0); } void main(int argc,char **argv ) { glutInit(&argc,argv); glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB); glutInitWindowSize(500,500); glutInitWindowPosition(200.0,200.0); glutCreateWindow("CG_test_Bresenham_Line example"); glutDisplayFunc(display); myinit(); glutMainLoop(); } 二、中点法绘制椭圆 #include #include #include inline int round(const float a){return int (a+0.5);} void setPixel(GLint xCoord,GLint yCoord) { glBegin(GL_POINTS); glVertex2i(xCoord,yCoord); glEnd(); } void ellipseMidpoint(int xCenter,int yCenter,int Rx,int Ry) { int Rx2=Rx*Rx; int Ry2=Ry*Ry; int twoRx2=2*Rx2; int twoRy2=2*Ry2; int p; int x=0; int y=Ry; int px=0; int py=twoRx2*y; void ellipsePlotPoints(int,int,int,int);

股市K线画线方法及用法

画线方法及用法 一、支撑线和压力线 画法: 将两个或两个以上的相对低点连成一条直线即得到支撑线 将两个或两个以上的相对高点连成一条直线即得到压力线 用法: 1.支撑线和压力线的作用 支撑线又称为抵抗线。当股价跌到某个价位附近时,股价停止下跌,甚至有可能还有回升。这个起着阻止股价继续下跌或暂时阻止股价继续下跌的价格就是支撑线所在的位置。 压力线又称为阻力线。当股价上涨到某价位附近时,股价会停止上涨,甚至回落。这个起着阻止或暂时阻止股价继续上升的价位就是压力线所在的位置。 支撑线和压力线的作用是阻止或暂时阻止股价向一个方向继续运动。同时,支撑线和压力线又有彻底阻止股价按原方向变动的可能。 2.支撑线与压力线相互转化 一条支撑线如果被跌破,那么这个支撑线将成为压力线;同理,一条压力线被突破,这个压力线将成为支撑线。这说明支撑线和压力线的地位不是一成不变的,而是可以改变的,条件是它被有效的足够强大的股价变动突破。 3.支撑线和压力线的确认和印正 一般来说,一条支撑线或压力线对当前影响的重要性有三个方面的考虑,一是股价在这个区域停留时间的长短;二是股价在这个区域伴随的成交量大小;三是这个支撑区域或压力区域发生的时间距离当前这个时期的远近。 二、趋势线 画法: 在上升趋势中,将两个低点连成一条直线,就得到上升趋势线。 在下降趋势中,将两个高点连成一条直线,就得到下降趋势线。 用法: 趋势线是衡量价格波动的方向的,由趋势线的方向可以明确地看出股价的趋势。要得到一条真正起作用的趋势线,要经多方面的验证才能最终确认。首先,必须确实有趋势存在。其次,画出直线后,还应得到第三个点的验证才能确认这条趋势线是有效的。 三、轨道线 画法: 轨道线又称通道线或管道线,是基于趋势线的一种方法。在已经得到了趋势线后,通过第一个峰和谷可以作出这条趋势线的平行线,这条平行线就是轨道线。 用法: 两条平行线组成一个轨道,这就是常说的上升和下降轨道。轨道的作用是限制股价的变动范围。对上面的或下面的直线的突破将意味着有一个大的变化。与突破趋势线不同,对轨道线的突破并不是趋势反向的开始,而是趋势加速的开始。轨道线的另一个作用是提出趋势转向的警报。 四、黄金分割线

计算机图形学课设(含所有程序图文)

计算机图形学课程设计报告 系(院):计算机科学学院 专业班级:信计11102 姓名:吴家兴 学号:201106262 指导教师:严圣华 设计时间:2014.6.16 - 2014.6.26 设计地点:10教机房

(此处目录根据自己情况可以调整改动) 一、课程设计目的 ................................................. 错误!未定义书签。 二、课程设计具体要求..................................... 错误!未定义书签。 三、需求分析与总体设计 ..................................... 错误!未定义书签。 四、详细设计与实现[含关键代码和实现界面] ... 错误!未定义书签。 五、小结......................................................................................... 错误!未定义书签。 一、课程设计目的 计算机图形学课程设计是验证、巩固和补充课堂讲授的理论知识的必要环节,通过上机实验,培养学生的自学能力、动手能力、综合运用知识解决实际问题的能力。要求学生运用计算机图形学理论与技术设计、编写、调试程序并撰写课程设计报告。 二、课程设计具体要求 1.独立完成设计并撰写课程设计报告。 2.在规定时间将程序和设计报告用附件(信计111X班XXX 图形学课设报告.RAR)发送到274548837@https://www.360docs.net/doc/e311566825.html,,并上交纸质打印稿(A4纸10页左右)。 3. 课程设计报告内容包括: (1)列出设计者姓名及本人详细信息、所用开发工具; (2)程序的基本功能介绍; (3)程序实现步骤和关键算法的理论介绍; (4)关键源代码实现说明。(不要打印全部源程序!) (5)程序运行界面截图(3幅左右) (6)课设总结和自我评价。 4.《计算机图形学》课程的知识结构体系: (1)课设为期两周:总学时为40学时,2学分 (2)学生必须完成二维线画图元和二维填充图元两个大功能。二维裁剪和二维图形变换至少实现两个内容。总共不少于10个算法。 (3)程序应做到:通用性、交互性、界面友好性!

计算机图形学 实验一:生成彩色立方体(含源代码)

实验一 实验目的:生成彩色立方体 实验代码://ColorCube1.java import java.applet.Applet; //可以插入html import java.awt.BorderLayout; //窗口采用BorderLayout方式布局import com.sun.j3d.utils.applet.MainFrame; //application import com.sun.j3d.utils.geometry.ColorCube;//调用生成ColorCube的Utility import com.sun.j3d.utils.geometry.Primitive; import com.sun.j3d.utils.universe.*; //观测位置的设置 import javax.media.j3d.*; //核心类 import javax.vecmath.*; //矢量计算 import com.sun.j3d.utils.behaviors.mouse.*; public class ColorCube1 extends Applet { public BranchGroup createSceneGraph() { BranchGroup objRoot=new BranchGroup(); //BranchGroup的一个对象objRoot(放置背景、灯光)BoundingSphere bounds=new BoundingSphere(new Point3d(0.0,0.0,0.0),100.0);//有效范围 TransformGroup objTrans=new TransformGroup(); objTrans.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE); objTrans.setCapability(TransformGroup.ALLOW_TRANSFORM_READ); objRoot.addChild(objTrans); MouseRotate behavior = new MouseRotate(); behavior.setTransformGroup(objTrans); objRoot.addChild(behavior); behavior.setSchedulingBounds(bounds); MouseZoom behavior2 = new MouseZoom(); behavior2.setTransformGroup(objTrans); objRoot.addChild(behavior2); behavior2.setSchedulingBounds(bounds); MouseTranslate behavior3 = new MouseTranslate(); behavior3.setTransformGroup(objTrans); objRoot.addChild(behavior3); behavior3.setSchedulingBounds(bounds);

交易中的重要画线方法及用法

交易中的重要画线方法及用法 一、支撑线和压力线画法: 将两个或两个以上的相对低点连成一条直线即得到支撑线;将两个或两个以上的相对 高点连成一条直线即得到压力线。 1.支撑线和压力线的作用 支撑线又称为抵抗线。当银价跌到某个价位附近时,银价停止下跌,甚至有可能还有回升。这个起着阻止银价继续下跌或暂时阻止银价继续下跌的价格就是支撑线所在的位置。压力线又称为阻力线。当银价上涨到某价位附近时,银价会停止上涨,甚至回落。这个起着阻止或暂时阻止银价继续上升的价位就是压力线所在的位置。支撑线和压力线的作用是阻止或暂时阻止银价向一个方向继续运动。同时,支撑线和压力线又有彻底阻止银价按原方向变动的可能。 2.支撑线与压力线相互转化 一条支撑线如果被跌破,那么这个支撑线将成为压力线;同理,一条压力线被突破,这个压力线将成为支撑线。这说明支撑线和压力线的地位不是一成不变的,而是可以改变的,条件是它被有效的足够强大的银价变动突破。 3.支撑线和压力线的确认和印正 一般来说,一条支撑线或压力线对当前影响的重要性有三个方面的考虑: 一是银价在这个区域停留时间的长短; 二是银价在这个区域伴随的成交量大小; 三是这个支撑区域或压力区域发生的时间距离当前这个时期的远近。 二、趋势线画法: 在上升趋势中,将两个低点连成一条直线,就得到上升趋势线。在下降趋势中,将两个高点连成一条直线,就得到下降趋势线。 用法: 趋势线是衡量价格波动方向的,由趋势线的方向可以明确地看出银价的趋势。要得到一条真正起作用的趋势线,要经多方面的验证才能最终确认。首先,必须确实有趋势存在。其次,画出直线后,还应得到第三个点的验证才能确认这条趋势线是有效的。 三、轨道线画法: 轨道线又称通道线或管道线,是基于趋势线的一种方法。在已经得到了趋势线后,通过第一个峰和谷可以作出这条趋势线的平行线,这条平行线就是轨道线。 用法: 两条平行线组成一个轨道,这就是常说的上升和下降轨道。轨道的作用是限制银价的变动范围。对上面的或下面的直线的突破将意味着有一个大的变化。与突破趋势线不同,对轨道线的突破并不是趋势反向的开始,而是趋势加速的开始。轨道线的另一个作用是提出趋势转向的警报。

计算机图形学 图形的几何变换的实现算法教程文件

计算机图形学图形的几何变换的实现算 法

实验二 图形的几何变换的实现算法 班级 08信计 学号 59 姓名 分数 一、实验目的和要求: 1、掌握而为图形的基本几何变换,如平移,旋转,缩放,对称,错切变换;。 2、掌握OpenGL 中模型变换函数,实现简单的动画技术。 3、学习使用OpenGL 生成基本图形。 4、巩固所学理论知识,加深对二维变换的理解,加深理解利用变换矩阵可由简单图形得到复杂图形。加深对变换矩阵算法的理解。 编制利用旋转变换绘制齿轮的程序。编程实现变换矩阵算法,绘制给出形体的三视图。调试程序及分析运行结果。要求每位学生独立完成该实验,并上传实验报告。 二、实验原理和内容: . 原理: 图像的几何变换包括:图像的空间平移、比例缩放、旋转、仿射变换和图像插值。 图像几何变换的实质:改变像素的空间位置,估算新空间位置上的像素值。 图像几何变换的一般表达式:[,][(,),(,)]u v X x y Y x y = ,其中,[,]u v 为变换后图像像素的笛卡尔坐标, [,]x y 为原始图像中像素的笛卡尔坐标。这样就得到了原始图像与变换后图像的像素的对应关系。 平移变换:若图像像素点 (,)x y 平移到 00(,)x x y y ++,则变换函数为 0(,)u X x y x x ==+, 0(,)v Y x y y y ==+,写成矩阵表达式为: 00x u x y v y ??????=+???????????? 其中,x 0和y 0分别为x 和y 的坐标平移量。 比例缩放:若图像坐标 (,)x y 缩放到( ,x y s s )倍,则变换函数为:

计算机图形学

1、名词解释:直接设备、间接设备、绝对坐标设备、相对坐标设备、离散设备、连续设备、 回显、约束、网格、引力域、橡皮筋技术、草拟技术、拖动、旋转、形变。 1)直接设备:直接设备指诸如触摸屏一类用户可直接用手指指点屏幕进行操作从而实 现定位的设备。 2)间接设备:指诸如鼠标、操纵杆等用户通过移动屏幕上的光标实现定位的设备。 3)绝对坐标设备:绝对坐标设备包括数字化仪和触摸屏,它们都有绝对原点,定位坐标 相对原点来确定。绝对坐标设备可以改成相对坐标设备,如数字化仪,只要记录当前点位置与前一点位置的坐标差(增量),并将前一点看成是坐标原点,则数字化仪的定位范围也可变成无限大。 4)相对坐标设备:相对坐标设备可指定的范围可以任意大,然而只有绝对坐标设备才能 作为数字化绘图设备。 5)离散设备:键控光标则为离散设备。使用离散设备也难以实现精确定位。 6)连续设备:把手的连续运动变成光标的连续移动,鼠标、操纵杆、数字化仪等均为此 类设备。连续设备比离散设备更自然、更快、更容易用,且在不同方向上运动的自由度比离散设备大。使用离散设备也难以实现精确定位。 7)回显:回显作为一种最直接的辅助方式,大部分交互式绘图过程都要求回显。比如 在定位时,用户不仅要求所选的位置可在屏幕上显示出来,还希望其数据参数也在屏幕上显示,这样可以获得精确位置来调整定位坐标。在选择、拾取等过程中,用户也都希望能够直观地看到选择或拾取的对象以便确认。 8)约束:约束是在图形绘制过程中对图形的方向、对齐方式等进行规定和校准。约束 方式有多种,最常用的约束是水平或垂直直线约束,使用户可以轻松地绘制水平和垂直线而不必担心线的末端坐标的精度范围。另外,其他类型的约束技术用于产生

计算机图形学课程教学大纲

《计算机图形学》课程教学大纲一、课程基本信息 课程代码:110053 课程名称:计算机图形学 英文名称:Computer Graphics 课程类别:专业课 学时:72 学分: 适用对象:信息与计算科学专业本科生 考核方式:考试(平时成绩占总成绩的30%) 先修课程:高级语言程序设计、数据结构、高等代数 二、课程简介 中文简介: 计算机图形学是研究计算机生成、处理和显示图形的学科。它的重要性体现在人们越来越强烈地需要和谐的人机交互环境:图形用户界面已经成为一个软件的重要组成部分,以图形的方式来表示抽象的概念或数据已经成为信息领域的一个重要发展趋势。通过本课程的学习,使学生掌握计算机图形学的基本原理和基本方法,理解图形绘制的基本算法,学会初步图形程序设计。 英文简介: Computer Graphics is the subject which concerned with how computer builds, processes and shows graphics. Its importance has been shown in people’s more and more intensively need for harmony human-machine interface. Graphics user interface has become an important part of software. It is a significant trend to show abstract conception or data in graphics way. Through the learning of this course, students could master Computer Graphics’basic theories and methods,understand graphics basic algorithms and learn how to design basic graphics program. 三、课程性质与教学目的 《计算机图形学》是信息与计算科学专业的一门主要专业课。通过本课程的学习,使学生掌握基本的二、三维的图形的计算机绘制方法,理解光栅图形生成基本算法、几何造型技术、真实感图形生成、图形标准与图形变换等概念和知识。学会图形程序设计的基本方法,为图形算法的设计、图形软件的开发打下基础。 四、教学内容及要求 第一章绪论 (一)目的与要求 1.掌握计算机图形学的基本概念; 2.了解计算机图形学的发展、应用; 3.掌握图形系统的组成。

计算机图形学显示变换算法具体程序实现

数学与软件科学学院实验报告 学期:___2010 至_2011 第__一__ 学期2010年12月21日课程名称:____计算机图形学 _____ 专业:__信息与计算科学_ 2007级_5_班实验编号: 07 实验项目_____显示变换__ 指导教师__庞朝阳_ 姓名:学号: 20070605 __ 实验成绩:_____ 实验目的: (1) 了解掌握显示变换的相关知识,知道什么是平行投影和透视投影; 实验内容: (1) 知道显示变换是什么; (2) 掌握平行投影变换; (3) 掌握透视投影变换; (4) 编写并执行简单的Prolog程序,并熟悉测试或调试的方法。 实验步骤: (1)显示变换 三维空间中的物体要在二维的屏幕显示出来,必须通过投影的方式把三维物体转换成二维的平面图形。投影的方式有平行投影,透视投影。 平行投影变换 (2)平行投影变换 平行投影可根据投影方向与投影面的夹角分为:正投影和斜投影。当投影方向与投影面垂直时,为正投影;否则为斜投影。 A.正投影 1.假设投影平面垂直于Z轴,且位于Z=Z0外,则在视坐标系中任意一点 (X,Y,Z)的投影是过该点的投影线与投影平面的交点,如下图: P(x,y,z) p`(x`,y`,z`) Z0 Z 则空间点的坐标与投影坐标间关系为: x`=x , y`=y , z`=z 即 ` ` ` 1 x y z = 000 0100 0000 0001 Z . 1 x y z 2.

`` ` 1 x y z = 1000010000000001 . 1 x y z 即平面投影的变换矩阵为: Mz (平)= 10000 100 00000 1 同理可得: 在y0z 平面的投影变换矩阵为: Mx(平) = 00000 10000000001 在x0z 平面的投影变换矩阵为: My(平) = 10000 00000100 2.斜投影 如下图 求空间中任意一点D (x,y,z )在斜面ABC 上的投影。 Step1:确定一定Q,并过P 作斜面的法向量n 。 X Z Y A C B P

计算机图形学常用算法及代码大全

2.1.1 生成直线的DDA算法 数值微分法即DDA法(Digital Differential Analyzer),是一种基于直线的微分方程来生成直线的方法。 一、直线DDA算法描述: 设(x1,y1)和(x2,y2)分别为所求直线的起点和终点坐标,由直线的微分方程得 可通过计算由x方向的增量△x引起y的改变来生成直线: 也可通过计算由y方向的增量△y引起x的改变来生成直线: 式(2-2)至(2-5)是递推的。 二、直线DDA算法思想: 选定x2-x1和y2-y1中较大者作为步进方向(假设x2-x1较大),取该方向上的增量为一个象素单位(△x=1),然后利用式(2-1)计算另一个方向的增量(△y=△x·m=m)。通过递推公式(2-2)至(2-5),把每次计算出的(x i+1,y i+1)经取整后送到显示器输出,则得到扫描转换后的直线。 之所以取x2-x1和y2-y1中较大者作为步进方向,是考虑沿着线段分布的象素应均匀,这在下图中可看出。 另外,算法实现中还应注意直线的生成方向,以决定Δx及Δy是取正值还是负值。 三、直线DDA算法实现: 1、已知直线的两端点坐标:(x1,y1),(x2,y2) 2、已知画线的颜色:color 3、计算两个方向的变化量:dx=x2-x1 dy=y2-y1 4、求出两个方向最大变化量的绝对值: steps=max(|dx|,|dy|) 5、计算两个方向的增量(考虑了生成方向): xin=dx/steps

yin=dy/steps 6、设置初始象素坐标:x=x1,y=y1 7、用循环实现直线的绘制: for(i=1;i<=steps;i++) { putpixel(x,y,color);/*在(x,y)处,以color色画点*/ x=x+xin; y=y+yin; } 五、直线DDA算法特点: 该算法简单,实现容易,但由于在循环中涉及实型数的运算,因此生成直线的速度较慢。 //@brief 浮点数转整数的宏 实现代码 #define FloatToInteger(fNum) ((fNum>0)?static_cast(fNum+0.5):static_cast(fNum-0.5)) /*! * @brief DDA画线函数 * * @param pDC [in]窗口DC * @param BeginPt [in]直线起点 * @param EndPt [in]直线终点 * @param LineCor [in]直线颜色 * @return 无 */ void CDrawMsg::DDA_DrawLine(CDC *pDC,CPoint &BeginPt,CPoint &EndPt,COLORREF LineCor) { l ong YDis = (EndPt.y - BeginPt.y); l ong XDis = (EndPt.x-BeginPt.x); l ong MaxStep = max(abs(XDis),abs(YDis)); // 步进的步数 f loat fXUnitLen = 1.0f; // X方向的单位步进 f loat fYUnitLen = 1.0f; // Y方向的单位步进

计算机图形学实验--完整版-带结果--vc++实现

计算机图形学实验报告信息学院计算机专业20081060183 周建明 综括: 利用计算机编程语言绘制图形,主要实现以下内容: (1)、中点算法生成任意斜率直线,并设置线型线宽。 (2)、中点算法生成圆 (3)、中点算法生成椭圆 (4)、扫描算法实现任意多边形填充 (5)、Cohen_Sutherland裁剪 (6)、自由曲线与曲面的绘制 (7)、二维图形变换 (8)、三视图变换 实验一、直线的生成 一、实验内容 根据提供的程序框架,修改部分代码,完成画一条直线的功能(中点画线法或者Bresenham画线法任选一),只要求实现在第一象限内的直线。 二、算法原理介绍 双击直线生成.dsw打开给定的程序,或者先启动VC++,文件(file)→打开工作空间(open workspace)。打开直线生成view.cpp,按注释改写下列函数: 1.void CMyView::OnDdaline() (此为DDA生成直线) 2.void CMyView::OnBresenhamline()(此为Bresenham画直线) 3.void CMYView::OnMidPointLine()(此为中点画线法) 三、程序源代码 1.DDA生成直线画法程序: float x,y,dx,dy,k; dx=(float)(xb-xa); dy=(float)(yb-ya); k=dy/dx; x=xa; y=ya;

if(abs(k)<1) { for (x=xa;x<=xb;x++) { pdc->SetPixel(x, int(y+0.5),COLOR); y=y+k; } } if(abs(k)>=1) { for(y=ya;y<=yb;y++) { pdc->SetPixel(int(x+0.5),y,COLOR); x=x+1/k; } } //DDA画直线结束 } 2.Bresenham画直线源程序: float b,d,xi,yi; int i; float k; k=(yb-ya)/(xb-xa); b=(ya*xb-yb*xa)/(xb-xa); if(k>0&&k<=1) for(i=0;i=0) { xi=xa+1; yi=ya; xa++; ya=ya+0.5; } if(d<0) { xi=xa+1; yi=ya+1; xa++; ya=ya+1.5; } pdc->SetPixel(xi,yi,COLOR); }

计算机图形学_有效边表算法源代码

#include #include #include #include #define EPSILON 0.000001 //最小浮点数 //点结构体 struct Point { int x; //x坐标 int y; //y坐标 }; //线结构体 struct Line { Point high_point; //高端点 Point low_point; //低端点 int is_active; //是否为有效边,水平边(0),非水平边(1) double inverse_k; //斜率k的倒数 }; //边结点 struct EdgeNode { double x; //扫描线与边交点的x坐标(边的低端点的x坐标)int y_max; //边的高端点的y坐标ymax double inverse_k; //斜率k的倒数 EdgeNode *next; //下一个边结点的指针 }; //有效边表 struct ActiveEdgeTable { int y; //扫描线y EdgeNode *head; //边链表的头指针 }; //桶结点 typedef struct Bucket { int y; //扫描线y EdgeNode *head; //边链表的头指针

Bucket *next; //下一个桶的指针 } EdgeTable; int compare(Point p1, Point p2); Line* create_lines(Point points[], int n); Point get_lowest_point(Line lines[], int n); Point get_highest_point(Line lines[], int n); void swap(Line &l1, Line &l2); void sort(Line lines[], int n); EdgeTable* create_edge_table(Line lines[], int n); ActiveEdgeTable* init_active_table(EdgeTable *edge_table); void delete_edge(ActiveEdgeTable *active_table, int y_max); void add_edge(ActiveEdgeTable *active_table, EdgeNode edge); ActiveEdgeTable* update_active_table(ActiveEdgeTable *active_table, EdgeTable *edge_table); void DrawPolygon(Point points, int n); void DrawGrid(int x, int y); void Fill(Point points[], int n); void Initial(); void Display(); int main(int argc, char* argv[]) { glutInit(&argc, argv); glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB); glutInitWindowSize(400, 300); glutInitWindowPosition(100, 120); glutCreateWindow("Polygon Filling"); glutDisplayFunc(Display); Initial(); glutMainLoop(); return 0; } //比较2个点的高度 int compare(Point p1, Point p2) { if (p1.y > p2.y) return 1; else if (p1.y == p2.y) return 0; return -1; }

计算机图形学简单画图代码

软件:NetBeans 图形效果: 代码: package newpackage; import java.awt.*; import javax.swing.*; import java.awt.geom.*; import java.awt.image.*; import https://www.360docs.net/doc/e311566825.html,.URL; import java.io.*; import javax.imageio.*; import java.awt.event.*; import java.util.Calendar; import javax.swing.*; public class Hello2D extends JApplet { public static void main(String s[]) { JFrame frame = new JFrame(); frame.setTitle("计算机图形学"); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); JApplet applet = new Hello2D(); applet.init(); frame.getContentPane().add(applet); frame.pack(); frame.setVisible(true); }

public void init() { JPanel panel = new Hello2DPanel(); getContentPane().add(panel); } } class Hello2DPanel extends JPanel implements ActionListener{ private BufferedImage image; AffineTransform rotH = new AffineTransform(); AffineTransform rotM = new AffineTransform(); AffineTransform rotS = new AffineTransform(); // AffineTransform zuq=new AffineTransform (); public Hello2DPanel() { setPreferredSize(new Dimension(1400,1000)); setBackground(Color.white); Timer timer=new Timer(500,this); timer.start(); URL url=getClass().getClassLoader().getResource("images/zuqiu.jpg"); try{ image=ImageIO.read(url); }catch(IOException ex) { ex.printStackTrace(); } } @Override public void paintComponent(Graphics g) { super.paintComponent(g); Graphics2D g2= (Graphics2D)g; g2.translate(100,100); g2.scale(0.5, 0.5); for (int i = 0; i < 12; i++) { g2.rotate(2*Math.PI/12); g2.fill3DRect(-3, -180, 6, 30, true); }

相关文档
最新文档