2023-02-05 01:56:04 +00:00
|
|
|
package lib.ui.elements;
|
|
|
|
|
|
|
|
import lib.ui.elements.UIElement;
|
|
|
|
|
|
|
|
class TextElement implements UIElement {
|
|
|
|
public var text:String;
|
|
|
|
|
|
|
|
private final uiEvents:UIEvents;
|
2023-07-11 11:17:33 +00:00
|
|
|
private final style:Style;
|
2023-02-05 01:56:04 +00:00
|
|
|
|
2023-07-30 13:55:22 +00:00
|
|
|
public function new(text:String, ?props:{?style:Style, ?uiEvents:UIEvents}) {
|
2023-02-05 01:56:04 +00:00
|
|
|
this.text = text;
|
2023-07-11 11:17:33 +00:00
|
|
|
this.uiEvents = props?.uiEvents;
|
|
|
|
this.style = props?.style ?? {fgColor: White, bgColor: Black};
|
2023-02-05 01:56:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function set(text:String) {
|
|
|
|
this.text = text;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get():String {
|
|
|
|
return this.text;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getEventHandlers():UIEvents {
|
|
|
|
return uiEvents;
|
|
|
|
}
|
|
|
|
|
2023-07-30 13:55:22 +00:00
|
|
|
public function render(bounds:Pos):Canvas {
|
2023-02-05 01:56:04 +00:00
|
|
|
var canvas = new Canvas();
|
2023-11-16 01:29:41 +00:00
|
|
|
|
|
|
|
var x = 0;
|
|
|
|
var y = 0;
|
|
|
|
|
2023-02-05 01:56:04 +00:00
|
|
|
for (i in 0...this.text.length) {
|
|
|
|
var c = this.text.charAt(i);
|
2023-11-16 01:29:41 +00:00
|
|
|
if (c == "\n") {
|
|
|
|
x = 0;
|
|
|
|
y++;
|
|
|
|
} else {
|
|
|
|
canvas.set({x: x, y: y}, {bg: style.bgColor ?? Black, textColor: style.fgColor ?? White, char: c});
|
|
|
|
x++;
|
|
|
|
}
|
2023-02-05 01:56:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return canvas;
|
|
|
|
}
|
|
|
|
}
|