Button.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /************************************************************************
  2. * Button.js
  3. ************************************************************************
  4. * Copyright (c) 2021 Pedro Tonini Rosenberg Schneider.
  5. *
  6. * This file is part of Pandora.
  7. *
  8. * Pandora is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * Pandora is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with Pandora. If not, see <https://www.gnu.org/licenses/>.
  20. *************************************************************************/
  21. /**
  22. * The {@code Button} class represents an UIObject that holds and HTML button.
  23. *
  24. * ! All GameObjects need to be inside the tree to do anything (can be added as a child
  25. * ! of another GameObject on the tree or as a root).
  26. *
  27. * @author Pedro Schneider
  28. *
  29. * @class
  30. */
  31. class Button extends UIObject
  32. {
  33. /**
  34. * Initializes an empty Button GameObject.
  35. *
  36. * @param {String} name
  37. * @param {String} label
  38. *
  39. * @constructor
  40. */
  41. constructor(name, label = "Button")
  42. {
  43. super(name);
  44. this.P5Element = createButton(); // This Button's HTML button.
  45. this.label = label; // This Button's label
  46. this.P5Element.html(label); // Set the label to the inner HTML of the button.
  47. this.setPosition(0, 0); // Set the position of the Button on the secondary buffer.
  48. this.setStyle(STYLE.DEFAULT_STYLE); // Set the default style of the UIObject.
  49. this.connectCallbacks(); // Connect the events of the p5.Element.
  50. }
  51. /**
  52. * Sets the label on this UIObject's button.
  53. *
  54. * @param {String} label new label for the button.
  55. */
  56. setLabel(label)
  57. {
  58. this.label = label;
  59. this.P5Element.html(label);
  60. }
  61. }