计算机图形学画圆算法源程序

合集下载

画圆环算法c程序

画圆环算法c程序

画圆环算法c程序全文共四篇示例,供读者参考第一篇示例:画圆环是计算机图形学中常见的基本图形之一,常用于游戏开发、动画制作等领域。

在计算机中,画圆环的算法有多种,其中最常用的是中点画圆算法。

本文将介绍使用C语言实现中点画圆算法的程序,并进行详细分析和讲解。

1. 算法原理中点画圆算法是一种简单而高效的算法,其基本原理是通过逐渐逼近圆形的方法,利用对称性和中点的位置进行迭代计算。

具体步骤如下:(1)给定圆的半径r和圆心坐标(x0, y0),设置初始点P(0, r)作为起点,并计算判别式d=1-r。

(2)在每次迭代中,分别取直线y=x和y=-x两侧的中点,分别计算两种情况下的判别式值,并根据判别式值的大小决定下一个中点的位置。

(3)重复进行上述步骤,直到计算完整个圆的一周。

2. C程序实现下面是使用C语言实现中点画圆算法的程序代码:```c#include <stdio.h>#include <graphics.h>void plot_circle_points(int x0, int y0, int x, int y) { // 绘制圆的八个对称点putpixel(x0 + x, y0 + y, WHITE);putpixel(x0 - x, y0 + y, WHITE);putpixel(x0 + x, y0 - y, WHITE);putpixel(x0 - x, y0 - y, WHITE);putpixel(x0 + y, y0 + x, WHITE);putpixel(x0 - y, y0 + x, WHITE);putpixel(x0 + y, y0 - x, WHITE);putpixel(x0 - y, y0 - x, WHITE);}void midpoint_circle(int x0, int y0, int r) { int x = 0, y = r;int d = 1 - r;plot_circle_points(x0, y0, x, y); while (x < y) {if (d < 0) {d = d + 2 * x + 3;x++;} else {d = d + 2 * (x - y) + 5;x++;y--;}plot_circle_points(x0, y0, x, y);}}delay(5000);closegraph();return 0;}```以上是一个简单的使用C语言实现中点画圆算法的程序代码。

计算机图形学--圆的生成算法的实现

