/**
* @author Russell Toris - russell.toris@gmail.com
*/
/**
* A button renders a button with text to an internal canvas. The width will scale to fit the text.
*/
class Button {
/**
* @param {Object} options - possible keys include:
* @param {string} options.text - the text to display on the button
* @param {number} options.height - the height of the button
*/
constructor(options) {
options = options || {};
this.text = options.text;
this.height = options.height;
// used to draw the text internally
this.canvas = document.createElement('canvas');
this.redraw();
}
redraw() {
const context = this.canvas.getContext('2d');
// determine text size
const buttonPadding = this.height * 0.33;
context.font = this.height - buttonPadding + 'px Verdana';
this.width = context.measureText(this.text).width + buttonPadding * 2;
this.canvas.width = this.width;
this.canvas.height = this.height;
// create the image
const image = new Image();
// keep the base64 representation internally
image.src =
'';
// draw the button
context.drawImage(image, 0, 0, this.width, this.height);
// draw the text
context.font = this.height - buttonPadding + 'px Verdana';
context.fillStyle = '#121212';
context.fillText(this.text, buttonPadding, this.height - buttonPadding);
}
}
export default Button;