2
0

Sidebar.Geometry.LatheGeometry.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /**
  2. * @author rfm1201
  3. */
  4. Sidebar.Geometry.LatheGeometry = function( editor, object ) {
  5. var signals = editor.signals;
  6. var container = new UI.Row();
  7. var geometry = object.geometry;
  8. var parameters = geometry.parameters;
  9. // segments
  10. var segmentsRow = new UI.Row();
  11. var segments = new UI.Integer( parameters.segments ).onChange( update );
  12. segmentsRow.add( new UI.Text( 'Segments' ).setWidth( '90px' ) );
  13. segmentsRow.add( segments );
  14. container.add( segmentsRow );
  15. // phiStart
  16. var phiStartRow = new UI.Row();
  17. var phiStart = new UI.Number( parameters.phiStart * 180 / Math.PI ).onChange( update );
  18. phiStartRow.add( new UI.Text( 'Phi start (°)' ).setWidth( '90px' ) );
  19. phiStartRow.add( phiStart );
  20. container.add( phiStartRow );
  21. // phiLength
  22. var phiLengthRow = new UI.Row();
  23. var phiLength = new UI.Number( parameters.phiLength * 180 / Math.PI ).onChange( update );
  24. phiLengthRow.add( new UI.Text( 'Phi length (°)' ).setWidth( '90px' ) );
  25. phiLengthRow.add( phiLength );
  26. container.add( phiLengthRow );
  27. // points
  28. var lastPointIdx = 0;
  29. var pointsUI = [];
  30. var pointsRow = new UI.Row();
  31. pointsRow.add( new UI.Text( 'Points' ).setWidth( '90px' ) );
  32. var points = new UI.Span().setDisplay( 'inline-block' );
  33. pointsRow.add( points );
  34. var pointsList = new UI.Div();
  35. points.add( pointsList );
  36. for ( var i = 0; i < parameters.points.length; i ++ ) {
  37. var point = parameters.points[ i ];
  38. pointsList.add( createPointRow( point.x, point.y ) );
  39. }
  40. var addPointButton = new UI.Button( '+' ).onClick( function() {
  41. if( pointsUI.length === 0 ){
  42. pointsList.add( createPointRow( 0, 0 ) );
  43. } else {
  44. var point = pointsUI[ pointsUI.length - 1 ];
  45. pointsList.add( createPointRow( point.x.getValue(), point.y.getValue() ) );
  46. }
  47. update();
  48. } );
  49. points.add( addPointButton );
  50. container.add( pointsRow );
  51. //
  52. function createPointRow( x, y ) {
  53. var pointRow = new UI.Div();
  54. var lbl = new UI.Text( lastPointIdx + 1 ).setWidth( '20px' );
  55. var txtX = new UI.Number( x ).setRange( 0, Infinity ).setWidth( '40px' ).onChange( update );
  56. var txtY = new UI.Number( y ).setWidth( '40px' ).onChange( update );
  57. var idx = lastPointIdx;
  58. var btn = new UI.Button( '-' ).onClick( function() {
  59. deletePointRow( idx );
  60. } );
  61. pointsUI.push( { row: pointRow, lbl: lbl, x: txtX, y: txtY } );
  62. lastPointIdx ++;
  63. pointRow.add( lbl, txtX, txtY, btn );
  64. return pointRow;
  65. }
  66. function deletePointRow( idx ) {
  67. if ( ! pointsUI[ idx ] ) return;
  68. pointsList.remove( pointsUI[ idx ].row );
  69. pointsUI[ idx ] = null;
  70. update();
  71. }
  72. function update() {
  73. var points = [];
  74. var count = 0;
  75. for ( var i = 0; i < pointsUI.length; i ++ ) {
  76. var pointUI = pointsUI[ i ];
  77. if ( ! pointUI ) continue;
  78. points.push( new THREE.Vector2( pointUI.x.getValue(), pointUI.y.getValue() ) );
  79. count ++;
  80. pointUI.lbl.setValue( count );
  81. }
  82. editor.execute( new SetGeometryCommand( object, new THREE[ geometry.type ](
  83. points,
  84. segments.getValue(),
  85. phiStart.getValue() / 180 * Math.PI,
  86. phiLength.getValue() / 180 * Math.PI
  87. ) ) );
  88. }
  89. return container;
  90. };
  91. Sidebar.Geometry.LatheBufferGeometry = Sidebar.Geometry.LatheGeometry;