Sidebar.Geometry.SphereGeometry.js 2.5 KB

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