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

            黎明的剔透里伸出了你沁清的曖昧

            Graphics|EngineDev|GameDev|2D&3D Art

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              60 隨筆 :: 1 文章 :: 18 評論 :: 0 Trackbacks

            gl_FragCoord和gl_FragDepth分別是片元著色器的輸入和輸出變量。

            gl_FragCoord是個vec4,四個分量分別對應x, y, z和1/w。其中,x和y是當前片元的窗口相對坐標,不過它們不是整數,小數部分恒為0.5。x - 0.5和y - 0.5分別位于[0, windowWidth - 1]和[0, windowHeight - 1]內。windowWidth和windowHeight都以像素為單位,亦即用glViewPort指定的寬高。w即為乘過了投影矩陣之后點坐標的w,用于perspective divide的那個值。gl_FragCoord.z / gl_FragCoord.w可以得到當前片元和camera之間的距離。參見Fog in GLSL page 4

            gl_FragCoord.z是固定管線計算出的當前片元的深度。它已經考慮了多邊形偏移,并經過了投影變換。它位于[0.0, 1.0]之間。如果用gl_FragColor = vec4(vec3(gl_FragCoord.z), 1.0)將其可視化,多半會看到一片白。這是由于變換的非線性,大多數點的深度都非常接近于1。用gl_FragColor = vec4(vec3(pow(gl_FragColor.z, exp)), 1.0)并將exp取為合適的值,就能看到從黑到白的深度變化了。距離觀察者近的顏色深,接近0.0;距離觀察者遠的顏色淺,接近1.0;這說明一直以來的右手坐標系在投影變換后變成了左手坐標系。關于深度的變換和精確性參見OpenGL FAQ - 12 The Depth Buffer

            根據GLSLangSpec.Full.1.30.08(p61),gl_FragCoord.z是固定功能計算所得的結果。如果片元著色器不寫gl_FragDepth,那么這個值將用在后續處理中。OpenGL Shading Language提到(p104),即使將gl_FragCoord.z賦值給gl_FragDepth也不能保證產生和固定功能完全相同的值。但是,可以保證相對正確。加之片元著色器一旦寫入gl_FragDepth,就必須保證在每個分支都有寫入。因此,如果一個著色器需要在某些條件下自己計算深度,其它條件下的正確做法就是gl_FragDepth = gl_FragCoord.z。

            在OpenGL的固定管線中,深度坐標是在視口變換期間變換到glDepthRange指定的范圍之內(OpenGL編程指南-原書第五版,88頁)。視口變換也就是光柵化(Rasterization),在進行到片元著色器的時候自然已經編碼完畢了。

            自行計算片元深度可以用下面的方法(參考OpenGL FAQ - 12 The Depth Buffer):

             

            1. // Vertex Shader   
            2. varying vec4 position;  
            3. void main(void)  
            4. {  
            5.     position = gl_ModelViewMatrix * gl_Vertex;  
            6.     gl_Position = ftransform();  
            7. }  
            8. // Fragment Shader   
            9. uniform float zFar;  
            10. uniform float zNear;  
            11. varying vec4 position;  
            12. void main()  
            13. {  
            14.     float zDiff = zFar - zNear;  
            15.     float interpolatedDepth = (position.w / position.z) * zFar * zNear / zDiff + 0.5 * (zFar + zNear) / zDiff + 0.5;  
            16.     gl_FragColor = vec4(vec3(pow(interpolatedDepth, 15.0)), 1.0);  
            17. }  

             

            這樣計算出的深度與gl_FragCoord.z基本一致。

            posted on 2012-03-11 11:06 情絕格調(fresmaster) 閱讀(1634) 評論(0)  編輯 收藏 引用 所屬分類: Graphics
            久久久亚洲欧洲日产国码二区 | 亚洲中文字幕无码久久综合网 | 久久精品国产亚洲AV嫖农村妇女 | 久久91精品综合国产首页| 久久精品中文字幕无码绿巨人 | 日韩一区二区三区视频久久| 久久99久久成人免费播放| 精品国产乱码久久久久久浪潮| 久久精品国产欧美日韩| 久久亚洲精品国产亚洲老地址| yellow中文字幕久久网| 国产精品VIDEOSSEX久久发布| 久久涩综合| 性色欲网站人妻丰满中文久久不卡| 久久精品国产亚洲av水果派| 久久精品国产99久久无毒不卡| 久久91精品综合国产首页| 久久99精品国产麻豆宅宅| AV狠狠色丁香婷婷综合久久| 久久99久久无码毛片一区二区| 国产精品久久久久影院色| 狠狠色综合网站久久久久久久| 久久九九精品99国产精品| 久久久久婷婷| 91精品婷婷国产综合久久| 久久久无码人妻精品无码| 国产精品gz久久久| 狠狠色丁香久久婷婷综合五月| 亚洲美日韩Av中文字幕无码久久久妻妇| 色欲综合久久躁天天躁蜜桃| 国产精品成人久久久久三级午夜电影| 久久午夜无码鲁丝片秋霞| AAA级久久久精品无码区| 久久国产精品成人影院| 亚洲精品乱码久久久久久中文字幕 | 久久伊人五月天论坛| 久久er国产精品免费观看2| 中文字幕人妻色偷偷久久| 久久婷婷色综合一区二区| 999久久久免费国产精品播放| 久久精品九九亚洲精品天堂|