| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 | function painterSortStable( a, b ) {	if ( a.groupOrder !== b.groupOrder ) {		return a.groupOrder - b.groupOrder;	} else if ( a.renderOrder !== b.renderOrder ) {		return a.renderOrder - b.renderOrder;	} else if ( a.material.id !== b.material.id ) {		return a.material.id - b.material.id;	} else if ( a.z !== b.z ) {		return a.z - b.z;	} else {		return a.id - b.id;	}}function reversePainterSortStable( a, b ) {	if ( a.groupOrder !== b.groupOrder ) {		return a.groupOrder - b.groupOrder;	} else if ( a.renderOrder !== b.renderOrder ) {		return a.renderOrder - b.renderOrder;	} else if ( a.z !== b.z ) {		return b.z - a.z;	} else {		return a.id - b.id;	}}class WebGPURenderList {	constructor() {		this.renderItems = [];		this.renderItemsIndex = 0;		this.opaque = [];		this.transparent = [];	}	init() {		this.renderItemsIndex = 0;		this.opaque.length = 0;		this.transparent.length = 0;	}	getNextRenderItem( object, geometry, material, groupOrder, z, group ) {		let renderItem = this.renderItems[ this.renderItemsIndex ];		if ( renderItem === undefined ) {			renderItem = {				id: object.id,				object: object,				geometry: geometry,				material: material,				groupOrder: groupOrder,				renderOrder: object.renderOrder,				z: z,				group: group			};			this.renderItems[ this.renderItemsIndex ] = renderItem;		} else {			renderItem.id = object.id;			renderItem.object = object;			renderItem.geometry = geometry;			renderItem.material = material;			renderItem.groupOrder = groupOrder;			renderItem.renderOrder = object.renderOrder;			renderItem.z = z;			renderItem.group = group;		}		this.renderItemsIndex ++;		return renderItem;	}	push( object, geometry, material, groupOrder, z, group ) {		const renderItem = this.getNextRenderItem( object, geometry, material, groupOrder, z, group );		( material.transparent === true ? this.transparent : this.opaque ).push( renderItem );	}	unshift( object, geometry, material, groupOrder, z, group ) {		const renderItem = this.getNextRenderItem( object, geometry, material, groupOrder, z, group );		( material.transparent === true ? this.transparent : this.opaque ).unshift( renderItem );	}	sort( customOpaqueSort, customTransparentSort ) {		if ( this.opaque.length > 1 ) this.opaque.sort( customOpaqueSort || painterSortStable );		if ( this.transparent.length > 1 ) this.transparent.sort( customTransparentSort || reversePainterSortStable );	}	finish() {		// Clear references from inactive renderItems in the list		for ( let i = this.renderItemsIndex, il = this.renderItems.length; i < il; i ++ ) {			const renderItem = this.renderItems[ i ];			if ( renderItem.id === null ) break;			renderItem.id = null;			renderItem.object = null;			renderItem.geometry = null;			renderItem.material = null;			renderItem.program = null;			renderItem.group = null;		}	}}class WebGPURenderLists {	constructor() {		this.lists = new WeakMap();	}	get( scene, camera ) {		const lists = this.lists;		const cameras = lists.get( scene );		let list;		if ( cameras === undefined ) {			list = new WebGPURenderList();			lists.set( scene, new WeakMap() );			lists.get( scene ).set( camera, list );		} else {			list = cameras.get( camera );			if ( list === undefined ) {				list = new WebGPURenderList();				cameras.set( camera, list );			}		}		return list;	}	dispose() {		this.lists = new WeakMap();	}}export default WebGPURenderLists;
 |