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

天行健 君子當自強而不息

3D幾何圖元(4)

新建網頁 1

 

在3D中,平面是到兩個點的距離相等的點的集合。平面完全是平的,沒有厚度,且無限延伸。

 

平面方程 ---- 隱式定義

可以用類似于定義直線的方法來定義平面,平面的隱式定義由所有滿足平面方程的點p=(x, y, z)給出,平面方程的兩種記法如公式12.11所示:

ax + by + cz = d

p . n = d

公式12.11   平面方程

注意第二種形式中,n = [a, b, c]。一旦知道n,就能用任意已知的平面上的點來計算d

向量n也稱作平面的法向量,因為它垂直于平面。讓我們來驗證它,設pq都在平面上,滿足平面方程。將pq代入式12.11,即有:

最后一行點乘的幾何意義就是n垂直于從qp的向量,這對于平面上的任意pq點都是成立的,因此n垂直于平面上的任意向量。

我們還假設平面有"正面"和"反面"。一般來說,n指向的方向是平面的正面(front side)。即從n的頭向尾看,我們看見的是正面,如圖12.13所示:

n限制為單位長度并不會失去一般性,而且通常會給計算帶來方便。

 

用三個點定義

另一種定義平面的方法是給出平面上不共線的三個點,也就是說,這三個點不在一條直線上。(如果三個點在一條直線上,就存在無數多個平面包含這條直線,這樣也就無法說明我們指的是哪個平面了。)

讓我們通過平面上的三個點p1p2p3來計算nd。先計算nn指向什么方向呢?左手坐標系中的慣例是:當從平面的正面看時,p1p2p3以順時針方向列出。(右手坐標系中,經常假設這些點以逆時針方向列出,這樣不管使用哪種坐標系公式,結果都是相同的。)

12.14展示了使用平面上的三個點計算平面的法線向量的情況。

我們按順時針方向構造兩個向量(如圖12.14所示),"e"代表"邊(edge"向量,因為這個公式經常用來計算三角形代表的平面。這兩個向量叉乘的結果就是n,但可能不是單位向量,但我們可以單位化n,以上所有過程用公式12.12來簡介地概括:

注意,如果這些點共線,則e3e1平行。這樣叉乘為0,不能單位化。這個數學上的特例與物理特例相吻合:共線點不能唯一地定義一個平面。

現在知道了n,剩下的就是求d,可以由某個點與n點乘獲得。

 

多于三個點的"最佳"平面

有時,我們希望從一組三個以上的點集求出平面方程,這種點集最常見的例子就是多邊形頂點。在這種情況下,這些頂點繞多邊形順指針地列出。(順序很重要,因為要依據它決定哪邊是"正面"哪邊是"反面"。)

一種糟糕的方式是任選三個連續的點并用這三個點計算平面方程。畢竟所選的三個點可能共線,或接近共線。因為數值精度的問題,這將非常糟糕。或者,多邊形可能是凹的,所選的點恰好在凹處,從而構成了逆時針(將導致法向量方向錯誤)。又或者,多邊形上的頂點可能不是共面的,這可能是由數值上的不精確,或錯誤的生成多邊形的方法所引起的。我們真正想要的是從點集中求出"最佳"平面的方法,該平面綜合考慮了所有的點。設給定n個點:

如果我們限制n必須為單位向量,則這個向量必須單位化。

求和符號能使公式12.13更簡潔些,設pn+1 = p1,則有:


如下代碼展示了怎樣從點集中求出最佳法向量:

    Listing 12.2: Computing the best-fit plane normal for a set of points
    
    Vector3 computeBestFitNormal(
const Vector3 v[], int n) 
    {
      
// Zero out sum
    
  Vector3 result = kZeroVector;
    
      
// Start with the "previous" vertex as the last one.
      // This avoids an if-statement in the loop
    
  const Vector3 *p = &v[n–1];
    
      
// Iterate through the vertices
    
  for (int i = 0 ; i < n ; ++i) 
      {
        
// Get shortcut to the "current" vertex
    
    const Vector3 *c = &v[i];
    
        
// Add in edge vector products appropriately
    
    result.x += (p–>z + c–>z) * (p–>y – c–>y);
        result.y += (p–>x + c–>x) * (p–>z – c–>z);
        result.z += (p–>y + c–>y) * (p–>x – c–>x);
    
        
// Next vertex, please
    
    p = c;
      }
    
      
// Normalize the result and return it
    
  result.normalize();
    
      
return result;
    }

最佳d值為每個點對應的d的平均值:

點到平面的距離

設想一個平面和一個不在平面上的點q,平面上存在一個點p,它到q的距離最短。很明顯,從pq的向量垂直于平面,且形式為an。如圖12.15所示:

假設n為單位向量,那么pq的距離(也就是q到平面的距離)就是a了。(如果q在平面的反面,這個距離為負。)令人驚奇的是,不用知道p的位置就能計算出a。讓我們回顧q的原定義,并做一些向量計算以消掉p,如公式12.14所示:

posted on 2008-02-23 14:06 lovedday 閱讀(867) 評論(0)  編輯 收藏 引用


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


