在Three.js中動態(tài)改變meterial的著色器的不起作用的問題

????????最近在做Three.js相關(guān)的一些工作列林,其中需要對構(gòu)建好的mesh動態(tài)改變其著色器瑞你,于是就做了下面的修改

this.mesh.material.vertexShader = material.vertexShader;

this.mesh.material.fragmentShader = material.fragmentShader;

????????因為mesh是不斷創(chuàng)建、添加到scene中希痴,這就造成了一個問題者甲,著色器已經(jīng)修改完畢,在場景中應(yīng)該按照修改完的著色器的值來展示砌创,但現(xiàn)實卻不是过牙,而是一部分按照后來修改的著色器展示甥厦,一部分沒有按照修改完的著色器展示,也就是說--修改后的著色器使mesh的展示寇钉,一部分正常刀疙,一部分異常,這是為什么呢扫倡?

????????借助調(diào)試Spector.js工具的先看到修改之前的著色器谦秧,這里只看一個典型值NUMBER_OF_TEXTURES,修改shader之前是4撵溃;修改之后依然是4疚鲤。


shader修改之前


shader修改之后

????????是不是覺得很怪異,圖片是我偷懶復(fù)制粘貼的缘挑,但情況就是這樣集歇,why???

吾日三省吾身,著實經(jīng)過一番痛苦的自查语淘,自認為在代碼賦值這一塊應(yīng)該是沒問題的诲宇,那這是什么問題?惶翻?姑蓝?

后來就仔細跟了一下Three.js的源碼,發(fā)現(xiàn)在其內(nèi)部使用了一個叫WeakMap的鍵值對集合吕粗,搜索一下纺荧,巴拉巴拉一大堆,核心就最后一段


Why WeakMap


????????再看一下Three.js是如何使用這個東西的

WebGLProperties


在Three.js中這個類會將要渲染的material存放在這里面颅筋,等下次渲染時候會從這個緩存中查找宙暇,如果存在,就直接使用緩存中的shader议泵,恍然大悟占贫,原來如此;


修改后的shader
緩存中的shader


最后返回的shder

????????上面三幅圖就是造成我修改shader失敗的核心肢簿,回過頭再看一下WebGLProperties這個類,它有一個remove函數(shù)蜻拨,正好使用就是WeakMap的方法池充,那就每次修改著色器之前把當前的material從鍵值對中移除就好了吧?

WeakMap的remove方法

? ? ? ? 那么就把代碼做點修改吧缎讼,增加下面一句

修改后的賦值方式

? ? ? ? 代碼跑起來收夸,結(jié)果已經(jīng)可以預(yù)見。

????????僅此血崭,記錄一下Three.js的踩坑之旅卧惜。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末厘灼,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子咽瓷,更是在濱河造成了極大的恐慌设凹,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件茅姜,死亡現(xiàn)場離奇詭異闪朱,居然都是意外死亡,警方通過查閱死者的電腦和手機钻洒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門奋姿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人素标,你說我怎么就攤上這事称诗。” “怎么了头遭?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵寓免,是天一觀的道長。 經(jīng)常有香客問我任岸,道長再榄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任享潜,我火速辦了婚禮困鸥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘剑按。我一直安慰自己疾就,他們只是感情好,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布艺蝴。 她就那樣靜靜地躺著猬腰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪猜敢。 梳的紋絲不亂的頭發(fā)上姑荷,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天,我揣著相機與錄音缩擂,去河邊找鬼鼠冕。 笑死,一個胖子當著我的面吹牛胯盯,可吹牛的內(nèi)容都是我干的懈费。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼博脑,長吁一口氣:“原來是場噩夢啊……” “哼憎乙!你這毒婦竟也來了票罐?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤泞边,失蹤者是張志新(化名)和其女友劉穎该押,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體繁堡,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡沈善,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了椭蹄。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闻牡。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖绳矩,靈堂內(nèi)的尸體忽然破棺而出罩润,到底是詐尸還是另有隱情,我是刑警寧澤翼馆,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布割以,位于F島的核電站,受9級特大地震影響应媚,放射性物質(zhì)發(fā)生泄漏严沥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一中姜、第九天 我趴在偏房一處隱蔽的房頂上張望消玄。 院中可真熱鬧,春花似錦丢胚、人聲如沸翩瓜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽兔跌。三九已至,卻和暖如春峡蟋,著一層夾襖步出監(jiān)牢的瞬間坟桅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工蕊蝗, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留仅乓,地道東北人。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓匿又,卻偏偏與公主長得像方灾,于是被迫代替她去往敵國和親建蹄。 傳聞我的和親對象是個殘疾皇子碌更,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容