Sidebar.Geometry.SphereGeometry.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. Sidebar.Geometry.SphereGeometry = function ( signals, object ) {
  2. var container = new UI.Panel();
  3. var geometry = object.geometry;
  4. // radius
  5. var radiusRow = new UI.Panel();
  6. var radius = new UI.Number( geometry.parameters.radius ).onChange( update );
  7. radiusRow.add( new UI.Text( 'Radius' ).setWidth( '90px' ) );
  8. radiusRow.add( radius );
  9. container.add( radiusRow );
  10. // widthSegments
  11. var widthSegmentsRow = new UI.Panel();
  12. var widthSegments = new UI.Integer( geometry.parameters.widthSegments ).setRange( 1, Infinity ).onChange( update );
  13. widthSegmentsRow.add( new UI.Text( 'Width segments' ).setWidth( '90px' ) );
  14. widthSegmentsRow.add( widthSegments );
  15. container.add( widthSegmentsRow );
  16. // heightSegments
  17. var heightSegmentsRow = new UI.Panel();
  18. var heightSegments = new UI.Integer( geometry.parameters.heightSegments ).setRange( 1, Infinity ).onChange( update );
  19. heightSegmentsRow.add( new UI.Text( 'Height segments' ).setWidth( '90px' ) );
  20. heightSegmentsRow.add( heightSegments );
  21. container.add( heightSegmentsRow );
  22. // phiStart
  23. var phiStartRow = new UI.Panel();
  24. var phiStart = new UI.Number( geometry.parameters.phiStart ).onChange( update );
  25. phiStartRow.add( new UI.Text( 'Phi start' ).setWidth( '90px' ) );
  26. phiStartRow.add( phiStart );
  27. container.add( phiStartRow );
  28. // phiLength
  29. var phiLengthRow = new UI.Panel();
  30. var phiLength = new UI.Number( geometry.parameters.phiLength ).onChange( update );
  31. phiLengthRow.add( new UI.Text( 'Phi length' ).setWidth( '90px' ) );
  32. phiLengthRow.add( phiLength );
  33. container.add( phiLengthRow );
  34. // thetaStart
  35. var thetaStartRow = new UI.Panel();
  36. var thetaStart = new UI.Number( geometry.parameters.thetaStart ).onChange( update );
  37. thetaStartRow.add( new UI.Text( 'Theta start' ).setWidth( '90px' ) );
  38. thetaStartRow.add( thetaStart );
  39. container.add( thetaStartRow );
  40. // thetaLength
  41. var thetaLengthRow = new UI.Panel();
  42. var thetaLength = new UI.Number( geometry.parameters.thetaLength ).onChange( update );
  43. thetaLengthRow.add( new UI.Text( 'Theta length' ).setWidth( '90px' ) );
  44. thetaLengthRow.add( thetaLength );
  45. container.add( thetaLengthRow );
  46. //
  47. function update() {
  48. object.geometry.dispose();
  49. object.geometry = new THREE.SphereGeometry(
  50. radius.getValue(),
  51. widthSegments.getValue(),
  52. heightSegments.getValue(),
  53. phiStart.getValue(),
  54. phiLength.getValue(),
  55. thetaStart.getValue(),
  56. thetaLength.getValue()
  57. );
  58. object.geometry.buffersNeedUpdate = true;
  59. object.geometry.computeBoundingSphere();
  60. signals.objectChanged.dispatch( object );
  61. }
  62. return container;
  63. }