123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- Sidebar.Outliner = function ( signals ) {
- var objectTypes = {
- 'PerspectiveCamera': THREE.PerspectiveCamera,
- 'PointLight': THREE.PointLight,
- 'DirectionalLight': THREE.DirectionalLight,
- 'Mesh': THREE.Mesh,
- 'Object3D': THREE.Object3D
- };
- var selected = null;
- var container = new UI.Panel();
- container.setPadding( '10px' );
- container.setBorderTop( '1px solid #ccc' );
- container.add( new UI.Text().setValue( 'SCENE' ).setColor( '#666' ) );
- container.add( new UI.Button( 'absolute' ).setRight( '8px' ).setTop( '5px' ).setLabel( 'Export' ).onClick( exportScene ) );
- container.add( new UI.Break(), new UI.Break() );
- var sceneGraph = new UI.FancySelect().setWidth( '100%' ).setHeight('140px').setColor( '#444' ).setFontSize( '12px' ).onChange( update );
- container.add( sceneGraph );
- var scene = null;
- function update() {
- var id = parseInt( sceneGraph.getValue() );
- scene.traverse( function ( node ) {
- if ( node.id === id ) {
- signals.objectSelected.dispatch( node );
- return;
- }
- } );
- }
- function getObjectType( object ) {
- for ( var type in objectTypes ) {
- if ( object instanceof objectTypes[ type ] ) return type;
- }
- }
- // events
- signals.sceneCreated.add( function ( object ) {
- scene = object;
- } );
- signals.sceneChanged.add( function ( object ) {
- scene = object;
- var options = {};
- ( function createList( object, pad ) {
- for ( var key in object.children ) {
- var child = object.children[ key ];
- options[ child.id ] = pad + child.name + ' <span style="color: #aaa">- ' + getObjectType( child ) + '</span>';
- createList( child, pad + ' ' );
- }
- } )( scene, '' );
- sceneGraph.setOptions( options );
- } );
- signals.objectSelected.add( function ( object ) {
- sceneGraph.setValue( object !== null ? object.id : null );
- } );
- signals.clearColorChanged.add( function ( color ) {
- clearColor.setHex( color );
- } );
- function exportScene() {
- signals.exportScene.dispatch( scene );
- }
- return container;
- }
|