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

SoRoMan

人若無名,便可專心練劍.

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

感覺很多書上都沒講清楚透視投影變換的推導(dǎo)過程,自己推導(dǎo)了下,以前一直含糊的關(guān)于方形/非方形的視平面和屏幕的寬高比的問題也有了答案.本文組織如下:

1.相機空間到視平面的變換
2.視平面到屏幕的變換
3.綜合
4.一般情形

1.相機空間到視平面的變換


?????????????????????? * p (xc,0, zc)
???????????????????? ?/ |
??????????????????? ?/? |
?????????????????? ?/?? |
?????????? X??? |/???? |
?????????? ^???? *p' |(xp,0,zp)
?????????? |?? / |????? |
?????????? |? /? |???? ?|
?????????? | /?? |???? ?|
C(cam)?|/??? |???? ?|
--------*----|----*------------->Z
?????????? 0??? dx?? zc
???? (X-Z平面的投影示圖)

a.透視投影一般的視景體為棱臺,相機空間的物體會投影到視平面z=d,這里考慮左手坐標系,矩陣使用行優(yōu)先方式。如圖所示,由相似三角形知識可知相機空間中的物體投影到視平面上的坐標為:

xp = xc*(dx/zc)
yp = yc*(dy/zc)

其中,xc,yc,zc為相機空間坐標,xp,yp,zp為視平面坐標,dx,dy為x,y軸向的視距view distance,視平面到camera的距離,
故相機空間投影到視平面上的矩陣Tcp為:

|dx 0? 0 0? |

|0? dy 0 0? |

|0? 0?? 1 1? |

|0? 0?? 0 0? |

