Sidebar.Object3D.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423
  1. Sidebar.Object3D = 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 container = new UI.Panel();
  10. container.setBorderTop( '1px solid #ccc' );
  11. container.setDisplay( 'none' );
  12. container.setPadding( '10px' );
  13. var objectType = new UI.Text().setColor( '#666' );
  14. container.add( objectType );
  15. container.add( new UI.Break(), new UI.Break() );
  16. // name
  17. var objectNameRow = new UI.Panel();
  18. var objectName = new UI.Input( 'absolute' ).setLeft( '100px' ).setWidth( '150px' ).setColor( '#444' ).setFontSize( '12px' ).onChange( update );
  19. objectNameRow.add( new UI.Text().setValue( 'Name' ).setColor( '#666' ) );
  20. objectNameRow.add( objectName );
  21. container.add( objectNameRow );
  22. // position
  23. var objectPositionRow = new UI.Panel();
  24. var objectPositionX = new UI.Number( 'absolute' ).setLeft( '100px' ).setWidth( '50px' ).onChange( update );
  25. var objectPositionY = new UI.Number( 'absolute' ).setLeft( '160px' ).setWidth( '50px' ).onChange( update );
  26. var objectPositionZ = new UI.Number( 'absolute' ).setLeft( '220px' ).setWidth( '50px' ).onChange( update );
  27. objectPositionRow.add( new UI.Text().setValue( 'Position' ).setColor( '#666' ) );
  28. objectPositionRow.add( objectPositionX, objectPositionY, objectPositionZ );
  29. container.add( objectPositionRow );
  30. // rotation
  31. var objectRotationRow = new UI.Panel();
  32. var objectRotationX = new UI.Number( 'absolute' ).setLeft( '100px' ).setWidth( '50px' ).onChange( update );
  33. var objectRotationY = new UI.Number( 'absolute' ).setLeft( '160px' ).setWidth( '50px' ).onChange( update );
  34. var objectRotationZ = new UI.Number( 'absolute' ).setLeft( '220px' ).setWidth( '50px' ).onChange( update );
  35. objectRotationRow.add( new UI.Text().setValue( 'Rotation' ).setColor( '#666' ) );
  36. objectRotationRow.add( objectRotationX, objectRotationY, objectRotationZ );
  37. container.add( objectRotationRow );
  38. // scale
  39. var objectScaleRow = new UI.Panel();
  40. var objectScaleX = new UI.Number( 'absolute' ).setValue( 1 ).setLeft( '100px' ).setWidth( '50px' ).onChange( updateScaleX );
  41. var objectScaleY = new UI.Number( 'absolute' ).setValue( 1 ).setLeft( '160px' ).setWidth( '50px' ).onChange( updateScaleY );
  42. var objectScaleZ = new UI.Number( 'absolute' ).setValue( 1 ).setLeft( '220px' ).setWidth( '50px' ).onChange( updateScaleZ );
  43. objectScaleRow.add( new UI.Text().setValue( 'Scale' ).setColor( '#666' ) );
  44. objectScaleRow.add( objectScaleX, objectScaleY, objectScaleZ );
  45. container.add( objectScaleRow );
  46. // uniform scale lock
  47. var objectScaleLockRow = new UI.Panel();
  48. var objectScaleLock = new UI.Checkbox( 'absolute' ).setLeft( '100px' ).onChange( updateScaleLock );
  49. objectScaleLockRow.add( new UI.Text().setValue( 'Uniform scale' ).setColor( '#666' ) );
  50. objectScaleLockRow.add( objectScaleLock );
  51. container.add( objectScaleLockRow );
  52. // visible
  53. var objectVisibleRow = new UI.Panel();
  54. var objectVisible = new UI.Checkbox( 'absolute' ).setLeft( '100px' ).onChange( update );
  55. objectVisibleRow.add( new UI.Text().setValue( 'Visible' ).setColor( '#666' ) );
  56. objectVisibleRow.add( objectVisible );
  57. container.add( objectVisibleRow );
  58. // fov
  59. var objectFovRow = new UI.Panel();
  60. var objectFov = new UI.Number( 'absolute' ).setLeft( '100px' ).onChange( update );
  61. objectFovRow.add( new UI.Text().setValue( 'Fov' ).setColor( '#666' ) );
  62. objectFovRow.add( objectFov );
  63. container.add( objectFovRow );
  64. // near
  65. var objectNearRow = new UI.Panel();
  66. var objectNear = new UI.Number( 'absolute' ).setLeft( '100px' ).onChange( update );
  67. objectNearRow.add( new UI.Text().setValue( 'Near' ).setColor( '#666' ) );
  68. objectNearRow.add( objectNear );
  69. container.add( objectNearRow );
  70. // far
  71. var objectFarRow = new UI.Panel();
  72. var objectFar = new UI.Number( 'absolute' ).setLeft( '100px' ).onChange( update );
  73. objectFarRow.add( new UI.Text().setValue( 'Far' ).setColor( '#666' ) );
  74. objectFarRow.add( objectFar );
  75. container.add( objectFarRow );
  76. // intensity
  77. var objectIntensityRow = new UI.Panel();
  78. var objectIntensity = new UI.Number( 'absolute' ).setRange( 0, Infinity ).setLeft( '100px' ).onChange( update );
  79. objectIntensityRow.add( new UI.Text().setValue( 'Intensity' ).setColor( '#666' ) );
  80. objectIntensityRow.add( objectIntensity );
  81. container.add( objectIntensityRow );
  82. // color
  83. var objectColorRow = new UI.Panel();
  84. var objectColor = new UI.Color( 'absolute' ).setLeft( '100px' ).onChange( update );
  85. objectColorRow.add( new UI.Text().setValue( 'Color' ).setColor( '#666' ) );
  86. objectColorRow.add( objectColor );
  87. container.add( objectColorRow );
  88. //
  89. var selected = null;
  90. var uniformScale = 1;
  91. var scaleRatioX = 1;
  92. var scaleRatioY = 1;
  93. var scaleRatioZ = 1;
  94. var scaleLock = false;
  95. function updateScaleLock() {
  96. scaleLock = objectScaleLock.getValue();
  97. if ( scaleLock ) {
  98. scaleRatioX = objectScaleX.getValue() / uniformScale;
  99. scaleRatioY = objectScaleY.getValue() / uniformScale;
  100. scaleRatioZ = objectScaleZ.getValue() / uniformScale;
  101. }
  102. }
  103. function updateScaleX() {
  104. uniformScale = objectScaleX.getValue();
  105. update();
  106. }
  107. function updateScaleY() {
  108. uniformScale = objectScaleY.getValue();
  109. update();
  110. }
  111. function updateScaleZ() {
  112. uniformScale = objectScaleZ.getValue();
  113. update();
  114. }
  115. function update() {
  116. if ( selected ) {
  117. selected.name = objectName.getValue();
  118. selected.position.x = objectPositionX.getValue();
  119. selected.position.y = objectPositionY.getValue();
  120. selected.position.z = objectPositionZ.getValue();
  121. selected.rotation.x = objectRotationX.getValue();
  122. selected.rotation.y = objectRotationY.getValue();
  123. selected.rotation.z = objectRotationZ.getValue();
  124. if ( scaleLock ) {
  125. objectScaleX.setValue( uniformScale * scaleRatioX );
  126. objectScaleY.setValue( uniformScale * scaleRatioY );
  127. objectScaleZ.setValue( uniformScale * scaleRatioZ );
  128. }
  129. selected.scale.x = objectScaleX.getValue();
  130. selected.scale.y = objectScaleY.getValue();
  131. selected.scale.z = objectScaleZ.getValue();
  132. selected.visible = objectVisible.getValue();
  133. if ( selected.fov !== undefined ) {
  134. selected.fov = objectFov.getValue();
  135. }
  136. if ( selected.near !== undefined ) {
  137. selected.near = objectNear.getValue();
  138. }
  139. if ( selected.far !== undefined ) {
  140. selected.far = objectFar.getValue();
  141. }
  142. if ( selected.intensity !== undefined ) {
  143. selected.intensity = objectIntensity.getValue();
  144. }
  145. if ( selected.color !== undefined ) {
  146. selected.color.setHex( objectColor.getHexValue() );
  147. }
  148. signals.objectChanged.dispatch( selected );
  149. }
  150. }
  151. function updateRows() {
  152. var properties = {
  153. 'fov': objectFovRow,
  154. 'near': objectNearRow,
  155. 'far': objectFarRow,
  156. 'intensity': objectIntensityRow,
  157. 'color': objectColorRow
  158. };
  159. for ( var property in properties ) {
  160. properties[ property ].setDisplay( selected[ property ] !== undefined ? '' : 'none' );
  161. }
  162. }
  163. function getObjectInstanceName( object ) {
  164. for ( var key in objects ) {
  165. if ( object instanceof objects[ key ] ) return key;
  166. }
  167. }
  168. // events
  169. signals.objectSelected.add( function ( object ) {
  170. selected = object;
  171. if ( object ) {
  172. container.setDisplay( 'block' );
  173. objectType.setValue( getObjectInstanceName( object ).toUpperCase() );
  174. objectName.setValue( object.name );
  175. objectPositionX.setValue( object.position.x );
  176. objectPositionY.setValue( object.position.y );
  177. objectPositionZ.setValue( object.position.z );
  178. objectRotationX.setValue( object.rotation.x );
  179. objectRotationY.setValue( object.rotation.y );
  180. objectRotationZ.setValue( object.rotation.z );
  181. objectScaleX.setValue( object.scale.x );
  182. objectScaleY.setValue( object.scale.y );
  183. objectScaleZ.setValue( object.scale.z );
  184. if ( object.fov !== undefined ) {
  185. objectFov.setValue( object.fov );
  186. }
  187. if ( object.near !== undefined ) {
  188. objectNear.setValue( object.near );
  189. }
  190. if ( object.far !== undefined ) {
  191. objectFar.setValue( object.far );
  192. }
  193. if ( object.intensity !== undefined ) {
  194. objectIntensity.setValue( object.intensity );
  195. }
  196. if ( object.color !== undefined ) {
  197. objectColor.setValue( '#' + object.color.getHexString() );
  198. }
  199. objectVisible.setValue( object.visible );
  200. updateRows();
  201. } else {
  202. container.setDisplay( 'none' );
  203. }
  204. } );
  205. signals.cameraChanged.add( function ( camera ) {
  206. if ( camera && camera === selected ) {
  207. refreshObjectUI( camera );
  208. }
  209. } );
  210. signals.objectChanged.add( function ( object ) {
  211. if ( object ) {
  212. refreshObjectUI( object );
  213. }
  214. } );
  215. function refreshObjectUI( object ) {
  216. container.setDisplay( 'block' );
  217. objectType.setValue( getObjectInstanceName( object ).toUpperCase() );
  218. objectName.setValue( object.name );
  219. objectPositionX.setValue( object.position.x );
  220. objectPositionY.setValue( object.position.y );
  221. objectPositionZ.setValue( object.position.z );
  222. objectRotationX.setValue( object.rotation.x );
  223. objectRotationY.setValue( object.rotation.y );
  224. objectRotationZ.setValue( object.rotation.z );
  225. objectScaleX.setValue( object.scale.x );
  226. objectScaleY.setValue( object.scale.y );
  227. objectScaleZ.setValue( object.scale.z );
  228. if ( object.fov !== undefined ) {
  229. objectFov.setValue( object.fov );
  230. }
  231. if ( object.near !== undefined ) {
  232. objectNear.setValue( object.near );
  233. }
  234. if ( object.far !== undefined ) {
  235. objectFar.setValue( object.far );
  236. }
  237. if ( object.intensity !== undefined ) {
  238. objectIntensity.setValue( object.intensity );
  239. }
  240. if ( object.color !== undefined ) {
  241. objectColor.setValue( '#' + object.color.getHexString() );
  242. }
  243. objectVisible.setValue( object.visible );
  244. }
  245. return container;
  246. }