• <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>

            天秤座的唐風

            總會有一個人需要你的分享~!- 唐風 -

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              13 隨筆 :: 0 文章 :: 69 評論 :: 0 Trackbacks

            昨天晚上動手寫了橢圓的光柵化實現(xiàn),照著計算機圖形學書上的偽代碼編寫了 C++ 的代碼,結(jié)果運行結(jié)果完全出乎我的意料之外。
            畫出來的橢圓居然像這個樣子:


                這實在是不像橢圓了,呵呵。雖然說在網(wǎng)上看到有說 Bresenham 算法有一定的失真?但也不至于成這樣啊。于是反復地 check 偽代碼與我寫的 C++ 代碼,感覺算法上我的“翻譯”應該是沒有問題的。不會是這偽碼有問題?所以是翻回前面反復地閱讀和理解這個算法的原理,對照原理的公式和偽代碼的表達,也沒有問題啊,難道公式有問題?只是硬著頭皮自己再推導一遍。還是沒發(fā)現(xiàn)問題所在。頭大了,一直折騰到 2 點多,實在是沒找出問題在哪,想想第二天還得上班,沒辦法只好放下。心想第二天在代碼中加入一些輸出,把計算結(jié)果都輸出來進行 check。
                第二天中午休息的時候,在網(wǎng)上看到一個代碼的實現(xiàn),拷下來運行,雖然那份代碼也有問題,但至少有一半的橢圓弧看起來是相當正常的。另一半沒畫正確,也是因為斜率為 -1 的判斷有問題。再對照看了看我的代碼,赫然發(fā)現(xiàn),算法中用于存儲決定下一點的選擇策略的變量 d,在網(wǎng)上的代碼用的是 int 型,而我自己則用的自定義的 INT16。難道是 INT16 太小導致的?于是我改成 INT32,一運行,正常了,雖然有些走樣,但橢圓還是比較漂亮的。原來問題出在這里。INT16 的范圍太小,而計算結(jié)果是 32 位的,截取成 16 位正負號就亂套了,唉,教訓啊。OK 后的效果圖如下:


                記下來,給自己提個醒!

                附上橢圓的生成代碼,Bresenham算法:

             

            void Draw2DLine::DrawEllipse(Point const& a_Center, UINT16 a_a, UINT16 a_b)
            {
                UINT16 x 
            = 0, y = a_b; 
                UINT32 
            const taa = a_a*a_a;
                UINT32 
            const tbb = a_b*a_b;

                INT32 minYofDeltaX 
            = static_cast<INT32>(tbb/sqrt(static_cast<double>(tbb + taa)));

                INT32 p 
            = tbb - taa*a_b;  // 就是這個變量!

                
            while( minYofDeltaX <= y)
                

                    DrawPoint(a_Center.x
            +x, a_Center.y+y);
                    DrawPoint(a_Center.x
            +x, a_Center.y-y);
                    DrawPoint(a_Center.x
            -x, a_Center.y+y);
                    DrawPoint(a_Center.x
            -x, a_Center.y-y); 
                    
            if( p <= 0)
                    

                        
            ++x ;
                    }
             
                    
            else
                    

                        
            ++x; 
                        
            --y;
                    }
                    
                    p 
            = tbb*(x+1)*(x+1+ taa*(y*- y) - taa*tbb;
                }
             

                p 
            = tbb*(x*+ x) + taa*(y*- y) - taa*tbb;
                
            while(y > 0)
                

                    DrawPoint(a_Center.x
            +x, a_Center.y+y);
                    DrawPoint(a_Center.x
            +x, a_Center.y-y);
                    DrawPoint(a_Center.x
            -x, a_Center.y+y);
                    DrawPoint(a_Center.x
            -x, a_Center.y-y); 
                    
            if(p >= 0)
                    

                        
            --y; 
                        p 
            = p - 2*taa*- taa; 
                    }
             
                    
            else
                    

                        
            --y; 
                        
            ++x; 
                        p 
            = p - 2*taa*- taa + 2*tbb*+ 2*tbb; 
                    }
             
                }
             
                DrawPoint(a_Center.x
            +x, a_Center.y);
                DrawPoint(a_Center.x
            -x, a_Center.y);
            }
            posted on 2009-06-25 21:22 唐風 閱讀(766) 評論(1)  編輯 收藏 引用 所屬分類: 語言技術(shù)

            評論

            # re: 數(shù)據(jù)類型錯誤導致的 bug 與 Bresenham 橢圓生成算法代碼 2009-06-25 22:31 唐風
            PS:
              附上的代碼中,第一個 while 中(切線斜率大于 -1 )的判別子 p 是直接用橢圓方程來計算的,第二個 while 中(切線斜率小于 -1 )中使用的是增量計算。
              原來第一個 while 中也是使用增量法來計算的,但在斜率為 -1 的附近,橢圓的變形比較嚴重,感覺像是一段很明顯的 -1 斜率的直線。可能是計算式的精度有問題?但沒有細查。先改成上面的方式,用著先,以后再回來優(yōu)化。
            Mark 下。  回復  更多評論
              

            亚洲国产视频久久| 国内精品久久久久| 国内精品伊人久久久久777| 伊人情人综合成人久久网小说| 久久久久亚洲国产| 99久久成人国产精品免费| 精品国产热久久久福利| 国产成人精品综合久久久| 97久久超碰成人精品网站| 亚洲色欲久久久久综合网| 久久久久久亚洲AV无码专区| 91久久香蕉国产熟女线看| 国产精品99久久久精品无码 | 2021久久国自产拍精品| 97久久精品人人做人人爽| 亚洲伊人久久成综合人影院 | 久久播电影网| 三上悠亚久久精品| 欧美伊人久久大香线蕉综合| 国产精品视频久久久| 中文字幕无码久久人妻| 国产福利电影一区二区三区久久久久成人精品综合 | 久久精品无码一区二区无码| 久久综合伊人77777麻豆| AV色综合久久天堂AV色综合在| 一本色道久久88综合日韩精品 | 国产精品美女久久久久网| 波多野结衣AV无码久久一区| 99久久亚洲综合精品成人| 久久精品国产亚洲av影院| 久久婷婷色综合一区二区| 久久国产成人| 久久九色综合九色99伊人| 久久精品草草草| 免费精品99久久国产综合精品| 久久久精品国产sm调教网站 | 99久久香蕉国产线看观香| 国产精品美女久久久m| 精品国产乱码久久久久久1区2区 | 国内精品久久久久久久久电影网| 久久国产精品偷99|