青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 87  文章 - 279  trackbacks - 0
<2007年4月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 220431
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

昨晚去圖書館看了《計算機圖形學——OpenGL實現》關于Bresenham算法的另一種推導方式。
Bresenham最精妙之處在于通過方程變換,然后得到迭代方程,從而消除了浮點運算。

下面簡單寫寫自己對中點法推導的理解:

記:W = bx - ax, H = by - ay
         所以 (ax, ay)和(bx, by)的理想直線為:
         -W*(y-ay) + H*(x-ax) = 0

記:函數 f(x, y) = -2*W*(y-ay) + 2*H*(x-ax);
         f(x,y)有如下性質:
         f(x, y) < 0, 那么(x, y)在直線上方
         f(x, y) > 0, 那么(x, y)在直線下方

現考慮 點L(Px+1, Py), 點U(Px+1, Py+1), 則LU中點M(Px+1, Py+1/2) 有:
         如果f(Mx, My) < 0, 則M在理想直線上方, 所以選擇L
         如果f(Mx, My) > 0, 則M在理想直線下方, 所以選擇U
則:
         f(Mx,My) = -2*w*(Py+1/2-ay) + 2*H*(Px+1-ax)
當 x從Px+1移動到Px+2時, 考慮f變化M'和M'':
         M':在前一步沒有增加y, M' = (Px+2, Py+1/2)
         M'':在前一步增加了y, M' = (Px+2, Py+3/2)
對于 M':
         f(M'x, M'y) = -2*w*(Py+1/2-ay) + 2*H*(Px+2-ax) = f(Mx, My) + 2 * H
對于 M'':
         f(M''x, M''y) = -2*w*(Py+3/2-ay) + 2*H*(Px+2-ax) = f(Mx, My) - 2 * (W-H)
所以
         對于下一個“測試量”都有一個常數增量:前一次沒有增加y,增量為2*H,如果增加了y,則增量為-2*(W-H)

對于初始條件:x = ax, y = ay
         M = (ax+1, ay+1/2);
         f(Mx, My) = -2*W*(ay+1/2-ay) + 2*H(ax+1-ax) = 2*H-W

Code:
#include <stdlib.h>
#include 
<math.h>
#include 
<GL/glut.h>

void myInit() {
    glClearColor(
1.01.01.00.0);
    glColor3f(
0.00.00.0);
    
//glPointSize(2.0);
    glMatrixMode(GL_PROJECTION);
    glLoadIdentity();
    gluOrtho2D(
0.0640.00.0480.0);
}


void setPixel(int x, int y) {
    glBegin(GL_POINTS);
    glVertex2i(x, y);
    glEnd();

}


