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

隨筆 - 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>
            亚洲图片欧美日产| 久久综合狠狠综合久久综青草| 欧美性一区二区| 欧美激情在线免费观看| 欧美刺激午夜性久久久久久久| 久久国产精品毛片| 久久av资源网| 久久久噜噜噜久久人人看| 欧美一级日韩一级| 久久久久免费观看| 免费高清在线视频一区·| 欧美xx69| 国产精品国产自产拍高清av| 国产日本欧美一区二区三区在线 | 欧美国产视频在线| 久久综合给合| 欧美日本中文字幕| 国产精品一区二区欧美| 在线观看亚洲视频啊啊啊啊| 亚洲精品中文字幕在线观看| 亚洲制服av| 免费成人av资源网| 日韩一二三区视频| 午夜精彩国产免费不卡不顿大片| 久久久久国色av免费看影院| 欧美不卡高清| 国产精品美女久久福利网站| 一区久久精品| 亚洲女优在线| 欧美国产日本韩| 一本久道久久综合婷婷鲸鱼| 久久国产综合精品| 国产精品啊啊啊| 亚洲激情视频网| 久久精品一区二区三区四区| 亚洲精品老司机| 久久激情一区| 国产精品久久久久一区二区三区共 | 亚洲精品永久免费| 久久精品国亚洲| 一区二区精品| 欧美成人免费网站| 伊人精品成人久久综合软件| 亚洲午夜精品一区二区| 亚洲电影免费在线| 欧美伊人精品成人久久综合97| 欧美日韩精品免费看| 亚洲成在人线av| 久久九九久精品国产免费直播| 亚洲理论在线| 欧美插天视频在线播放| 狠狠色丁香久久婷婷综合_中| 亚洲欧美中日韩| 亚洲免费电影在线观看| 久久综合网络一区二区| 国产日韩欧美在线播放| 亚洲精品美女在线观看| 久久综合久久综合这里只有精品| 这里只有视频精品| 欧美区国产区| 日韩午夜一区| 欧美va天堂在线| 美女999久久久精品视频| 国产午夜精品久久久久久久| 亚洲综合精品| 亚洲调教视频在线观看| 国产精品女主播| 亚洲一区二区三区国产| 亚洲精品小视频| 欧美色大人视频| 亚洲视频一区二区免费在线观看| 亚洲电影免费在线| 麻豆精品一区二区综合av | 欧美日韩综合精品| 一区二区日韩伦理片| 亚洲第一页在线| 欧美女主播在线| 亚洲视频一区二区| 亚洲欧美日韩专区| 亚洲第一色在线| 亚洲精品日韩在线观看| 欧美美女喷水视频| 亚洲午夜激情在线| 亚洲欧美国产视频| 狠狠入ady亚洲精品| 亚洲高清在线观看| 欧美日韩在线视频首页| 亚洲欧美日韩另类精品一区二区三区| 亚洲网站在线播放| 精品不卡一区二区三区| 亚洲国产一区二区a毛片| 国产精品视频免费观看www| 麻豆精品精华液| 一区二区激情视频| 欧美一区二区啪啪| 日韩视频精品| 亚洲欧美日韩成人| 亚洲精品欧美日韩专区| 在线午夜精品自拍| 黄色成人免费网站| 在线亚洲精品| 亚洲大胆人体视频| 亚洲综合大片69999| 亚洲第一黄色| 亚洲欧美偷拍卡通变态| 国产噜噜噜噜噜久久久久久久久| 国产一区二区高清视频| av不卡在线| 曰韩精品一区二区| 亚洲男人的天堂在线aⅴ视频| 久久精品视频在线看| 蜜乳av另类精品一区二区| 国产日韩欧美一区二区三区在线观看| 日韩亚洲欧美精品| 亚洲视频在线观看三级| 日韩午夜精品| 在线中文字幕不卡| 久久aⅴ国产欧美74aaa| 午夜精品久久久久久| 亚洲天堂av图片| 一区二区三区欧美日韩| 久久午夜精品一区二区| 日韩视频在线你懂得| 这里只有精品丝袜| 欧美高清视频一二三区| 欧美激情一区二区久久久| 黄色成人av| 欧美一级视频一区二区| 久久综合给合久久狠狠狠97色69| 国产欧美日韩另类一区| 一本久道久久综合婷婷鲸鱼 | 亚洲精品一区在线| 亚洲午夜国产一区99re久久| 国产精品久久久久久久久动漫| 99热这里只有精品8| 亚洲精品网站在线播放gif| 欧美影院午夜播放| 一区二区不卡在线视频 午夜欧美不卡在 | 一区二区三区高清在线| 99精品视频免费观看| 伊人久久大香线蕉av超碰演员| 国产精品久久99| 在线亚洲自拍| 亚洲性视频网站| 亚洲自拍啪啪| 国产精品久久久久9999吃药| 亚洲久久成人| 一本大道久久a久久综合婷婷| 欧美精品1区| 亚洲伦理自拍| 午夜精品一区二区三区在线播放| 午夜精品视频在线观看| 国产精品视频自拍| 欧美亚洲视频在线看网址| 久久久久国产免费免费| 影音先锋亚洲视频| 免费黄网站欧美| 日韩视频免费观看高清完整版| 亚洲无毛电影| 国产欧美日韩视频在线观看| 欧美亚洲免费在线| 久久精品免费| 亚洲激情影院| 欧美色精品在线视频| 亚洲午夜在线观看| 久久综合给合久久狠狠色 | 欧美日韩一区二区三区在线看| 亚洲精品久久久一区二区三区| 亚洲一本视频| 黄色小说综合网站| 欧美国产精品| 午夜亚洲伦理| 亚洲精品久久久久中文字幕欢迎你 | 欧美国产精品v| 亚洲天堂偷拍| 欧美国产精品人人做人人爱| 正在播放亚洲| 国产在线精品成人一区二区三区| 免费在线观看日韩欧美| 亚洲一级网站| 亚洲第一页在线| 久久久久久久久久久一区| 国产精品h在线观看| 久久全国免费视频| 亚洲午夜精品福利| 亚洲国产成人午夜在线一区 | 久久er精品视频| 一本色道久久综合亚洲91| 韩国av一区| 国产精品区一区二区三区| 免费在线成人| 亚洲欧美成人网| 一本色道久久88亚洲综合88| 欧美成人免费全部观看天天性色| 亚洲综合社区| 日韩亚洲精品视频| 亚洲国产午夜| 在线免费观看日韩欧美| 国产一区二区三区自拍 | 亚洲精品一区二区三区不|