three.js OBJLoader

2023-02-16 17:50 更新

用于加載 .obj 資源的加載器。

OBJ 文件格式是一種簡單的數(shù)據(jù)格式, 這種格式以人類可讀的形式來表示3D幾何體,即每個頂點的位置、每個紋理坐標(biāo)頂點的UV位置、頂點法線、 將使每個多邊形定義為頂點列表的面以及紋理頂點。

代碼示例

// instantiate a loader
const loader = new OBJLoader();

// load a resource
loader.load(
	// resource URL
	'models/monster.obj',
	// called when resource is loaded
	function ( object ) {

		scene.add( object );

	},
	// called when loading is in progresses
	function ( xhr ) {

		console.log( ( xhr.loaded / xhr.total * 100 ) + '% loaded' );

	},
	// called when loading has errors
	function ( error ) {

		console.log( 'An error happened' );

	}
);

例子

webgl_loader_obj

構(gòu)造函數(shù)

OBJLoader( manager : LoadingManager )

manager — 加載器使用的loadingManager(加載管理器),默認(rèn)值是THREE.DefaultLoadingManager。

創(chuàng)建一個新的OBJLoader。

屬性

共有屬性請參見其基類Loader。

方法

共有方法請參見其基類Loader。

.load ( url : String, onLoad : Function, onProgress : Function, onError : Function ) : undefined

url — 一個包含有.obj文件的路徑或URL的字符串。
onLoad — 當(dāng)加載過程成功完成以后將被調(diào)用的函數(shù)。
onProgress — (可選)加載過程正在進(jìn)行的時候被調(diào)用的函數(shù)。其參數(shù)是一個XMLHttpRequest實例,其包含了total bytes(總的字節(jié)數(shù))和loaded bytes(已經(jīng)載入的字節(jié)數(shù))。
onError — (可選) 加載過程中若發(fā)生了錯誤將被調(diào)用的函數(shù)。這一函數(shù)接收錯誤作為參數(shù)。

開始從URL中加載,并使用包含有已被解析響應(yīng)內(nèi)容來調(diào)用onLoad。

.parse ( text : String ) : Object3D

text — 要解析的表示 obj 結(jié)構(gòu)的文本。

返回一個Object3D。它包含了解析過后的網(wǎng)格(解析為Mesh)以及線條(解析為LineSegments)。所有的幾何體被創(chuàng)建為BufferGeometry,默認(rèn)材質(zhì)被創(chuàng)建為MeshPhongMaterial。如果obj物體或組在聲明面時使用了多個材質(zhì),則使用幾何體組和材質(zhì)數(shù)組。

.setMaterials ( materials : MTLLoader.MaterialCreator ) : this

MTLLoader.MaterialCreator materials - 一個 MaterialCreator 實例。

設(shè)置由 MTLLoader 載入的材質(zhì),或是其它由 MTLLoader.MaterialCreator 提供的材質(zhì)。

源碼

examples/jsm/loaders/OBJLoader.js


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號