.
.....
实验报告
班级 计算机科学与技术 姓名 学号
2014 年 6 月 2 日
《计算机图形学》
.
实验一 基本图形生成算法
一、实验目的:
1、掌握中点Bresenham绘制直线的原理; 2、设计中点Bresenham算法;
3、掌握八分法中点Bresenham算法绘制圆的原理; 4、设计八分法绘制圆的中点Bresenham算法;
5、掌握绘制1/4椭圆弧的上半部分和下半部分的中点Bresenham算法原理; 6、掌握下半部分椭圆偏差判别式的初始值计算方法; 7、设计顺时针四分法绘制椭圆的中点Bresenham算法。 二、实验过程:
1、实验描述
实验1:使用中点Bresenham算法绘制斜率为0<=k<=1的直线。
实验2:使用中点Bresenham算法绘制圆心位于屏幕客户区中心的圆。 实验3:使用中点Bresenham算法绘制圆心位于屏幕客户区中心的椭圆。
2、实验过程
1)用MFC(exe)建立一个单文档工程;
2)编写对话框,生成相应对象,设置相应变量;
3)在类CLineView中声明相应函数,并在相关的cpp文件中实现; 4)在OnDraw()函数里调用函数实现绘制直线、圆、椭圆; 5)运行程序,输入相应值,绘制出图形。
三、源代码
实验1:直线中点Bresenham算法
1.// cline.cpp : implementation file // cline dialog
cline::cline(CWnd* pParent /*=NULL*/) : CDialog(cline::IDD, pParent) {
//{{AFX_DATA_INIT(cline) m_x0 = 0; m_y0 = 0; m_x1 = 0; m_y1 = 0;
//}}AFX_DATA_INIT }
void cline::DoDataExchange(CDataExchange* pDX)
.....
.
{
CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(cline)
DDX_Text(pDX, IDC_x0, m_x0); DDX_Text(pDX, IDC_y0, m_y0); DDX_Text(pDX, IDC_x1, m_x1); DDX_Text(pDX, IDC_y1, m_y1); //}}AFX_DATA_MAP }
BEGIN_MESSAGE_MAP(cline, CDialog) //{{AFX_MSG_MAP(cline) //}}AFX_MSG_MAP END_MESSAGE_MAP()
2、// LineView.h
class CLineView : public CView {
public:
CLineDoc* GetDocument(); ..........
void Mbline(double,double,double,double); //直线中点Bresenham函数
.......
}
3、// Line.cpp
//*******************直线中点Bresenham函数*********************/
void CLineView::Mbline(double x0, double y0, double x1, double y1) {
CClientDC dc(this);
COLORREF rgb=RGB(0,0,255); //定义直线颜色为蓝色 double x,y,d,k;
x=x0; y=y0; k=(y1-y0)/(x1-x0); d=0.5-k; for(x=x0;x<=x1;x++) {
dc.SetPixel((int)x,(int)y,rgb); if(d<0) {
y++;
.....