欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Three.js后期處理效果(發(fā)光描邊OutlinePass)

 更新時(shí)間:2024年01月18日 09:12:40   作者:Threejs可視化  
這篇文章主要給大家介紹了關(guān)于Three.js后期處理效果(發(fā)光描邊OutlinePass)的相關(guān)資料,Three js 開發(fā)的一些知識(shí)整理,方便后期遇到類似的問(wèn)題,能夠及時(shí)查閱使用,需要的朋友可以參考下

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)控件學(xué)習(xí)筆記,介紹了Bootstrap開關(guān)(switch)控件的功能、使用說(shuō)明,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 微信小程序?qū)崿F(xiàn)富文本圖片寬度自適應(yīng)的方法

    微信小程序?qū)崿F(xiàn)富文本圖片寬度自適應(yīng)的方法

    小程序里圖片會(huì)顯示不全,這時(shí)就應(yīng)該做相應(yīng)的處理,使小程序里圖片顯示正確,這篇文章主要介紹了微信小程序?qū)崿F(xiàn)富文本圖片寬度自適應(yīng)的方法,感興趣的小伙伴們可以參考一下
    2019-01-01
  • JavaScript將對(duì)象數(shù)組按字母順序排序的方法詳解

    JavaScript將對(duì)象數(shù)組按字母順序排序的方法詳解

    這篇文章主要介紹了JavaScript如何將對(duì)象數(shù)組按字母順序排序,本文介紹了三種解決方案,if條件語(yǔ)句 + sort(),localeCompare() + sort(),Collator() + sort(),有感興趣的同學(xué)可以跟著小編一起來(lái)看看
    2023-07-07
  • 在table中插入多行的js代碼(與insertAdjacentHTML相似的功能)

    在table中插入多行的js代碼(與insertAdjacentHTML相似的功能)

    在table中插入多行,能使用與insertAdjacentHTML相似的功能
    2010-06-06
  • JavaScript自學(xué)筆記(必看篇)

    JavaScript自學(xué)筆記(必看篇)

    下面小編就為大家?guī)?lái)一篇JavaScript自學(xué)筆記(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • js仿京東輪播效果 選項(xiàng)卡套選項(xiàng)卡使用

    js仿京東輪播效果 選項(xiàng)卡套選項(xiàng)卡使用

    這篇文章主要為大家詳細(xì)介紹了js仿京東輪播效果,選項(xiàng)卡里套選項(xiàng)卡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例

    JavaScript代碼模擬鼠標(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ù)量

    詳解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-01
  • 為指定元素增加樣式的js代碼

    為指定元素增加樣式的js代碼

    從此例子中發(fā)現(xiàn),js對(duì)"" 與 " " ,注意中間還有一空格,解析是非常嚴(yán)格的。在java與net中還有待于研究。
    2009-12-12
  • cnblogs csdn 代碼運(yùn)行框?qū)崿F(xiàn)代碼

    cnblogs 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

最新評(píng)論