自学计算机图形学OpenGL(五)DDA数值微分线段法
生活随笔
收集整理的這篇文章主要介紹了
自学计算机图形学OpenGL(五)DDA数值微分线段法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?DAA算法流程:
1.有了起始點(x1,y1)和終點(xn,yn)
2.△x=|xn-x1|,△y=|yn-y1|
3.比較△x和△y的大小
4.steps=△x和△y的大者
5.stepx=△x/steps,stepy=△y/steps
#include <glut.h> #include<math.h>void myDDA(GLfloat xl, GLfloat y1, GLfloat xn, GLfloat yn) {float dx = fabs(xn - xl);float dy = fabs(yn - y1);float steps;//步長if (dx > dy)steps = dx;elsesteps = dy;float stepX = dx / steps;float stepY = dy / steps;glBegin(GL_POINTS);//畫點//畫線for (int i = 0; i < (int)steps; i++){glVertex2f(xl, y1);xl += stepX;y1 += stepY;}glEnd(); }//繪制函數 void myDisplay() {glClear(GL_COLOR_BUFFER_BIT);glPointSize(1);glColor3f(0.9, 0.5, 0.8);myDDA(1.5, 3.8, 189.8, 267.5);glFlush(); }void init() {glClearColor(1.0, 1.0, 1.0, 0.0);glMatrixMode(GL_PROJECTION);glLoadIdentity();gluOrtho2D(0, 600, 0, 500); }void main(int argc, char** argv) {glutInit(&argc, argv);glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB); //設置顯示模式glutInitWindowSize(300, 200); //設置窗口大小glutInitWindowPosition(600, 500); //設置窗口在屏幕上的位置 glutCreateWindow("DAA application"); //創建窗口并給出標題init();glutDisplayFunc(myDisplay);glutMainLoop(); //消息循環(處理操作系統等的消息,例如鍵盤、鼠標事件等) }?
總結
以上是生活随笔為你收集整理的自学计算机图形学OpenGL(五)DDA数值微分线段法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 比Office365、WPS更好用的最新
- 下一篇: ChatGPT150个指令大全