Three.js后期處理效果(發(fā)光描邊OutlinePass)
Three.js后處理(發(fā)光描邊OutlinePass)
參考資料:Threejs中文網(wǎng)
查看threejs文件包目錄examples/jsm/postprocessing/
,你可以看到Three.js提供了一個(gè)擴(kuò)展庫(kù)EffectComposer.js
,通過(guò)EffectComposer可以實(shí)現(xiàn)一些后期處理效果。
所謂threejs后期處理,就像ps一樣,對(duì)threejs的渲染結(jié)果進(jìn)行后期處理,比如添加發(fā)光效果。
不同功能后處理通道
查看threejs文件包目錄examples/jsm/postprocessing/
,你可以看到threejs提供了很多后處理通道,想實(shí)現(xiàn)什么樣的后期處理效果,需要調(diào)用threejs對(duì)應(yīng)的后處理通道擴(kuò)展庫(kù)。
OutlinePass.js
:高亮發(fā)光描邊UnrealBloomPass.js
:Bloom發(fā)光GlitchPass.js
:畫面抖動(dòng)效果
比如OutlinePass.js
擴(kuò)展庫(kù)提供的類OutlinePass
就可以給一個(gè)模型添加一個(gè)高亮發(fā)光描邊,下面就給大家演示下如何實(shí)現(xiàn)。
引入EffectComposer.js
你可以在threejs文件包目錄examples/jsm/postprocessing/
找到擴(kuò)展庫(kù)EffectComposer.js。
代碼中引入后處理擴(kuò)展庫(kù)EffectComposer.js
import { EffectComposer } from 'three/addons/postprocessing/EffectComposer.js';
大家都知道three.js WebGL渲染器執(zhí)行渲染方法.render()
會(huì)得到一張圖像,如果你需要對(duì)一個(gè)webgl渲染器的渲染結(jié)果進(jìn)行后期處理,就把它作為EffectComposer
的參數(shù)。
// 創(chuàng)建后處理對(duì)象EffectComposer,WebGL渲染器作為參數(shù) const composer = new EffectComposer(renderer);
渲染器通道RenderPass
RenderPass.js擴(kuò)展庫(kù)目錄:examples/jsm/postprocessing/
// 引入渲染器通道RenderPass import { RenderPass } from 'three/addons/postprocessing/RenderPass.js';
通過(guò)EffectComposer(renderer)
指定了需要后處理的渲染器WebGLRenderer
,渲染器通道RenderPass
的作用是指定后處理對(duì)應(yīng)的相機(jī)camera
和場(chǎng)景scene
。
// 創(chuàng)建一個(gè)渲染器通道,場(chǎng)景和相機(jī)作為參數(shù) const renderPass = new RenderPass(scene, camera);
給EffectComposer
添加一個(gè)渲染器通道RenderPass
。
// 設(shè)置renderPass通道 composer.addPass(renderPass);
OutlinePass通道
OutlinePass
可以給指定的某個(gè)模型對(duì)象添加一個(gè)高亮發(fā)光描邊效果。
OutlinePass.js擴(kuò)展庫(kù)目錄:examples/jsm/postprocessing/
// 引入OutlinePass通道 import { OutlinePass } from 'three/addons/postprocessing/OutlinePass.js';
創(chuàng)建OutlinePass通道
// OutlinePass第一個(gè)參數(shù)v2的尺寸和canvas畫布保持一致 const v2 = new THREE.Vector2(window.innerWidth, window.innerHeight); // const v2 = new THREE.Vector2(800, 600); const outlinePass = new OutlinePass(v2, scene, camera);
OutlinePass屬性.selectedObjects
three.js場(chǎng)景中有多個(gè)模型的話,你希望給哪個(gè)模型對(duì)象設(shè)置發(fā)光描邊效果,就可以通過(guò)OutlinePass的選擇對(duì)象屬性.selectedObjects
設(shè)置。
// 一個(gè)模型對(duì)象 outlinePass.selectedObjects = [mesh]; // 多個(gè)模型對(duì)象 outlinePass.selectedObjects = [mesh1,mesh2,group];
設(shè)置OutlinePass通道
最后把創(chuàng)建好的OutlinePass通道添加到后處理composer中。
// 設(shè)置OutlinePass通道 composer.addPass(outlinePass);
渲染循環(huán)執(zhí)行EffectComposer.render()
渲染循環(huán)中后處理EffectComposer執(zhí)行.render()
,會(huì)調(diào)用webgl渲染器執(zhí)行.render()
,也就是說(shuō)renderer.render(scene, camera)
不用再執(zhí)行。
// 渲染循環(huán) function render() { composer.render(); // renderer.render(scene, camera); requestAnimationFrame(render); } render();
修改OutlinePass默認(rèn)描邊效果
參考下節(jié)課具體講解
總結(jié)
到此這篇關(guān)于Three.js后期處理效果(發(fā)光描邊OutlinePass)的文章就介紹到這了,更多相關(guān)Three.js發(fā)光描邊OutlinePass內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Bootstrap開關(guān)(switch)控件學(xué)習(xí)筆記分享
這篇文章主要為大家分享了Bootstrap開關(guān)(switch)控件學(xué)習(xí)筆記,介紹了Bootstrap開關(guān)(switch)控件的功能、使用說(shuō)明,感興趣的小伙伴們可以參考一下2016-05-05微信小程序?qū)崿F(xiàn)富文本圖片寬度自適應(yīng)的方法
小程序里圖片會(huì)顯示不全,這時(shí)就應(yīng)該做相應(yīng)的處理,使小程序里圖片顯示正確,這篇文章主要介紹了微信小程序?qū)崿F(xiàn)富文本圖片寬度自適應(yīng)的方法,感興趣的小伙伴們可以參考一下2019-01-01JavaScript將對(duì)象數(shù)組按字母順序排序的方法詳解
這篇文章主要介紹了JavaScript如何將對(duì)象數(shù)組按字母順序排序,本文介紹了三種解決方案,if條件語(yǔ)句 + sort(),localeCompare() + sort(),Collator() + sort(),有感興趣的同學(xué)可以跟著小編一起來(lái)看看2023-07-07在table中插入多行的js代碼(與insertAdjacentHTML相似的功能)
在table中插入多行,能使用與insertAdjacentHTML相似的功能2010-06-06js仿京東輪播效果 選項(xiàng)卡套選項(xiàng)卡使用
這篇文章主要為大家詳細(xì)介紹了js仿京東輪播效果,選項(xiàng)卡里套選項(xiàng)卡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例
這篇文章主要介紹了JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例,文章通過(guò)示例代碼和運(yùn)行效果圖介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08詳解JavaScript如何控制并發(fā)請(qǐng)求數(shù)量
某些情況下,我們可能需要對(duì)需要執(zhí)行的多個(gè)異步任務(wù)進(jìn)行異步數(shù)量控制,只允許固定數(shù)量的任務(wù)執(zhí)行,本文為大家整理了JS控制并發(fā)請(qǐng)求數(shù)量的相關(guān)代碼,希望對(duì)大家有所幫助2024-01-01cnblogs csdn 代碼運(yùn)行框?qū)崿F(xiàn)代碼
大家用cnblogs,csdn博客發(fā)布技術(shù)文檔的時(shí)候,可以用下面的代碼實(shí)現(xiàn)運(yùn)行功能。當(dāng)然大家看了源碼就會(huì)發(fā)現(xiàn)其實(shí)方法還有很多。有更好的方法就發(fā)布一下啊。2009-11-11