日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

three.js(五) 地形纹理混合

發布時間:2025/3/15 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 three.js(五) 地形纹理混合 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

地形生成通常使用高度圖, 而高度圖的生成可以使用繪圖工具,或者通過分形算法生成,例如square-diamond, ?fbm方法。
這里采用簡單求平均值+隨機波動的方法。




對于一個2^n+1 ?* ?2^n+1 的網格, 中心點的高度是四角點的平均值加隨機偏移, 邊上中點的高度值是邊兩端點的平均值加隨機偏移。
接著將偏移的幅度縮小, 計算四個較小方塊的頂點的高度值。
這樣隨機生成了高度。


接著構造地形, 地形分割成2^n * 2^n 塊, 這樣頂點就有 2^n+1 ?* ?2^n+1 個?
? ? var geo = new THREE.PlaneGeometry(3, 3, WIDTH-1, HEIGHT-1);


上面生成了每個頂點的高度, 需要將高度值傳入shader中, 可以直接修改geo中的所有頂點的z值,來修改高度。


我們可以根據地形的高度來混合紋理,例如比較高的位置為石塊, 而低洼處為草地, 這個紋理的混合。
c2 = mix(c0, c1, (height-minHeight)/(maxHeight-minHeight))
c0是第一張紋理獲取的顏色, c1是第二張紋理獲取的顏色, 而minHeight maxHeight 是整個地形高度的方位, height是當前高度。
c2 就是混合后的顏色。
shader如下,兩張紋理, 頂點在平面坐標中的位置,?
紋理坐標采用頂點的x, y 坐標的小數部分。
? ? uniform sampler2D texture_grass;
? ? uniform sampler2D texture_rock;
? ? uniform float maxHeight;
? ? uniform float minHeight;
? ? varying vec3 pos;




void main( void ) {
? ? ? ? vec2 uv0;
? ? ? ??
? ? ? ? uv0.x = fract(pos.x);
? ? ? ? uv0.y = fract(pos.y);
? ? ? ??
? ? ? ? vec4 c0 = texture2D(texture_grass, uv2);
? ? ? ? vec4 c1 = texture2D(texture_rock, uv2);




? ? ? ? vec4 c2 = mix(c0, c1, (pos.z-minHeight)/(maxHeight-minHeight));


? ? ? ? gl_FragColor = c2;
? ? ?

}








而材質:
? ? var pmat = new THREE.ShaderMaterial({
? ? ? ? uniforms:{
? ? ? ? ? ? texture_grass:{type:'t', value:0, texture:THREE.ImageUtils.loadTexture("grassa512.bmp")},
? ? ? ? ? ? texture_rock:{type:'t', value:1, texture:THREE.ImageUtils.loadTexture("dirt512.bmp")},
? ? ??
? ? ? ? ? ? maxHeight:{type:'f', value:0},
? ? ? ? ? ? minHeight:{type:'f', value:1},
? ? ? ? },
? ? ? ? attributes:{
? ? ? ? },
? ? ? ? vertexShader: document.getElementById("vert").textContent,
? ? ? ? fragmentShader: document.getElementById("frag").textContent,
? ? ? ? //wireframe:true,
? ??
? ? });




其中紋理的值 0, 1 表示GPU內部的紋理編號, 這個數量受硬件限制。


頂點shader


? ? varying vec3 pos;
void main( void ) {


? ? ? ? pos = position.xyz;
? ? ? ? gl_Position = projectionMatrix * modelViewMatrix * vec4(position.xyz, 1);

}






















轉載于:https://my.oschina.net/u/186074/blog/79069

總結

以上是生活随笔為你收集整理的three.js(五) 地形纹理混合的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美无砖砖区免费 | 三上悠亚ed2k | 海角社区在线视频播放观看 | 毛片黄色片| 少女忠诚电影高清免费 | 欧美日韩亚洲精品内裤 | 无码人妻精品一区二区50 | 欧美一级电影在线 | 亚洲a中文字幕 | 日韩精品人妻中文字幕有码 | 国产精品久久久久久久无码 | 亚洲国产一区二区三区 | 成人黄色电影在线 | 日日操夜夜骑 | 欧美77777| 性猛交xxxx乱大交3 | 香蕉视频在线观看视频 | 以女性视角写的高h爽文 | 丝袜一区二区三区 | 天天爽夜夜爽人人爽 | 精品一二三四区 | 欧美粗暴jizz性欧美20 | 国产精品美女久久久久久久久 | 亚洲精品一级片 | 国产羞羞 | 午夜爽视频 | 久久久久性色av无码一区二区 | 99久久久国产精品 | 67194午夜 | 在线理论视频 | 射死你天天日 | 久草91| 亚洲蜜桃精久久久久久久久久久久 | 中文字幕在线字幕中文 | 日韩在线视频精品 | 日韩人妻精品一区二区 | 简单av在线 | 91精品在线播放 | 国产免费久久 | 欧美一区视频在线 | 尤物在线免费视频 | 黄页在线观看 | 美女脱裤子让男人捅 | 午夜精品久久久久久久久久久久 | 第色 | 欧美在线高清 | 91欧美成人 | 成人免费毛片男人用品 | 伊人色在线 | 先锋影音制服丝袜 | 一区二区日韩在线观看 | 精品女同一区二区三区 | 日韩美女视频网站 | 欧美成人专区 | 免费啪视频 | 国产黄色精品网站 | jizz中文字幕 | 欧洲一级黄 | 中文字幕精品三级久久久 | 日本乱子伦xxxx | 成年网站免费观看 | 日韩av毛片在线观看 | 黄色一机片 | a亚洲天堂 | 成人性生交大片免费看r链接 | 少妇在线播放 | 一本大道综合伊人精品热热 | 91蝌蚪九色| 韩漫动漫免费大全在线观看 | 黄色动漫免费在线观看 | 色多多视频网站 | 欧美日韩中文字幕视频 | 女裸全身无奶罩内裤内衣内裤 | 欧美在线观看a | 久热草 | 午夜av电影在线观看 | 黑人导航 | 精品国产乱码久久久久久蜜臀网站 | 五月婷综合网 | 国产群p| 久久亚洲精品无码va白人极品 | 高清乱码免费看污 | 又紧又大又爽精品一区二区 | 亚洲瘦老头同性xxxxx | 男人晚上看的视频 | 天天干天天爱天天射 | 91久久久久久久久 | 国产男男chinese网站 | 日韩福利在线观看 | 牛牛在线免费视频 | 香蕉视频传媒 | 欧美美女视频 | 国产亚洲精品精品国产亚洲综合 | 亚洲91精品 | 91在线观看免费高清 | 日韩女优一区二区 | 欧美日韩精品一区二区 | 男人操女人免费视频 | 欧美一区二区三区久久妖精 |