Sidebar.Geometry.CircleGeometry.js 972 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. Sidebar.Geometry.CircleGeometry = function ( signals, object ) {
  2. var container = new UI.Panel();
  3. var parameters = object.geometry.parameters;
  4. // radius
  5. var radiusRow = new UI.Panel();
  6. var radius = new UI.Number( parameters.radius ).onChange( update );
  7. radiusRow.add( new UI.Text( 'Radius' ).setWidth( '90px' ) );
  8. radiusRow.add( radius );
  9. container.add( radiusRow );
  10. // segments
  11. var segmentsRow = new UI.Panel();
  12. var segments = new UI.Integer( parameters.segments ).setRange( 3, Infinity ).onChange( update );
  13. segmentsRow.add( new UI.Text( 'Segments' ).setWidth( '90px' ) );
  14. segmentsRow.add( segments );
  15. container.add( segmentsRow );
  16. //
  17. function update() {
  18. object.geometry.dispose();
  19. object.geometry = new THREE.CircleGeometry(
  20. radius.getValue(),
  21. segments.getValue()
  22. );
  23. object.geometry.buffersNeedUpdate = true;
  24. object.geometry.computeBoundingSphere();
  25. signals.geometryChanged.dispatch( object );
  26. }
  27. return container;
  28. }