qq_44882950 2019-04-10 21:14 采纳率: 0%
浏览 200

求助大佬 ,,,,如何将以下程序生成的图片以bmp格式保存在任意盘

图片说明

#include
#include
const int POINTNUM = 6;
typedef struct XET
{
float x;
float dx, ymax;
XET* next;
}AET, NET;
struct point
{
float x;
float y;
}
polypoint[POINTNUM] = { 20,30,70,10,130,50,130,110,70,70,20,90,};
void PolyScan()
{
int MaxY = 0;
int i;
for (i = 0; i < POINTNUM; i++)
{
if (polypoint[i].y > MaxY)
MaxY = polypoint[i].y;
}
AET *pAET = new AET;
pAET->next = NULL;

NET *pNET[1024];
for (i = 0; i <= MaxY; i++)
{
pNET[i] = new NET;
pNET[i]->next = NULL;
}
glClear(GL_COLOR_BUFFER_BIT);
glColor3f(1, 0, 1);
glBegin(GL_POINTS);

for (i = 0; i < MaxY; i++) //扫描建立NET表
{
for (int j = 0; j < POINTNUM; j++)
{
if (polypoint[j].y == i)
{
if (polypoint[(j - 1 + POINTNUM) % POINTNUM].y > polypoint[j].y)
{
NET *p = new NET;
p->x = polypoint[j].x;
p->ymax = polypoint[(j - 1 + POINTNUM) % POINTNUM].y;
p->dx = (polypoint[(j - 1 + POINTNUM) % POINTNUM].x - polypoint[j].x) / (polypoint[(j - 1 + POINTNUM) % POINTNUM].y - polypoint[j].y);
p->next = pNET[i]->next;
pNET[i]->next = p;
}
if (polypoint[(j + 1 + POINTNUM) % POINTNUM].y > polypoint[j].y)
{
NET *p = new NET;
p->x = polypoint[j].x;
p->ymax = polypoint[(j + 1 + POINTNUM) % POINTNUM].y;
p->dx = (polypoint[(j + 1 + POINTNUM) % POINTNUM].x - polypoint[j].x) / (polypoint[(j + 1 + POINTNUM) % POINTNUM].y - polypoint[j].y);
p->next = pNET[i]->next;
pNET[i]->next = p;
}
}
}
}
for (i = 0; i <= MaxY; i++) //建立更新活性边表
{
NET *p = pAET->next;
while (p)
{
p->x = p->x + p->dx;
p = p->next;
}

AET *tq = pAET;             //AET按照X值从小到大排序
p = pAET->next;
tq->next = NULL;
while (p)
{
    while (tq->next && p->x >= tq->next->x)
        tq = tq->next;
    NET *s = p->next;
    p->next = tq->next;
    tq->next = p;
    p = s;
    tq = pAET;
}


AET *q = pAET;              //从AET中删除ymax == i的结点
p = q->next;
while (p) 
{
    if (p->ymax == i) 
    {
        q->next = p->next;
        delete p;
        p = q->next;
    }
    else
    {
        q = q->next;
        p = q->next;
    }
}


p = pNET[i]->next;          //将NET中的新点加入AET,并用插入法按X值递增排序
q = pAET;
while (p)
{
    while (q->next && p->x >= q->next->x)
        q = q->next;
    NET *s = p->next;
    p->next = q->next;
    q->next = p;
    p = s;
    q = pAET;
}


p = pAET->next;               //颜色填充         
while (p && p->next)
{
    for (float j = p->x; j <= p->next->x; j++) 
    {
        glVertex2i(static_cast<int>(j), i);
    }
    p = p->next->next;
}

}
glEnd();
glFlush();
}
void init()
{
glClearColor(1.0, 1.0, 1.0, 1.0);
glMatrixMode(GL_PROJECTION);
gluOrtho2D(0, 200,0,200);
}
int main(int argc, char* argv)
{
glutInit(&argc, &argv);
glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);
glutInitWindowPosition(0, 0);
glutInitWindowSize(800,800);
glutCreateWindow(" OpenGL ");
init();
glutDisplayFunc(PolyScan);
glutMainLoop();
}

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 求差集那个函数有问题,有无佬可以解决
    • ¥15 【提问】基于Invest的水源涵养
    • ¥20 微信网友居然可以通过vx号找到我绑的手机号
    • ¥15 寻一个支付宝扫码远程授权登录的软件助手app
    • ¥15 解riccati方程组
    • ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
    • ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
    • ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
    • ¥50 树莓派安卓APK系统签名
    • ¥65 汇编语言除法溢出问题