OpenGL中Bresenham画线算法,就是画不出东西。麻烦大神帮忙看看

57_Viking 2015-12-17 09:37:23
//------------Bresenham画线算法---------------------
//--------------by D_Viking-------------------------
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<GL/glut.h>



/*Bresenham line-drawing procedure for |m|<1.0 */
void init(void){
glClearColor(1.0, 1.0, 1.0, 0.0);//Set display-window color to white.
glMatrixMode(GL_PROJECTION);//Set projection parameters.
gluOrtho2D(0.0, 550.0, 0.0, 550.0);
}

void setPixel(GLint x, GLint y){
glClear(GL_COLOR_BUFFER_BIT | GL_COLOR_BUFFER_BIT);


glBegin(GL_POINTS);
glColor3f(1, 0, 0);//Set line segment color to green.
glVertex2i(x, y);
glPointSize(9);//绘制前设置点的大小和颜色
glEnd();
glFlush();
}

void lineBres(){
int x0, y0, xEnd, yEnd;
//scanf_s("%d", &x0); scanf_s("%d", &xEnd); scanf_s("%d", &y0); scanf_s("%d", ¥d);
x0 = 60; y0 = 300; xEnd = 100; yEnd = 400;
glClear(GL_COLOR_BUFFER_BIT);//Clear display window.

glColor3f(1, 0, 0);//Set line segment color to green.
int dx = (int)fabs((float)xEnd - x0), dy = (int)fabs((float)yEnd - y0);
int p = 2 * dy - dx;
int twoDy = 2 * dy, twoDyMinusDx = 2 * (dy - dx);
int x, y;
/*Determine which endpoint to use as start position.*/

if (x0 > xEnd){
x = xEnd;
y = yEnd;
xEnd = x0;
}
else
{
x = x0;
y = y0;
}
setPixel(x, y);
while (x < xEnd){
x++;
if (p < 0)
p += twoDy;
else
{
y++;
p += twoDyMinusDx;
}
setPixel(x, y);
}
}

void main(int argc, char** argv){
glutInit(&argc, argv);//Initialize GLUT.
glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);//Set display mode.
glutInitWindowPosition(50, 100);//Set top-left display-window position.
glutInitWindowSize(400, 300);//Set display-window width and height.
glutCreateWindow("Bresenham画线算法");//Create display window.

init();//Execute initialization procedure.
glutDisplayFunc(lineBres);//Send graphics to display window.

glutMainLoop();//Display everything and wait.
}
...全文
82 1 打赏 收藏 转发到动态 举报
写回复
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
fly_dragon_fly 2015-12-18
  • 打赏
  • 举报
回复
没有设置modelview矩阵, 稍微向z-偏一点
相关推荐
课程解决的问题: 作为游戏行业或者图形学从业者,你是否面临以下问题: 到底openGL底层如何实现的? 到底矩阵操作变换是怎么做到的? 到底光栅化的算法以及原理是什么? 到底如何才能从3D世界投射到2D屏幕呢? 图形学有这么多的矩阵操作,到底如何推导如何应用呢? 学完这门课程,你应该就可以从底层了解一个初级的openGL图形接口如何实现,图形学最底层的封装到底面临哪些挑战;跟随我们一行一行写完代码,你就会得到一个迷你版本的openGL图形库,你可以深度体会图形从模型变换,观察矩阵变换,投影矩阵变换一直到光栅化纹理操作的全套模拟流程。 课程介绍: 本课程将带领学员不使用任何图形库,实现从0到1的图形学接口封装以及算法讲解,并且带领大家手敲代码,一行一行进行实现。 涵盖了(环境搭建,绘制点,Bresenham算法绘制完美直线,三角形拆分绘制算法,颜色插值算法,图片操作,图片二次插值放缩算法,纹理系统接口搭建及封装,矩阵操作理论以及实践,openGL类似接口封装,3D世界的图形学理论及接口封装等) 最终将带领大家通过C++实现一个3D世界的图形接口,方便所有人入门图形学,进行接下来的openGL接口以及GPU编程的学习   本课程为系列课程的第一步入门,且带领所有人进行实现,更加实用,可以让大家打牢图形学的基础知识及编程技能

3,880

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 其它技术问题
社区管理员
  • 其它技术问题社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告