Toolbar.js 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. var Toolbar = function ( editor ) {
  2. var signals = editor.signals;
  3. var container = new UI.Panel();
  4. container.setPosition( 'absolute' );
  5. container.setClass( 'toolbar' );
  6. var buttons = new UI.Panel();
  7. container.add( buttons );
  8. // translate / rotate / scale
  9. var translate = new UI.Button( 'translate' ).onClick( function () {
  10. signals.transformModeChanged.dispatch( 'translate' );
  11. } );
  12. buttons.add( translate );
  13. var rotate = new UI.Button( 'rotate' ).onClick( function () {
  14. signals.transformModeChanged.dispatch( 'rotate' );
  15. } );
  16. buttons.add( rotate );
  17. var scale = new UI.Button( 'scale' ).onClick( function () {
  18. signals.transformModeChanged.dispatch( 'scale' );
  19. } );
  20. buttons.add( scale );
  21. // grid
  22. var grid = new UI.Number( 25 ).onChange( update );
  23. grid.dom.style.width = '42px';
  24. buttons.add( new UI.Text( 'Grid: ' ) );
  25. buttons.add( grid );
  26. var snap = new UI.Checkbox( false ).onChange( update );
  27. buttons.add( snap );
  28. buttons.add( new UI.Text( 'snap' ) );
  29. function update() {
  30. signals.snapChanged.dispatch( snap.getValue() === true ? grid.getValue() : null );
  31. }
  32. update();
  33. return container;
  34. }