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

隨筆 - 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>
            久久久无码精品亚洲日韩按摩| 樱桃视频在线观看一区| 日韩图片一区| 亚洲黑丝在线| 欧美激情视频在线播放| 欧美国产精品va在线观看| 亚洲国产小视频| 一区二区激情| 欧美怡红院视频一区二区三区| 欧美有码在线观看视频| 老**午夜毛片一区二区三区| 欧美高清在线一区二区| 欧美日韩在线播放三区四区| 国产农村妇女精品| 亚洲激情不卡| 欧美一区激情| 亚洲电影第1页| 亚洲欧美日韩成人高清在线一区| 久久女同互慰一区二区三区| 欧美另类变人与禽xxxxx| 国产精品视频xxxx| 亚洲精品久久| 久久久久久国产精品mv| 亚洲日本成人| 久久精品人人| 欧美色图首页| 亚洲国产一区二区三区高清| 亚洲一区二区三区在线视频| 开心色5月久久精品| 99www免费人成精品| 久久久91精品国产一区二区精品| 欧美日韩亚洲视频| 91久久极品少妇xxxxⅹ软件| 欧美一区二区三区日韩| 亚洲国产精品t66y| 久久久97精品| 国产亚洲欧美另类中文| 一区二区欧美在线| 欧美国内亚洲| 久久久久国产精品一区| 国产麻豆91精品| 亚洲婷婷综合久久一本伊一区| 美女国产精品| 久久久999国产| 一区二区三区在线视频免费观看| 亚洲欧美国产毛片在线| 亚洲激情国产精品| 欧美成人国产| 亚洲伦伦在线| 亚洲精品国偷自产在线99热| 美女精品国产| 亚洲激情欧美| 欧美成人久久| 理论片一区二区在线| 黄色av成人| 老牛国产精品一区的观看方式| 羞羞答答国产精品www一本| 国产精品久久久久久亚洲毛片| 久久一区中文字幕| 香蕉成人久久| 国产欧美日韩精品在线| 中文av字幕一区| 99视频热这里只有精品免费| 欧美精品三区| 亚洲午夜av电影| 宅男66日本亚洲欧美视频| 欧美三级第一页| 日韩午夜在线| 女同性一区二区三区人了人一 | 99视频精品全部免费在线| 久久av一区二区| 国产三级欧美三级| 久久国产精品免费一区| 性做久久久久久久久| 国内精品视频666| 欧美成人精品一区二区三区| 欧美jizz19性欧美| 亚洲视频在线免费观看| 亚洲婷婷综合久久一本伊一区| 国产精品嫩草久久久久| 欧美一区二区三区成人| 久久国内精品自在自线400部| 黄色成人av| 亚洲日本中文字幕区| 国产精品激情偷乱一区二区∴| 欧美影视一区| 免费在线观看精品| 亚洲一区免费网站| 久久久久久久97| 中文日韩电影网站| 久久九九国产精品怡红院| 99re热这里只有精品免费视频| 中日韩男男gay无套| 国产一区视频网站| 亚洲免费观看高清在线观看| 国产亚洲一级| 亚洲人成网站777色婷婷| 国产精品久久久久久影视| 美女视频网站黄色亚洲| 在线日本成人| 欧美国产精品久久| 国产精品国产三级国产普通话三级 | 久久免费高清| 欧美精品一区二区久久婷婷| 亚洲欧美日本在线| 久久免费国产精品1| 亚洲欧美乱综合| 欧美+亚洲+精品+三区| 欧美一区二区成人6969| 欧美高清在线播放| 久久精品系列| 国产精品久久久一本精品| 欧美电影电视剧在线观看| 国产精品亚洲综合一区在线观看 | 亚洲大胆女人| 激情一区二区三区| 亚洲欧美在线高清| 亚洲一区二区三区视频播放| 免费在线视频一区| 美女精品在线| 在线精品国精品国产尤物884a| 亚洲欧美日韩另类| 亚洲一区二区三区在线观看视频| 欧美成人第一页| 欧美电影免费观看高清| 在线不卡a资源高清| 欧美一区二区在线免费观看| 亚洲欧美日韩一区二区三区在线| 欧美剧在线免费观看网站| 欧美国产精品劲爆| 亚洲日本电影在线| 欧美电影在线播放| 亚洲国产欧美在线人成| 亚洲国产高清一区| 欧美91大片| 亚洲精美视频| 一区二区久久久久| 欧美日韩福利| 一区二区三区av| 午夜宅男欧美| 国产视频一区二区三区在线观看| 性欧美大战久久久久久久免费观看| 欧美一区激情视频在线观看| 国产日韩精品在线播放| 欧美一区二区三区在线播放| 久久免费国产精品1| 在线不卡中文字幕播放| 免费欧美日韩国产三级电影| 国产精品一区一区三区| 欧美国产精品中文字幕| 女女同性精品视频| 在线观看中文字幕不卡| 欧美在线视频日韩| 欧美激情欧美狂野欧美精品| 在线观看亚洲视频| 久久在线免费观看视频| 欧美电影电视剧在线观看| 亚洲激情在线观看| 欧美日韩在线三区| 亚洲欧美一区二区三区在线| 久久亚洲欧美| 亚洲九九精品| 国产精品日韩一区二区| 久久精品人人| 亚洲免费成人| 久久久欧美精品| 99视频精品在线| 国产美女搞久久| 免费一区视频| 午夜精品久久久久久| 欧美国产第二页| 小黄鸭精品aⅴ导航网站入口| 国产一区二区三区在线观看网站| 另类酷文…触手系列精品集v1小说| 亚洲精品小视频| 久久久91精品| 一区二区三区波多野结衣在线观看| 国产精品入口日韩视频大尺度| 久久久国产一区二区| 日韩视频在线观看免费| 噜噜噜久久亚洲精品国产品小说| 宅男66日本亚洲欧美视频| 国产在线视频欧美| 国产精品videossex久久发布| 久久一二三区| 欧美一级二级三级蜜桃| 99国内精品久久| 欧美成人精品一区二区| 久久成人精品无人区| 一本色道久久综合亚洲二区三区| 国内精品久久久久久影视8| 欧美性猛交一区二区三区精品| 久久在线91| 久久精品亚洲| 午夜精品久久久久久久久久久久| av成人免费| 99国产精品久久久久久久| 亚洲第一中文字幕| 欧美福利视频一区| 欧美va天堂在线|