Opengl圆弧绘制算法(Bresenham画圆、角度离散法绘制圆弧、中点画圆)

1.Bresenham画圆
在这里插入图片描述

#include<gl/glut.h>
#include<math.h>

void SetPixel(int x, int y)//画点
{
    glColor3f(1.0f, 0.0f, 0.0f);
    glBegin(GL_POINTS);
    glVertex2i(x, y);
    glEnd();
}


//8路对称
void Cirpot(int x0, int y0, int x, int y)
{
    SetPixel((x0 + x), (y0 + y));//第1象限,90度至45度
    SetPixel((x0 + y), (y0 + x));//第1象限,45度至0度
    SetPixel((x0 + y), (y0 - x));//第4象限,0度至-45度
    SetPixel((x0 + x), (y0 - y));//第4象限,-45度至-90度
    SetPixel((x0 - x), (y0 - y));//第3象限
    SetPixel((x0 - y), (y0 - x));
    SetPixel((x0 - y), (y0 + x));//第2象限
    SetPixel((x0 - x), (y0 + y));
}



void Bres_Circle(int x0, int y0, double r)//x0,y0为圆心,r为半径
{
    int x, y, d;
    //考虑圆心在原点处,第一个点(x,y)位于90度的y轴上
    x = 0;
    y = (int)r;
    d = int(3 - 2 * r); //递推初值
    for (; x <= y; x++) //从90度到45度
    {
        Cirpot(x0, y0, x, y); //画点,同时画8个对称的点,若圆心不在原点处,平移还原

        i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值