• <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>
            隨筆 - 32  文章 - 94  trackbacks - 0
            <2009年9月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            常用鏈接

            留言簿(8)

            隨筆分類

            隨筆檔案

            好友連接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            很早就想學習shader了,當時看著那本《openGL超級寶典》的高級shader語言看了2遍,卻被誤導到了那些什么shaderObject,shaderProgramme的概念上,還一直在思考一個Programme和Object之間的關系。
            諸如包含和被包含、一對多,還有在程序中何時準備,何時釋放的問題(曾看過網上一個例子,在游戲循環中居然不斷重新編譯)。

            因為被這些問題搞混了很久,所以覺得應該找本更詳細的書看,于是就找了本《openGL shading language》英文版電子書,前面5章的內容仍然是那些渲染管線的老問題,因為害怕會漏點什么,都耐著性子看,業余時間看了10天左右,才看到第6章一個入門的例子,還有第七章解決了以前困擾著的問題。

            接下來用了那個RenderMonkey明明白白地試驗了第6章的那個例子,試驗時又冒出了不少數學問題,例如:vs中的法線變換為什么不用gl_ModelViewMatrix去乘、矩陣的各種運算公式等等,哎,都怪大一時線性代數學的太爛。

            以下是按照“橙寶書”第六章的磚塊,這一章后面留給讀者有關解決顏色鋸齒的問題,弄了半天.....
            另外,RenderMonkey添加中文注釋時,有時候居然會出什么“type name expected at token "<undefined>"”,然后編譯不通過,也弄了半天...
            uniform vec3 f3LightPos;
            const float specularContribution=0.4;
            const float diffuseContribution=1.0-specularContribution;

            varying 
            float LightIntensity;
            varying vec2  MCposition;

            void main(void)
            {
               vec3 ecPosition 
            = vec3(gl_ModelViewMatrix * gl_Vertex);//在眼坐標系中物體的坐標
               
               vec3 tnorm     
            = normalize(gl_NormalMatrix * gl_Normal);//在眼坐標系中的法線
               
               vec3 lightEyePos
            =vec3(vec4(f3LightPos,1.0));
               
               vec3 lightVec   
            = normalize(lightEyePos - ecPosition);//燈光方向(跟著眼睛移動)
               
               vec3 reflectVec 
            = reflect(-lightVec, tnorm);//反射方向
               vec3 viewVec    = normalize(-ecPosition);//眼睛的前方向
               float diffuse   = max(dot(lightVec, tnorm), 0.0);//光線和法線的乘積
               float spec      = 0.0;

                
            if (diffuse > 0.0)
                
            {
                    spec 
            = max(dot(reflectVec, viewVec), 0.0);//反射光 
                    spec = pow(spec, 2.0);
                }


                LightIntensity 
            = diffuseContribution * diffuse +specularContribution * spec;


                MCposition
            =gl_Vertex.xy;


               gl_Position 
            =gl_ProjectionMatrix*gl_ModelViewMatrix * gl_Vertex;// ftransform();
            }

            uniform vec4 BrickColor;
            uniform vec4 EdgeColor;
            uniform vec2 f2BrickSize;
            uniform vec2 f2BrickInnerPerc;

            varying vec2 MCposition;
            varying 
            float LightIntensity;

            void main(void)
            {
               vec4  color;
               vec2  position, useBrick;
               position
            =MCposition*0.02/f2BrickSize;
               
            //在貼圖為參考比例
               if (fract(position.y * 0.5> 0.5)
                  position.x 
            += 0.5;
                  

               position 
            = fract(position);//在貼圖上
               
               
               
            float smallX=(1.0-f2BrickInnerPerc.x)/2.0;
               
            float bigX=1.0-smallX;
               
               
               
            float smallY=(1.0-f2BrickInnerPerc.y)/2.0;
               
            float bigY=1.0-smallY;

               
            if(position.x>0.5)
                  useBrick.x 
            = 1.0-smoothstep(bigX-0.03, bigX+0.03,position.x);
               
            else
               
            {
               
            //useBrick.x = step(position.x, f2BrickInnerPerc.x);
                 useBrick.x = smoothstep(smallX-0.03, smallX+0.03,position.x);
                  }

               
            if (position.y>0.5)
                  useBrick.y 
            = 1.0-smoothstep(bigY-0.03, bigY+0.03,position.y);
               
            else
               
            {
               
            //useBrick.y = step(position.y, f2BrickInnerPerc.y);
               useBrick.y = smoothstep(smallY-0.03, smallY+0.03,position.y);
               }


              
            // useBrick.x = step(position.x, f2BrickInnerPerc.x);
              
            // useBrick.y = step(position.y, f2BrickInnerPerc.y);

                color  
            = mix(EdgeColor,BrickColor , useBrick.x * useBrick.y);

               
               color
            =color*LightIntensity;
               
               gl_FragColor 
            = vec4( color.rgb, 1.0 );
            }




            接下來學習的主要問題:

            shader環境配置、語法等煩問題都解決了,也能看明白RenderMonkey自帶的一些比較簡單的例子的整體思路。

            但是每個例子中的細節部分,每個具體步驟的計算,卻不明白。因此現在是看懂例子的大概,但是要我重新寫一個,或者指出例子中某個具體計算的作用,或者腦里想象例子中某個具體步驟產生的效果,肯定不會...
            posted on 2009-09-15 23:30 陳昱(CY) 閱讀(1763) 評論(4)  編輯 收藏 引用 所屬分類: 圖形學

            FeedBack:
            # re: 學習shader第一步 2009-09-16 10:13 StarX
            好大一條蟲子啊,哈哈。。  回復  更多評論
              
            # re: 學習shader第一步 2009-09-16 10:57 Touchsoft
            “但是每個例子中的細節部分,每個具體步驟的計算,卻不明白。”
            別說Shader,同樣對于是些簡單的3D程序,我經常搞不懂這些。  回復  更多評論
              
            # re: 學習shader第一步 2009-09-16 15:21 凡客誠品
            好大的一條啊~~  回復  更多評論
              
            # re: 學習shader第一步 2009-09-21 09:46 Sunshine Alike
            我想說這像一根大香腸,哈哈  回復  更多評論
              
            国产A三级久久精品| 亚洲熟妇无码另类久久久| 久久水蜜桃亚洲av无码精品麻豆| 日韩精品久久久久久免费| 久久国产欧美日韩精品| 久久精品国产亚洲av瑜伽| 日日躁夜夜躁狠狠久久AV| 嫩草影院久久国产精品| 99久久精品国产一区二区| 国产亚洲美女精品久久久久狼| 久久亚洲精品无码观看不卡| 伊人丁香狠狠色综合久久| 99久久成人国产精品免费| 日韩精品久久久肉伦网站| 国产精品成人99久久久久91gav| 性欧美丰满熟妇XXXX性久久久 | 91性高湖久久久久| 久久人人爽人人澡人人高潮AV| 久久久久亚洲AV无码专区体验 | 久久夜色精品国产噜噜麻豆| 久久国产视频网| 国内精品久久久久久99| 国内精品久久九九国产精品| 久久天天婷婷五月俺也去| 亚洲精品国产自在久久| 少妇人妻综合久久中文字幕| 伊人久久精品无码二区麻豆| 国产免费久久精品丫丫| 狠狠狠色丁香婷婷综合久久俺| 日本强好片久久久久久AAA| 久久综合色老色| 综合久久一区二区三区| 亚洲国产精品成人AV无码久久综合影院 | 久久综合久久久| 久久精品国产一区| .精品久久久麻豆国产精品 | 2020最新久久久视精品爱 | 久久久久波多野结衣高潮| 久久亚洲国产最新网站| 久久午夜福利无码1000合集| 久久久久久国产a免费观看黄色大片 |