(驗證:Tcp右乘點p(xc,yc,zc,1)得點p'(xc*dx, yc*dy, zc, zc),轉(zhuǎn)換為3D坐標為(xc*dx/zc, yc*dy/zc, 1),正確。)

********************************************************************
注:因為轉(zhuǎn)換過程中點使用的是4D齊次坐標,所以最后需轉(zhuǎn)換為3D坐標。4D齊次坐標(x,y,z,w)轉(zhuǎn)換為3D坐標的方法為除以w分量,即對應(yīng)3D坐標為(x/w,y/w,z/w)。
********************************************************************


考慮dx/zc和dy/zc項,如果dx != dy,則投影后x,y的比例會發(fā)生變化(原因:投影前坐標比例為xc/yc,投影后為xp/yp = xc*(dx/zc)/yc*(dy/zc) = xc*dx/yc*dy),從而投影后的圖像的x,y比例會發(fā)生變形。

---------------------------------------------
結(jié)論1:所以,一般都會令d=dx=dy,即x,y向的視距相同。否則,圖像失真。
---------------------------------------------

考慮視角(view angle,或視野filed of view)的問題,視角的大小不會影響到物體投影后的坐標,只會影響可視的范圍。

在視距一樣的情況下,x,y軸的視角可以不一樣。如果一樣,那么視平面就是一個正方形的。于是有:

tan(theta_x/2) = width_p/d
tan(theta_y/2) = height_p/d?

其中,theta_x,theta_y為x,y軸向的視角,width_p,height_p為視平面z=d的寬度(x軸)和高度(y軸)。
----------------------------------------------------------------
結(jié)論2:視平面的寬高比rp=width_p/height_p = tan(theta_x/2)/tan(theta_y/2)。
----------------------------------------------------------------

2.視平面到屏幕的變換

下面就是視平面到屏幕的變換了,這是一個2D到2D的變換(視平面的坐標需伸縮以填滿整個屏幕空間,即在視平面中出現(xiàn)的所有的點要變換到屏幕上去,同時x,y軸向的比例還要維持和變換前一樣,以免比例失真,同時視平面的坐標原點和屏幕中心點(x0=(width_s)/2, y0=(height_s)/2)對應(yīng)),其實,就是一個坐標縮放加平移的過程:

xs = xp*kx + x0
ys = -yp*ky + y0
?
矩陣Tps為:

|kx???? 0??????0 0? |

|0????? -ky????0 0? |

|0????? 0?????? 1 0? |

|x0?? y0??????0 1? |

(驗證:Tps右乘點p(xp,yp,zp,1)得點p'(xp*kx + x0, -yp*ky + y0, zp, 1),轉(zhuǎn)換為3D坐標為(xp*kx + x0, -yp*ky + y0, zp),正確。)

其中,kx,ky(kx>0,ky>0)為x,y軸向的縮放因子(kx=(width_s)/(width_p), ky = (height_s)/(height_p),和視距相同,kx,ky的值必須一樣,否則圖像的x,y比例又會發(fā)生變形。這里-yp*ky是因為一般屏幕的y軸是向下的,跟相機空間和視平面坐標系中的y軸方向相反。
------------------------------------------------------------------------------------------------
結(jié)論3: 一般令k=kx=ky,即x,y向的縮放因子相同。否則,圖像失真。
于是有,width_s/width_p = height_s/height_p,變化等式得,rp = width_p/height_p = width_s/height_s = rs
所以,在x,y軸視距一樣的情況下,要想最后變換到屏幕上的圖像x,y比例不失真,必須rp=rs,即視平面的寬高比和屏幕的寬高比一樣。

-----------------------------------------------------------------------------------------------

********************************************************************
注:若屏幕寬高為W,H,當(dāng)W != H,即屏幕不為方形的時候,要確保投影到屏幕上的圖像x,y比例不失真,則x,y軸視角(或視野FOV)肯定不能相等。
原因: 由結(jié)論2,3知,rp=width_p/height_p = tan(theta_x/2)/tan(theta_y/2)=width_s/height_s=rs=W/H。 故由W/H != 1 => theta_x != theta_Y.
********************************************************************

3.綜合:

相機空間點p轉(zhuǎn)換到屏幕空間點p',變換公式為:

xs = xc*(dx/zc)*kx + x0 = xc*(d/zc)*k + x0
ys = -yc*(dy/zc)*ky + y0 = -yc*(d/zc)*k + y0

綜合變換矩陣(相機空間到屏幕空間)Tcs為:
?
Tcs = Tcp*Tps =

|d*k??? 0?????? 0 0? |

|0????? -d*k??? 0 0? |

|x0???? y0????? 1 1? |

|0????? 0???????? 0? 0|

?其中,d為視距,k為屏幕寬高比或視平面寬高比,x0,y0為屏幕中心,注:最后需轉(zhuǎn)換為3D坐標。

(驗證:Tcs右乘點p(xc,yc,zc,1)得點p'(xc*d*k + x0*zc, -yc*d*k + y0*zc, zc, zc),轉(zhuǎn)換為3D坐標為(xc*(d/zc)*k + x0, -yc*(d/zc)*k + y0, 1),正確。)

4.一般情形:
?************************************
視距為1,x軸視角為90度,屏幕寬高為W,H.
************************************
?
代入d=1,theta_x = PI/2,x0= W/2,y0=H/2,則視平面寬高為width_p = 2。
要確保屏幕上的圖像x,y比例不失真,即rs=rp,有
height_p = 2/rp=2/rs=2H/W,
k=kx=ky=width_s/width_p = W/2.

于是,矩陣為:

Tcs1 =?

|W/2??? 0?????? 0 0? |

|0????? -W/2??? 0 0? |

|W/2??? H/2?? 1 1? |

|0????? 0???????? 0 0? |



?? |W/2??? 0????????????????? 0 0? |

|0????? -H/2*(W/H)??? 0 0? |

|W/2??? H/2????????????? 1 1? |

|0????? 0?????????????????? ?0 0? |

(可以看到,y軸的縮放因子中乘上了寬高比(aspect ratio))
?這個矩陣較常用。

---------------------
有什么問題,歡迎探討.
?

posted on 2006-09-17 00:34 SoRoMan 閱讀(8436) 評論(4)  編輯 收藏 引用

評論

# re: 探討:3D透視投影變換詳解-兼談視平面和屏幕的寬高比問題 2007-03-29 12:10 heihei
Can you give you commons ,why it is  回復(fù)  更多評論
  

# re: 探討:3D透視投影變換詳解-兼談視平面和屏幕的寬高比問題[未登錄] 2007-03-29 12:13 a
http://www.chinasoft.org.cn/Html/mm/05155655.html  回復(fù)  更多評論
  

# re: 探討:3D透視投影變換詳解-兼談視平面和屏幕的寬高比問題 2008-05-14 11:29 啊夏
hi SoRoman:
在你的博客上拜讀了你的大作"探討:3D透視投影變換詳解-兼談視平面和屏幕的寬高比問題".受益良多.

我按照你文章里面描述的.自己推導(dǎo)了一個公式.
世界坐標系的建立是這樣的. x左向右.y上向下,z朝向屏幕里面.
在里面有一點 p(x,y,z);
設(shè)視點v (0,0,vz); 然后采用透視投影將p投在 xoy平面上.

我的公式是這樣的.

t = -z/vz;
x' = t*x;
y' = t*y;
然后直接將 點(x',y') 繪制到 xoy屏幕上.

現(xiàn)在我遇到的問題是,在對線采用這樣的方式進行投影的時候會有飛線的情況發(fā)生.(我是在一個地圖引擎中使用). 在地圖級別比較小的情況下,繪制還算正確.但是如果地圖一放大線就亂了. 郁悶了好長時間了,希望能得到你的回信. 我的MSN: ren543#hotmail.com   回復(fù)  更多評論
  

# re: 探討:3D透視投影變換詳解-兼談視平面和屏幕的寬高比問題 2012-09-22 09:24 xwl
tan(theta_x/2) = width_p/d
tan(theta_y/2) = height_p/d

這是地方有點問題吧,應(yīng)該是
tan(theta_x/2) = width_p/2d
tan(theta_y/2) = height_p/2d
  回復(fù)  更多評論
  


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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精品日本一级| 欧美一区二区私人影院日本 | 欧美日韩精品在线| 欧美大片18| 亚洲美女毛片| 国产精品成人免费| 欧美激情视频给我| 国产精品成人在线| 黑人极品videos精品欧美裸| 在线看欧美日韩| 日韩视频三区| 午夜视频精品| 亚洲国产99| 亚洲欧美国产77777| 欧美一区二区高清| 欧美精品手机在线| 国产日韩一区在线| 亚洲免费电影在线| 久久婷婷亚洲| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲女人av| 欧美精品在线观看一区二区| 国产女优一区| 在线视频你懂得一区二区三区| 久久黄色级2电影| 一本色道久久99精品综合| 久久久久久色| 国产精品一区二区三区四区五区| 亚洲福利视频网| 午夜亚洲伦理| 亚洲美女黄网| 欧美成人三级在线| 一区二区视频欧美| 亚洲欧美日韩一区二区| 91久久久在线| 麻豆成人在线| 一区二区亚洲欧洲国产日韩| 亚洲欧美一区二区三区极速播放| 亚洲国产免费| 女主播福利一区| 在线观看日产精品| 狠狠久久亚洲欧美专区| 亚洲欧美卡通另类91av | 欧美freesex交免费视频| 亚洲一区黄色| 国产精品视频免费观看| 亚洲视屏在线播放| 9人人澡人人爽人人精品| 欧美大胆成人| 日韩视频在线永久播放| 欧美高清影院| 你懂的视频欧美| 91久久精品国产91久久性色tv| 久久久久国色av免费观看性色| 亚洲自拍电影| 国产日韩在线亚洲字幕中文| 午夜精品999| 亚洲欧美国产毛片在线| 国产精品亚洲一区二区三区在线| 一区二区三区三区在线| 亚洲精品免费一二三区| 午夜一区二区三区在线观看| 久久这里有精品15一区二区三区 | 亚洲欧美日本伦理| 国产精品一卡二| 久久九九精品| 久久成人精品电影| 亚洲电影免费观看高清| 欧美电影在线播放| 欧美久久视频| 午夜久久99| 久久蜜臀精品av| 亚洲精品一区二区三区四区高清| 亚洲国产精品精华液2区45| 欧美日韩国产一区二区三区地区| 99av国产精品欲麻豆| 一本色道久久综合狠狠躁篇怎么玩| 欧美日韩一卡| 久久亚洲欧美国产精品乐播| 久久久免费精品视频| 亚洲精品欧美专区| 一二三四社区欧美黄| 国产欧美一区二区色老头| 久久影院午夜论| 欧美美女喷水视频| 欧美影院成年免费版| 蜜臀91精品一区二区三区| 夜夜狂射影院欧美极品| 午夜精品久久一牛影视| 亚洲国产成人一区| 亚洲永久精品大片| 亚洲国产高清aⅴ视频| 亚洲视频狠狠| 亚洲福利视频在线| 亚洲女人天堂成人av在线| 亚洲国产精品久久久久| 国产精品99久久久久久久女警| 国内视频一区| 一区二区精品在线| 亚洲高清免费| 性久久久久久久久| 亚洲免费在线精品一区| 狂野欧美激情性xxxx欧美| 亚洲综合色在线| 女仆av观看一区| 巨乳诱惑日韩免费av| 欧美午夜不卡影院在线观看完整版免费| 久久人人爽国产| 国产精品久久久一区二区| 欧美刺激性大交免费视频 | 亚洲美女视频在线观看| 久久黄色级2电影| 在线亚洲一区| 欧美福利在线| 久久午夜羞羞影院免费观看| 欧美视频在线观看 亚洲欧| 欧美国产日韩在线| 国语自产精品视频在线看抢先版结局 | 亚洲美女免费精品视频在线观看| 欧美激情网友自拍| 国内偷自视频区视频综合| 亚洲精品国产拍免费91在线| 国内外成人免费激情在线视频| 亚洲私人黄色宅男| 正在播放亚洲一区| 欧美激情一区二区| 欧美成人午夜激情在线| 黄色成人免费观看| 久久成人国产精品| 久热国产精品| 在线成人av| 免费日韩av| 亚洲第一精品夜夜躁人人爽 | 亚洲一级网站| 亚洲欧美在线网| 国产精品青草久久久久福利99| 亚洲欧洲在线一区| 中日韩美女免费视频网址在线观看| 欧美大片一区二区三区| 亚洲清纯自拍| 中文亚洲字幕| 国产精品亚洲综合一区在线观看| 亚洲小说春色综合另类电影| 亚洲欧美三级在线| 国产日本亚洲高清| 久久国产精品毛片| 你懂的一区二区| 亚洲理论在线| 国产精品人成在线观看免费| 午夜精品美女久久久久av福利| 久久国产欧美日韩精品| 狠狠做深爱婷婷久久综合一区 | 日韩视频免费在线观看| 亚洲影院免费观看| 国产自产v一区二区三区c| 久久久久久综合| 亚洲精品一二区| 欧美一区在线直播| 亚洲黄色av一区| 欧美午夜精品久久久久久久| 午夜精品久久久久久久| 美女视频网站黄色亚洲| 一区二区三欧美| 国内揄拍国内精品少妇国语| 免费人成网站在线观看欧美高清| av成人手机在线| 裸体歌舞表演一区二区| 亚洲精品影院| 国产欧美一区二区精品秋霞影院| 久久精品午夜| 一本色道久久综合亚洲91| 另类春色校园亚洲| 亚洲一区二区三区四区在线观看 | 欧美日韩和欧美的一区二区| 亚洲一区激情| 亚洲精品永久免费| 久久亚洲私人国产精品va| 一区二区欧美国产| 亚洲第一精品夜夜躁人人躁| 国产精品毛片大码女人| 欧美jizz19性欧美| 欧美一进一出视频| 一本色道久久88综合日韩精品| 久久综合网hezyo| 欧美日韩 国产精品| 久久精品在线观看| 一区二区三区视频在线看| 国产欧美日韩一区二区三区在线观看 | 亚洲五月婷婷| 91久久夜色精品国产九色| 国产欧美一区二区白浆黑人| 欧美日韩国产麻豆| 美女视频网站黄色亚洲| 欧美一区二区在线观看| 午夜日本精品| 午夜精品久久久久| 午夜精品福利一区二区蜜股av| 99综合在线|