计算机图形学--圆的生成算法的实现
运行结果为: Line().exe
三、实验结果分析 1、显示圆上的 8 个对称点的算法如下:
void CirclePoints(int x,int y,int color) {
putpixel(x,y,color); putpixel(y,x,color); putpixel(-x,y,color); putpixel(y,-x,color); putpixel(x,-y,color); putpixel(-y,x,color); putpixel(-x,-y,color); putpixel(-y,-x,color); }
2 ) 7+ 3 2 7( 2 1)
5=2R-3R/
2
5(2R-3R/ 2 )/(R/ 2 ) 4.8
通过实际的程序运行进行比较,结论是中点画圆法速度比较快, 就算法本身而言,该算法仍可以在某些方面进行改进,如其中的浮点 运算改为整数运算等,执行速度将更快。生成直线和圆这类基础算法 在编程时要被无数次的调用,可能每生成一帧画面就要被调用成百上 千次,因此其执行速度是至关重要的。而这类基础算法的长度都很短, 即使多用一些分支,多用一些变量和语句,一般来说只不过是增加几 十个语句,这样的空间增加与算法极其重要的速度来比较是相对次要 的因素。因此在开发图形学的基础算法时,如果有可能提高算法的速 度,应不惜多占用一些存储空间。
2
{ int i,j; for(i=-n/2;i<=n/2;i++) for(j=-n/2;j<=n/2;j++) putpixel(x+j,y+i,color);
} void putpixelt(int x,int y,int color,int i) {int a[8]={1,1,1,1,0,0,0,0}; if(a[i%8])putpixel(x,y,color); } void EllipsePoints(int x,int y,int color) { putpixel(xo+x,yo+y,color);

【计算机图形学】基本图形元素:圆的生成算法

【计算机图形学】基本图形元素:圆的生成算法

【计算机图形学】基本图形元素:圆的⽣成算法圆的特征圆被定义为到给定中⼼位置(xc,yc)距离为r的点集。

圆⼼位于原点的圆有四条对称轴x=0,y=0, x=y和x=-y。

若已知圆弧上⼀点(x,y),可以得到其关于四条对称轴的其它7个点,这种性质称为⼋分对称性。

因此,只要扫描转换⼋分之⼀圆弧,就可以求出整个圆弧的象素集。

显⽰圆弧上的⼋个对称点的算法:void CirclePoints(int x,int y,int color){ Putpixel(x,y,color); Putpixel(y,x,color);Putpixel(-x,y,color); Putpixel(y,-x,color);Putpixel(x,-y,color); Putpixel(-y,x,color);Putpixel(-x,-y,color); Putpixel(-y,-x,color);}中点画圆算法果我们构造函数 F(x,y)=x2+y2-R2,则对于圆上的点有F(x,y)=0,对于圆外的点有F(x,y)>0,对于圆内的点F(x,y)<0 。

与中点画线法⼀样,构造判别式:d=F(M)=F(xp+1,yp-0.5)=(xp+1)2+(yp-0.5)2-R2若 d<0,则应取P1为下⼀象素,⽽且再下⼀象素的判别式为:d=F(xp+2,yp-0.5)=(xp+2)2+(yp-0.5)2-R2=d+2xp+3若d≥0,则应取P2为下⼀象素,⽽且下⼀象素的判别式为d=F(xp+2,yp-1.5)=(xp+2)2+(yp-1.5)2-R2=d+2(xp-yp)+5我们这⾥讨论的第⼀个象素是(0,R),判别式d的初始值为:d0=F(1,R-0.5)=1.25-R【算法流程图】【算法代码】void PaintArea::drawCircleMiddle(QPainter &painter,const QPoint ¢er, int r) {int x,y,deltax,deltay,d;x=0;y=r;deltax=3;deltay=2-3-3;d=1-r;while(x<y){if(d<0){d+=deltax;deltax+=2;x++;}else{d+=(deltax+deltay);deltax+=2;deltay+=2;x++;y++;}painter.drawPoint(center.x()+x,center.y()+y);painter.drawPoint(center.x()+x,center.y()-y);painter.drawPoint(center.x()-x,center.y()+y);painter.drawPoint(center.x()-x,center.y()-y);painter.drawPoint(center.x()+y,center.y()+x);painter.drawPoint(center.x()+y,center.y()-x);painter.drawPoint(center.x()-y,center.y()+x);painter.drawPoint(center.x()-y,center.y()-x);}}Bresenham画圆算法思想参见直线的Bresenham画法【算法流程图】【算法代码】void PaintArea::drawCircleBresenham(QPainter &painter,const QPoint ¢er, int r) {int x,y,delta,delta1,delta2,direction;x=0;y=r;delta=2*(1-r);while(y>=0){painter.drawPoint(x,y);if(delta<0){ delta1=2*(delta+y)-1;if(delta1<=0)direction=1; else direction=2; }else if(delta>0){ delta2=2*(delta-x)-1;if(delta2<=0)direction=2; else direction=3; }else direction=2;switch(direction){case 1:x++;delta+=2*x+1; break;case 2:x++; y--; delta+=2*(x-y+1); break;case 3:y--;delta+=(-2*y+1); break;}}}椭圆弧⽣成算法基本同圆弧算法,只是⽅程变得复杂F(x,y)=(bx)^2+(ay)^2-(ab)^2.对称性:4分对称,画第⼀象限分段依据:斜率为⼀点上段圆弧:下段圆弧:【椭圆中点算法流程图】【算法代码】void PaintArea::drawEllipseMiddle(QPainter &painter,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,x=0,y=Ry,px=0,py=twoRx2*y;void ellipsePlotPoints(QPainter&,int,int,int,int);ellipsePlotPoints(painter,xCenter,yCenter,x,y);//Region1p=round(Ry-(Rx2*Ry)+(0.25*Rx2));while(px<py){x++;px+=twoRy2;if(p<0)p+=Ry2+px;else{y--;py-=twoRx2;p+=Ry2+px-py;}ellipsePlotPoints(painter,xCenter,yCenter,x,y);}//Region2p=round(Ry2*(x+0.5)*(x+0.5)+Rx2*(y-1)*(y-1)-Rx2*Ry2);while(y>0){y--;py-=twoRx2;if(p>0)p+=Rx2-py;else{ x++;px+=twoRy2;p+=Rx2-py+px;}ellipsePlotPoints(painter,xCenter,yCenter,x,y);}}void ellipsePlotPoints(QPainter &painter,int xCenter,int yCenter,int x,int y){ painter.drawPoint(xCenter+x,yCenter+y);painter.drawPoint(xCenter-x,yCenter+y);painter.drawPoint(xCenter+x,yCenter-y);painter.drawPoint(xCenter-x,yCenter-y);}软件截图这个绘图软件是⽤QT写的,我会另外写⼀篇介绍编程结构,待续~转载请注明出处:。

Bresenham算法画圆并填充实验报告 09009202 陶园

Bresenham算法画圆并填充实验报告 09009202 陶园

计算机图形学实验报告实验二Bresenham算法画圆并填充学号:09009202 姓名:陶园成绩:东南大学计算机科学与工程学院二〇一一年十一月一.实验题目Bresenham算法画圆并填充二.算法思想1.首先,真实的线条是连续的,但是计算机中的线条是离散的,是由很多点组成的,那么画线的重点就是如何高效地找到这些离散的点来更好地画出想要的图形。

2.实验要求用Bresenham算法实现画圆。

那么首先先要了解Bresenham算法是一种什么算法。

经过查阅,我找到Bresenham直线算法和画圆算法。

直线是圆的基础。

Bresenham直线算法是用来描绘由两点所决定的直线的算法,它会算出一条线段在 n 维光栅上最接近的点。

这个算法只会用到较为快速的整数加法、减法和位元移位,常用于绘制电脑画面中的直线。

是计算机图形学中最先发展出来的算法。

Bresenham画圆算法又称中点画圆算法,与Bresenham 直线算法一样,其基本的方法是利用判别变量来判断选择最近的像素点,判别变量的数值仅仅用一些加、减和移位运算就可以计算出来。

为了简便起见,考虑一个圆心在坐标原点的圆,而且只计算八分圆周上的点,其余圆周上的点利用对称性就可得到。

Bresenham直线算法流程图圆的八对称性所以,只需要知道圆上的一个点的坐标 (x, y) ,利用八对称性,就能得到另外七个对称点的坐标。

和直线算法类似,Bresenham画圆算法也是用一系列离散的点来近似描述一个圆。

Bresenham画圆算法的流程图三.源代码#include "stdlib.h"#include "math.h"#include <gl/glut.h>//按坐标画点void draw(GLint xCoord, GLint yCoord){glBegin(GL_POINTS);//以点的形式glVertex2i(xCoord, yCoord);//在(xCoord, yCoord)坐标下画点glEnd();glFlush();//强制刷新}void Circle(GLint x,GLint y){int a=abs(x);//将x的绝对值赋给aint b=abs(y);//将y的绝对值赋给bint c=a*-1;//使c=a的相反数int d=b*-1;//使d=b的相反数draw(x, y); draw(y, x);draw(-x, y); draw(y, -x);draw(x, -y); draw(-y, x);draw (-x, -y); draw(-y, -x);//按照圆的对称性以圆心为对称点将四个象限的圆周画出for(int i=c;i<=a;i++){for(int j=d;j<=b;j++){draw(i,j);}}//以a,b,c,d为边界用点填充该圆}//主函数void BresenhamCircle(GLint r){int d, d1, d2, direct;GLint x,y;x=0;y=r;d = 2*(1-r);while(y>=0){Circle(x,y);if(d < 0){d1 = 2* (d+ y) -1;if(d1 <=0)direct = 1;elsedirect = 2;}else{if( d > 0){d2 = 2*(d-x)-1;if(d2 <= 0)direct = 2;elsedirect = 3;}elsedirect = 2;}switch(direct){case 1:x++;d+=2*x + 1;break;case 2:x++; y--;d+=2*(x-y+1) + 1;break;case 3:y--;d+=-2*y + 1;break;}}}void RenderScene(void){BresenhamCircle(50);//主函数调用}//当窗口大小改变时由GLUT函数调用void ChangeSize(GLsizei width, GLsizei Height){GLfloat aspectRatio;if (Height == 0){Height = 1;}glViewport(0, 0, width, Height);//指定视口矩形左下角glMatrixMode(GL_PROJECTION);//指定当前矩阵,对投影矩阵应用随后的矩阵操glLoadIdentity();// 装载单位矩阵aspectRatio = (GLfloat)width / (GLfloat) Height;if (width <= Height){glOrtho(-100.0, 100.0, -100.0 / aspectRatio, 100.0 / aspectRatio, 1.0, -1.0);}else{glOrtho(-100.0 * aspectRatio, 100.0 * aspectRatio, -100.0, 100.0, 1.0, -1.0);}glMatrixMode(GL_MODELVIEW);//指定当前矩阵,对模型视景矩阵堆栈应用随后的矩阵操作glLoadIdentity();// 装载单位矩阵}//主程序入口void main(void){glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);//设置初始显示模式,指定单缓存窗口,指定RGB 颜色模式的窗口glutCreateWindow("圆");//创建窗口,窗口名称为“圆”glutDisplayFunc(RenderScene);//进行画图glutReshapeFunc(ChangeSize);//重画回调函数glutMainLoop();//进入GLUT事件处理循环,让所有的与“事件”有关的函数调用无限循环}四.结果截屏五.出现问题及解决方案1.对于如何填充整个圆一开始没有好的方法,后来决定每画一个点,就将该横坐标的所有纵坐标点画出,从下到上,整个填充圆从中间到两边形成。

计算机图形学圆的生成

计算机图形学圆的生成
假设M是E和SE的中点,即 ,则:
1、当F(M)<0时, M在圆内(圆弧A),说明点E距离圆更近,应取E点; 2、当F(M)>0时, M在圆外(圆弧B),表明SE点离圆更近,应取SE点; 3、当F(M)=0时, 在E点与SE点之中任取一个即可,我们约定取SE点。
2.2.3 中点画圆算法思想
我们用中点M的圆函数作为决策变量di,同时用增量法来迭 代计算下一个中点M的决策变量di+1。
2.2.5 中点画圆程序
F(x,y) <0 点(x,y)位于数学圆内 =0 点(x,y)位于数学圆上 >0 点(x,y)位于数学圆外
, 假定当前取点为Pi(xi,yi),如果顺 时针生成圆,那么下一点只能取正 右方的点E(xi+1,yi)或右下方的点 SE(xi+1,yi-1)两者之一。
(2-8)
生成圆的初始条件和圆的生成方向
2.2.4 中点画圆算法实现
1、输入:圆半径r、圆心(x0,y0); 2、确定初值:x=0,y=r、d=5/4-r; 3、While(x<=y) { circlePoints (x,y,color); if(d≥0) { y--; d=d+2(x-y)+5; } else d=d+2x+3; x++; }
2.2 圆的生成
这里仅讨论圆心位于坐标原点的圆的扫描转 换算法,对于圆心不在原点的圆,可先用平 移变换,将它的圆心平移到原点,然后进行 扫描转换,最后再平移到原来的位置。
2.2.1 圆的八分对称性
八分对称性: 圆心位于原点的圆有四条对称轴x=0、y=0、x=y和x=-y, 若 已知圆弧上一点P(x,y),就可得到其关于四条对称轴的七个对称点。因 此只要能画出八分之一的圆弧,就可以用对称性的原理得到整个圆弧。

12864液晶屏上画圆算法函数(源代码)

12864液晶屏上画圆算法函数(源代码)
第四象限
二、中心点画圆(算法 2)
/**************************************************/ //函数名称:draw_circle(int x0,int y0,int r,int colour) //函数功能:在 12864 液晶屏上画圆(已知圆心和半径) //返回值:无 //(x0,y0)为圆心,r 为半径 /**************************************************/ void draw_circle(int x0,int y0,int r,int colour) { int x,y; float d; x=0; y=r; d=1.25-r; while(x<=y) { draw_point(x0+x,y0+y,colour); draw_point(x0+x,y0-y,colour); draw_point(x0-x,y0+y,colour); draw_point(x0-x,y0-y,colour); draw_point(x0+y,y0+x,colour); draw_point(x0+y,y0-x,colour); draw_point(x0-y,y0+x,colour); draw_point(x0-y,y0-x,colour); if(d<0) d+=x*2.0+3; else { d+=2.0*(x-y)+5; y--; } x++; } }
一、中心点画圆(算法 1)
/**************************************************/ //函数名称:draw_circle(uchar x0,uchar y0,uchar r) //函数功能:在 12864 液晶屏上画圆(已知圆心和半径) //返回值:无(不带 colour 变量) //(x0,y0)为圆心,r 为半径 /**************************************************/ void draw_circle(uchar x0,uchar y0,uchar r) { uint xx,rr,x,y,rs,col,row;//col:列 row:行 y=r; rr=r*r+1; //补偿 1 修正方形 rs=(y+(y>>1))>>1; //(*0.75)分开 1/8 圆弧来画 for (x=0;x<=rs;x++) { xx=x*x; while ((y*y)>(rr-xx)) y--; col=x0+x; //第一象限 row=y0-y; draw_point(col,row,1); col=x0-x; //第二象限 draw_point(col,row,1); row=y0+y; //第三象限 draw_point(col,row,1); col=x0+x; //第四象限 draw_point(col,row,1); /***************45 度镜象画另一半***************/ col=x0+y; row=y0-x; draw_point(col,row,1); col=x0-y; draw_point(col,row,1); row=y0+x; draw_point(col,row,1); col=x0+y; draw_point(col,row,1); } } //第一象限

c++ 圆形算法

c++ 圆形算法

在C++中,绘制圆形需要使用一些基本的几何和数学公式。

如果你想在一个二维平面上绘制一个圆形,你可以使用极坐标系中的公式:r = ρ * cos(θ)r = ρ * sin(θ)其中,ρ是半径,θ是角度(通常从0到2π)。

如果你想要在一个像素矩阵(例如二维数组)上绘制一个圆形,你可能需要写一个循环,检查每个像素是否在圆内。

以下是一个简单的C++代码示例,它在N*N的二维数组上绘制一个圆心在(N/2, N/2)的圆形。

该圆形的半径是N/2-1。

```cpp#include <iostream>#include <vector>void drawCircle(std::vector<std::vector<int>>& matrix, int n) {for (int i = 0; i < n; ++i) {for (int j = 0; j < n; ++j) {double distance = std::sqrt((i - n / 2) * (i - n / 2) + (j - n / 2) * (j - n / 2));if (distance <= n / 2 - 1) {matrix[i][j] = 1; // Set the pixel to be in the circle} else {matrix[i][j] = 0; // Set the pixel to be outside the circle}}}}int main() {int n = 5; // Define the size of the circlestd::vector<std::vector<int>> matrix(n, std::vector<int>(n, 0)); // Initialize a n*n matrix with zerosdrawCircle(matrix, n); // Draw the circle// Now you can print the matrix or do something elsewith it.return 0;}```这个代码会创建一个N*N的二维数组,并使用上述算法将数组中的每个元素设置为1(如果该点在圆内)或0(如果该点在圆外)。

计算机图形学圆弧生成算法具体程序实现

计算机图形学圆弧生成算法具体程序实现
y=r;
e=1-r;
this->CirclePoints(x,y,color,pDC);
while(x<=y)
{
if(e<0)
{
e+=2*x+3;
}
else
{
e+=2*(x-y)+5;
y--;
}
x++;
this->CirclePoints(x,y,color,pDC);
}
}
实验结果:
六:椭圆的绘制
(1):基本原理
while(dx<dy)
{
x++;
dx+=twobb;
if(d<0)
{
d+=bb+dx;
}
else
{
dy-=twoaa;
d+=bb+dx-dy;
y--;
}
pDC->SetPixel(xc+x,yc+y,color);
pDC->SetPixel(xc+x,yc-y,color);
pDC->SetPixel(xc-x,yc+y,color);
d =F(1,b-0.5)= b + a (b-0.5) -a b
= b + a (-b+0.25)
其中,每一步的迭代过程中需要随时的计算和比较从上部分转入下部分的条件是否成立,从而将逼近方向由x改为y。
2.代码实现及结果:
#include "math.h"
class CCircle
{
protected:
}
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
相关文档
最新文档