void lineBres(int xs, int ys, int xe, int ye) {
    
int W = xe - xs, H = ye - ys, f = 2 * H - W, tH = 2 * H, tHW = 2 * (H - W);
    
int x, y;
    
if (xs > xe) {
        x 
= xe;
        y 
= ye;
        xe 
= xs;
    }
 else {
        x 
= xs;
        y 
= ys;            
    }

    
while (x <= xe) {
        setPixel(x, y);
        x
++;
        
if (f<0{
            f 
+= tH;
        }
 else {
            y
++;
            f 
+= tHW;
        }

    }

}


void myDisplay() {
    glClear(GL_COLOR_BUFFER_BIT);
    lineBres(
2010300180);
    glFlush();
}


int main(int argc, char **argv) {
    glutInit(
&argc, argv);
    glutInitDisplayMode(GLUT_SINGLE
|GLUT_RGB);
    glutInitWindowSize(
640480);
    glutInitWindowPosition (
100150);
    glutCreateWindow(
"Bresenham畫線");
    glutDisplayFunc(myDisplay);
    myInit();
    glutMainLoop();
    
return 0;
}

         
posted on 2007-10-11 11:57 閱讀(1166) 評論(0)  編輯 收藏 引用 所屬分類: 計算機圖形學

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产婷婷成人久久av免费高清 | 免费观看日韩av| 亚洲综合三区| 欧美成人一区二区三区片免费 | 久久精品卡一| 日韩亚洲在线| 国产亚洲制服色| 99精品福利视频| 精品av久久707| 久久久久高清| 午夜精品999| 亚洲精品韩国| 国产精品一区一区| 一本色道久久综合亚洲精品婷婷 | 欧美精品久久一区二区| 亚洲国产乱码最新视频| 亚洲综合第一页| 久久精品九九| 黄色精品免费| 最新国产成人在线观看| 亚洲毛片一区二区| 午夜精品美女自拍福到在线| 久久久国产一区二区三区| 免播放器亚洲| 日韩午夜电影在线观看| 欧美亚洲综合久久| 欧美精品一区二区在线观看 | 国产精品麻豆欧美日韩ww| 国产一区二区三区无遮挡| 欧美在线国产| 久久aⅴ国产欧美74aaa| 亚洲国产精品成人| 欧美一级夜夜爽| 一区二区日韩伦理片| 欧美高清免费| 国产一区二区久久| 亚洲图片在区色| 免费观看成人www动漫视频| 一区二区三区欧美在线观看| 久久综合999| 国外成人免费视频| 亚洲欧美日韩视频二区| 亚洲欧洲一区二区在线观看| 久久久久久久性| 国产伦精品一区二区三区在线观看 | 久久一本综合频道| 日韩视频一区二区三区在线播放| 久久九九国产精品| 国产精品久久久久影院色老大 | 中日韩美女免费视频网址在线观看| 一道本一区二区| 国内精品久久久久久久影视麻豆| 一区二区精品国产| 亚洲国产视频一区| 免费成人黄色片| 精品成人乱色一区二区| 久久久久久久综合色一本| 一区二区三区四区国产| 日韩手机在线导航| 欧美福利视频在线| 国产一区激情| 欧美日韩理论| 一区二区三区av| 亚洲黄色天堂| 欧美高潮视频| 在线视频一区观看| 一本色道婷婷久久欧美| 免费在线欧美黄色| 久久最新视频| 最近中文字幕mv在线一区二区三区四区 | 香蕉久久久久久久av网站| 国产精品国产一区二区| 亚洲天堂av综合网| 一区久久精品| 在线观看欧美精品| 欧美激情中文字幕一区二区 | 一区二区三区日韩欧美精品| 欧美日韩国产黄| 亚洲免费在线播放| 欧美伊人影院| 亚洲福利视频免费观看| 欧美国产一区二区| 欧美日韩精品在线观看| 午夜精品福利在线| 久久久av毛片精品| 亚洲久久一区二区| 亚洲淫性视频| 伊伊综合在线| 欧美大片免费| 亚洲国产精品悠悠久久琪琪| 毛片精品免费在线观看| 亚洲精品中文字| 亚洲一区二区三区中文字幕在线| 国产一区二区三区av电影 | 久久精品色图| 欧美91福利在线观看| 亚洲综合色激情五月| 欧美在线啊v| av成人福利| 久久国产精品久久精品国产| 在线天堂一区av电影| 美国十次了思思久久精品导航| 亚洲精品一区在线观看| 午夜精品在线| 在线一区二区三区四区| 欧美影院一区| 亚洲午夜国产一区99re久久| 久久精选视频| 欧美亚洲免费在线| 欧美区日韩区| 国语自产偷拍精品视频偷| 亚洲欧美国产高清| 久久在线免费观看| 午夜日韩av| 欧美精品国产精品| 久久久久久久999| 国产精品久久中文| 亚洲免费av网站| 免费在线成人| 欧美在线免费观看视频| 欧美激情bt| 欧美不卡视频| 亚洲欧洲99久久| 免播放器亚洲一区| 国产精品午夜电影| 亚洲色诱最新| 中文在线不卡视频| 欧美激情在线狂野欧美精品| 乱人伦精品视频在线观看| 国产情人综合久久777777| 亚洲视频一区二区| 亚洲国产精品久久91精品| 国产欧美日韩视频在线观看| 日韩视频不卡| 一区二区不卡在线视频 午夜欧美不卡在| 久久久国产91| 免费的成人av| 亚洲国产精品毛片| 女女同性精品视频| 亚洲国产精品久久久久秋霞不卡 | 国产精品一区二区女厕厕| 亚洲欧洲视频在线| 99国产精品久久| 欧美日韩一区二区三区四区在线观看 | 欧美高清视频一二三区| 一区二区三区我不卡| 久久久欧美一区二区| 蜜桃av久久久亚洲精品| 在线不卡欧美| 欧美极品欧美精品欧美视频| 亚洲精品你懂的| 亚洲国产婷婷香蕉久久久久久| 久久久久国内| 久久综合色88| 亚洲国产成人av好男人在线观看| 美女精品国产| 国产亚洲欧美一区在线观看| 美女尤物久久精品| 亚洲精品中文字幕有码专区| 欧美精品一区二区在线观看 | 久久久国产视频91| 欧美二区在线观看| 夜久久久久久| 国产精品视频福利| 久久中文在线| 亚洲深夜激情| 免费av成人在线| 亚洲性视频h| 黄色综合网站| 亚洲精品久久久久| 国产日韩欧美高清| 精品不卡视频| 老司机精品久久| 亚洲国产一区二区精品专区| 亚洲午夜免费福利视频| 国产欧美va欧美va香蕉在| 久久精品国产免费观看| 亚洲国产va精品久久久不卡综合| 亚洲一区二区视频在线| 国产自产精品| 欧美日韩国产大片| 久久精品国产久精国产思思| 亚洲精品在线三区| 开心色5月久久精品| 亚洲一区二区精品在线| 亚洲国产精品一区制服丝袜| 日韩一区二区免费高清| 欧美一区免费| 欧美精品免费播放| 亚洲欧美日韩一区二区三区在线观看| 国产亚洲一区二区三区在线观看 | 亚洲高清av在线| 国产精品乱子久久久久| 欧美a级在线| 久久成人一区| 亚洲欧美不卡| 在线亚洲美日韩| 亚洲国产cao| 免费视频一区二区三区在线观看| 午夜日本精品|