公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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综合网| 久久久91精品国产| 久久久.com| 91久久精品一区| 亚洲视频免费在线观看| 欧美主播一区二区三区美女 久久精品人| 久久精品视频在线| 欧美理论片在线观看| 国产精品国产自产拍高清av| 狠狠干狠狠久久| 日韩视频在线观看国产| 亚洲影院在线观看| 午夜欧美不卡精品aaaaa| 久久午夜羞羞影院免费观看| 亚洲高清不卡| 午夜亚洲福利在线老司机| 老司机精品视频一区二区三区| 欧美日本国产精品| 国产一级揄自揄精品视频| 亚洲欧洲精品一区二区| 亚洲欧美成人在线| 免费人成网站在线观看欧美高清| 亚洲精品乱码| 欧美在线影院| 欧美日韩国产综合视频在线观看| 国产精品www色诱视频| 国产精品久久久久久久久动漫| 极品少妇一区二区三区| 亚洲综合色自拍一区| 免费成人高清视频| 一区二区不卡在线视频 午夜欧美不卡在 | 在线亚洲+欧美+日本专区| 久久www成人_看片免费不卡| 亚洲黄色在线看| 9色精品在线| 欧美岛国激情| 好吊视频一区二区三区四区| 亚洲一区二区在线看| 亚洲第一精品在线| 久久国产66| 国产人久久人人人人爽| 亚洲影院免费观看| 亚洲免费观看视频| 欧美成人激情在线| 亚洲国产精品va在看黑人| 国产精品永久免费在线| 欧美在线视频观看免费网站| 国产精品免费一区豆花| 亚洲一级黄色片| 亚洲美女黄色| 欧美日韩一区二区三区| 亚洲精选中文字幕| 欧美xart系列高清| 久久综合一区| 亚洲人成绝费网站色www| 欧美成人国产一区二区| 老鸭窝毛片一区二区三区| 在线观看中文字幕亚洲| 欧美二区乱c少妇| 母乳一区在线观看| 亚洲精品免费在线| 亚洲成色777777在线观看影院| 久久精品国产免费| 激情综合电影网| 欧美韩国在线| 欧美成人精品| 亚洲一区二区三区精品在线观看 | 亚洲免费中文字幕| 国产精品高清在线观看| 午夜精品剧场| 久久国产精品久久精品国产| 亚洲福利视频在线| 亚洲区一区二区三区| 欧美日韩综合一区| 亚洲尤物视频网| 欧美一区二区三区另类| 亚洲国产成人久久综合一区| 欧美国产日韩xxxxx| 欧美日韩国产页| 性一交一乱一区二区洋洋av| 欧美一区二区三区免费在线看 | 国产精品一页| 狼人天天伊人久久| 欧美激情综合五月色丁香| 一区二区日韩| 欧美在线视频a| 亚洲开发第一视频在线播放| 亚洲天堂av图片| 亚洲福利国产| 亚洲制服av| 亚洲日本国产| 亚洲综合成人婷婷小说| 亚洲动漫精品| 夜夜嗨av色一区二区不卡| 国产日韩欧美综合精品| 亚洲福利视频二区| 国产区精品在线观看| 亚洲福利在线视频| 国产日韩一区欧美| 亚洲精品四区| 伊人成年综合电影网| 在线中文字幕不卡| 亚洲免费av观看| 久久久免费精品| 午夜亚洲伦理| aⅴ色国产欧美| 一区在线免费| 亚洲欧美区自拍先锋| 99re成人精品视频| 欧美一级二区| 亚洲永久网站| 欧美日韩一区二区在线视频| 欧美aa国产视频| 国内揄拍国内精品少妇国语| 亚洲一区二区三| 亚洲午夜高清视频| 欧美日韩国产在线播放| 欧美高清视频一二三区| 影音先锋中文字幕一区| 久久精品国产99精品国产亚洲性色| 国产精品99久久久久久久女警| 美女视频黄 久久| 欧美xxx成人| 亚洲国产黄色| 欧美成人一区二区三区片免费| 久久综合九色欧美综合狠狠| 国产欧美精品va在线观看| 亚洲在线一区二区三区| 一本久久青青| 欧美精品日日鲁夜夜添| 亚洲欧洲精品一区二区三区波多野1战4| 在线成人欧美| 美女久久一区| 亚洲激情在线激情| 99国产精品99久久久久久粉嫩 | 欧美一区激情视频在线观看| 在线一区二区三区四区| 欧美日韩不卡视频| av72成人在线| 性伦欧美刺激片在线观看| 国产伦精品一区二区三区高清| 亚洲综合日韩在线| 久久免费视频网| 亚洲国产日韩欧美| 欧美电影在线| 一区二区三区 在线观看视| 亚洲欧美日韩综合aⅴ视频| 国产精品丝袜xxxxxxx| 性久久久久久久| 欧美中文字幕在线视频| 国内精品**久久毛片app| 狂野欧美性猛交xxxx巴西| 欧美不卡视频一区| 一区二区三区国产盗摄| 国产拍揄自揄精品视频麻豆| 久久国产免费看| 欧美激情在线狂野欧美精品| 在线一区二区三区做爰视频网站| 国产精品社区| 久久亚洲午夜电影| 日韩视频一区二区三区在线播放免费观看 | 99精品国产福利在线观看免费| 欧美激情网站在线观看| 99精品视频网| 老司机午夜精品| 亚洲一区二区三区三| 精品不卡视频| 欧美亚男人的天堂| 亚洲国产一区二区视频| 午夜视黄欧洲亚洲| 亚洲精品麻豆| 国产一区白浆| 国产精品成人一区二区| 欧美在线视频不卡| 一本久久青青| 欧美大片一区二区| 欧美一区二区三区男人的天堂| 亚洲高清三级视频| 国产精品五区| 欧美成人一品| 欧美一区中文字幕| 一区二区三区日韩| 欧美成人免费在线视频| 亚洲在线视频观看| 亚洲精品国产欧美| 在线欧美日韩精品| 国产欧美一区二区三区沐欲| 欧美性色aⅴ视频一区日韩精品| 欧美va亚洲va香蕉在线| 欧美诱惑福利视频| 亚洲欧美中文日韩在线|