91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

OpenGL中點Bresenham怎么繪制直線算法

發布時間:2021-05-19 10:43:20 來源:億速云 閱讀:297 作者:小新 欄目:編程語言

這篇文章主要介紹OpenGL中點Bresenham怎么繪制直線算法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

具體內容如下

環境

macos xcode編譯器

代碼

#include <GLUT/GLUT.h>
#include <iostream>
#include<iostream>
#include<cstdlib>
#include<ctime>
using namespace std;
float wid = 400;  //設置窗口的大小,約定窗口必須為正方形
float height = wid; //設置窗口的大小
int numbers = 20; //設置劃分的網格的個數
float t = wid/numbers; //模擬像素下的單位1
/*
 參數設置說明:
 輸入直線的兩點A(x1,y1);B(x2,y2)
 您應當確保參數范圍在-400~400.且為整數。
 *支持不同斜率
 *支持兩點位置顛倒
 */
int x1 = -300,y1=-400,x2 =400,y2 = 100;
void draw_point(float x, float y,int k_kind,int d_kind);
float translater(int x);
void swap(int &a, int &b)
{ int tmp = 0;
 tmp = b;
 b = a;
 a = tmp; }
void bresenham(int x1, int y1,int x2, int y2){
 /*
 函數說明:bresenham算法部分
 參數說明:與openGL已有的劃線函數一樣,要求用戶提供的是點的起點(x1,y1)和終點(x2,y2)
 為了便于觀察,我們會繪制原像素下的直線。
 這里的坐標要求是-1 ~ 1
 */
 int k_kind = 0; //k_kind用來表示斜率的類型。0是0~1;1是1~無窮;2是0~-1;3是負無窮~-1
 int d_kind =0; //d_kind用來表示dy正負的類型。
 if (x1 > x2) {
 swap(x1,x2);
 swap(y1,y2);
 }
 int dx = abs(x2-x1), dy = abs(y2-y1);
 if (y1 > y2) {//如果是向下的
 y1 = -y1;
 y2 = -y2;
 d_kind = 1;
 }
 if (dy > dx) { //斜率介于1~無窮的,將看作坐標系變換(這里將坐標變換)。
 swap(x1, y1);
 swap(x2,y2);
 swap(dx,dy);
 k_kind = 1;
 }
 float d = (dy +dy -dx)*t; //令d為決策量(這里利用d = dx*w*2避免浮點運算)
 float x = x1+0.0,y = y1+0.0;
 draw_point(translater(x),translater(y),k_kind,d_kind); //繪制下一個點
 while( x < x2){  //以x為步長
 if (d < 0){
  d += 2*dy*t;
 }
 else{
  d += 2*(dy-dx)*t;
  y += t; //說明應該畫在上面那個位置
 }
 x= x + t;
 draw_point(translater(x),translater(y),k_kind,d_kind); //繪制下一個點
 }
}
float translater(int x){
 /*
 函數說明:將像素坐標下的坐標轉化為openGL坐標
 參數說明:傳入點像素坐標-wid-wid,返回-1~1坐標
 */
 return x/wid;
}
void draw_point(float x , float y, int k_kind,int d_kind){
 /*
 函數說明:繪制像素的點,這里將點的大小設置為7。
 顏色采用藍色。
 參數說明:浮點數x,y是openGl坐標系。kind是指明斜率的類型
 */
 glPointSize(7);
 glColor3f(0.0,0.0,1.0);
 glBegin(GL_POINTS);
 cout <<"k:"<<k_kind<<"d:" << d_kind << endl;
 if(k_kind==0&&d_kind==1){
 y = -y;
 }else if (k_kind ==1 &&d_kind==1){
 x= -x;
 swap(x,y);
 }else if (k_kind==1&&d_kind ==0){
 swap(x,y);
 }
 glVertex3f(x,y,0.0);
 glEnd();
 glFlush();
}
void grid(){
 /*
 函數說明:繪制網格為了便于將真實的像素pixel轉化為我們模擬的像素
 */
 glClearColor(0, 0, 0, 0);//這是設置背景色,必須要在glclear之前調用
 glClear(GL_COLOR_BUFFER_BIT);
 //畫直線
 int wid_number = numbers;
 int hei_number = numbers;
 float delta_wid = wid / wid_number;
 float delta_hei = height / hei_number;
 glColor3f(1.0,1.0,0);
 for (int i = 1; i < 40 ; i ++ ) {
 glBegin(GL_LINES);
 glVertex2f(-1+i*delta_hei/height, -1);
 glVertex2f(-1+i*delta_hei/height, 1);
 glVertex2f(-1,-1+i*delta_hei/height);
 glVertex2f(1,-1+i*delta_hei/height);
 glEnd();
 glFlush();
 }
 glColor3f(1.0,0,0);
 glBegin(GL_LINES); //繪制坐標系,便于觀察
 glVertex2f(-1,0);
 glVertex2f(1,0);
 glVertex2f(0,-1);
 glVertex2f(0,1);
 glEnd();
 glFlush();
 glBegin(GL_LINES);
 glColor3f(1.0,0.0,0.0);
 glVertex2f(translater(x1),translater(y1)); //定點坐標范圍
 glVertex2f(translater(x2),translater(y2));
 glEnd();
 glFlush();
 //刷新緩沖,保證繪圖命令能被執行
 bresenham(x1, y1,x2,y2);
}
int main(int argc, char *argv[]) {
 //初始化GLUT library
 glutInit(&argc, argv);
 //對窗口的大小進行初始化
 glutInitWindowSize(700,700);
 glutInitWindowPosition(300,200);
 // 設置窗口出現的位置
 //glutInitWindowPosition(int x, int y);
 glutInitDisplayMode(GLUT_RGBA);
 glutCreateWindow("class16_hw1");
 glutDisplayFunc(&grid);
 glutMainLoop();
 return 0;

以上是“OpenGL中點Bresenham怎么繪制直線算法”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

高台县| 宁蒗| 石河子市| 兴化市| 黄山市| 尚志市| 巴林左旗| 汪清县| 买车| 中山市| 兴城市| 阿合奇县| 光山县| 邢台市| 姚安县| 元江| 泰宁县| 县级市| 安福县| 澄江县| 昔阳县| 临澧县| 华容县| 贺州市| 于田县| 积石山| 沂南县| 封开县| 灵宝市| 苏尼特右旗| 松桃| 兴宁市| 承德市| 长寿区| 忻州市| 宁陕县| 古田县| 嘉义市| 唐河县| 靖州| 新巴尔虎左旗|