Sidebar.Geometry.SphereGeometry.js 2.4 KB

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