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

隨筆 - 87  文章 - 279  trackbacks - 0
<2006年1月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 220433
  • 排名 - 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>
            久久人人九九| 永久域名在线精品| 亚洲一区国产精品| 欧美国产视频在线观看| 欧美一区午夜精品| 欧美亚洲视频一区二区| 欧美成人久久| 在线视频你懂得一区| 欧美大片专区| 亚洲破处大片| 亚洲二区在线观看| 国产精品久久综合| 亚洲国产午夜| 久久免费视频网站| 夜夜夜精品看看| 国产精品qvod| 欧美伦理一区二区| 亚洲美女中文字幕| 亚洲图片在线| 午夜精品久久久久久久99热浪潮| 欧美在线1区| 久久婷婷国产综合精品青草| 亚洲福利一区| 一本到12不卡视频在线dvd| 亚洲视频专区在线| 欧美一级在线视频| 欧美精品999| 国产区亚洲区欧美区| 精品99一区二区三区| 蜜臀va亚洲va欧美va天堂| 免费成人激情视频| 欧美激情精品久久久六区热门| 亚洲国产精品久久久久| 亚洲免费在线精品一区| 欧美连裤袜在线视频| 亚洲日本欧美在线| 久久精品日韩一区二区三区| 91久久精品国产91久久性色| 欧美一级专区免费大片| 国产精品视频免费观看| 一区二区不卡在线视频 午夜欧美不卡在 | 在线播放豆国产99亚洲| 亚洲一区二区三区欧美| 欧美激情视频一区二区三区免费| 久久免费视频这里只有精品| 欧美三级免费| 亚洲图中文字幕| 亚洲日本欧美| 国产精品久久福利| 久久久精品国产一区二区三区 | 亚洲欧美视频在线| 国产精品国产自产拍高清av王其| 亚洲手机在线| 久久国产精品色婷婷| 日韩视频在线观看| 亚洲午夜av| 在线观看成人av| 亚洲精品社区| 国产亚洲一区在线| 亚洲激情成人在线| 国内精品**久久毛片app| 亚洲欧洲精品一区二区精品久久久 | 亚洲国产91| 欧美日韩日本国产亚洲在线| 久久久999精品视频| 欧美+日本+国产+在线a∨观看| 99国产精品| 亚洲乱码国产乱码精品精天堂| 亚洲午夜一区二区| 一本久道久久综合中文字幕| 久久九九精品99国产精品| 午夜精品免费在线| 国产精品无码专区在线观看 | 亚洲精品欧洲| 久久九九国产精品怡红院| 欧美精品日日鲁夜夜添| 欧美在线观看一区二区三区| 18成人免费观看视频| 免费中文日韩| 午夜在线电影亚洲一区| 亚洲最新中文字幕| 国产精品国产精品| 久久久www免费人成黑人精品| 欧美一区2区视频在线观看 | 亚洲午夜精品国产| 久久国产精品一区二区三区四区 | 日韩视频中文字幕| 久久精品视频一| 亚洲午夜性刺激影院| 欧美视频一区二区在线观看| 亚洲区欧美区| 亚洲尤物在线视频观看| 国产精一区二区三区| 久热re这里精品视频在线6| 欧美一区三区三区高中清蜜桃| 欧美日韩国产探花| 亚洲性感美女99在线| 亚洲一区二区在| 国产精品美女一区二区在线观看| 亚洲日本中文字幕免费在线不卡| 亚洲激情成人在线| 欧美激情一区三区| av不卡在线| 久久国产精品久久w女人spa| 在线欧美日韩| 国产精品一级久久久| 久久久久欧美精品| 午夜国产精品视频| 亚洲欧美国产精品va在线观看| 亚洲男女自偷自拍图片另类| 欧美日韩在线精品一区二区三区| 亚洲高清视频一区| 在线视频日韩精品| 亚洲精品一区二区三| 韩国v欧美v日本v亚洲v| 欧美日韩一区综合| 国产精品久久| 欧美1区2区3区| 亚洲午夜久久久久久久久电影院 | 欧美一区二区女人| 亚洲精品乱码久久久久久黑人 | 亚洲日本va午夜在线影院| 亚洲国产欧美在线| 久久综合给合久久狠狠狠97色69| 91久久视频| 欧美国产先锋| 久久深夜福利免费观看| 亚洲午夜国产成人av电影男同| 亚洲韩国青草视频| 日韩视频国产视频| 亚洲午夜女主播在线直播| 在线亚洲自拍| 欧美日韩在线免费视频| 久久久精品国产99久久精品芒果| 一个色综合导航| 日韩视频免费在线| 日韩视频在线一区| 午夜日韩激情| 欧美成人激情视频| 国产精品国产三级欧美二区| 国产日产亚洲精品系列| 国产日产高清欧美一区二区三区| 国产精品久久午夜| 欧美精品v国产精品v日韩精品| 新67194成人永久网站| 亚洲免费综合| 欧美不卡视频一区发布| 欧美精品一区二区三区很污很色的 | 久久久久久久91| 欧美黄色一区二区| 亚洲制服少妇| 欧美不卡福利| 黄色综合网站| 久久精品女人| av不卡在线| 久久本道综合色狠狠五月| 女仆av观看一区| 国产精品一区二区久久久| 亚洲国产乱码最新视频| 久久夜色精品| 久久久99爱| 在线成人性视频| 欧美在线观看日本一区| 国产欧美日韩一区二区三区| 99re热这里只有精品视频| 久久久噜噜噜| 另类春色校园亚洲| 亚洲日本aⅴ片在线观看香蕉| 久久综合99re88久久爱| 欧美日韩久久| 亚洲视频图片小说| 最新中文字幕一区二区三区| 毛片一区二区| 亚洲三级电影全部在线观看高清| 欧美激情网友自拍| 国产精品久在线观看| 欧美va日韩va| 欧美女同视频| 亚洲一区图片| 亚洲一线二线三线久久久| 国产精品视频不卡| 欧美国产日韩二区| 国产精品手机视频| 亚洲高清三级视频| 国产乱码精品一区二区三区忘忧草| 宅男精品视频| 亚洲欧美日韩一区在线| 国产一区二区成人| 日韩视频三区| 亚洲四色影视在线观看| 欧美精品久久99| 久久精品系列| 欧美日韩亚洲国产精品| 久久免费视频网| 国产日韩在线播放| 午夜精品福利一区二区蜜股av| 国产精品99久久久久久久女警 | 欧美日韩在线一区| 久久久噜噜噜久久久| 国产精品你懂的在线欣赏|