Sidebar.Outliner.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. Sidebar.Outliner = function ( signals ) {
  2. var objects = {
  3. 'PerspectiveCamera': THREE.PerspectiveCamera,
  4. 'PointLight': THREE.PointLight,
  5. 'DirectionalLight': THREE.DirectionalLight,
  6. 'Mesh': THREE.Mesh,
  7. 'Object3D': THREE.Object3D
  8. };
  9. var selected = null;
  10. var container = new UI.Panel();
  11. container.setPadding( '8px' );
  12. container.setBorderTop( '1px solid #ccc' );
  13. container.add( new UI.Text().setValue( 'SCENE' ).setColor( '#666' ) );
  14. container.add( new UI.Break(), new UI.Break() );
  15. var sceneGraph = new UI.Select().setMultiple( true ).setWidth( '100%' ).setHeight('140px').setColor( '#444' ).setFontSize( '12px' ).onChange( update );
  16. container.add( sceneGraph );
  17. container.add( new UI.Break(), new UI.Break() );
  18. var scene = null;
  19. function update() {
  20. var id = parseInt( sceneGraph.getValue() );
  21. for ( var i in scene.children ) {
  22. var object = scene.children[ i ];
  23. if ( object.id === id ) {
  24. signals.objectSelected.dispatch( object );
  25. return;
  26. }
  27. }
  28. }
  29. function getObjectInstanceName( object ) {
  30. for ( var key in objects ) {
  31. if ( object instanceof objects[ key ] ) return key;
  32. }
  33. }
  34. // events
  35. signals.sceneChanged.add( function ( object ) {
  36. scene = object;
  37. var options = {};
  38. ( function createList( object, pad ) {
  39. for ( var key in object.children ) {
  40. var child = object.children[ key ];
  41. options[ child.id ] = pad + '+ ' + object.name + ' [' + getObjectInstanceName( child ) + ']';
  42. createList( child, pad + '   ' );
  43. }
  44. } )( scene, '' );
  45. sceneGraph.setOptions( options );
  46. } );
  47. signals.objectSelected.add( function ( object ) {
  48. sceneGraph.setValue( object !== null ? object.id: null );
  49. } );
  50. return container;
  51. }