2022-01-13 05:24:03 +01:00
|
|
|
function Node_create_Text(_x, _y) {
|
|
|
|
var node = new Node_Text(_x, _y);
|
|
|
|
ds_list_add(PANEL_GRAPH.nodes_list, node);
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
function Node_Text(_x, _y) : Node_Processor(_x, _y) constructor {
|
|
|
|
name = "Text";
|
|
|
|
|
|
|
|
font = f_p0;
|
|
|
|
|
|
|
|
inputs[| 0] = nodeValue(0, "Text", self, JUNCTION_CONNECT.input, VALUE_TYPE.text, "");
|
|
|
|
|
|
|
|
inputs[| 1] = nodeValue(1, "Font", self, JUNCTION_CONNECT.input, VALUE_TYPE.path, "")
|
2022-01-19 03:05:13 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.path_load, ["*.ttf;*.otf", ""]);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-01-19 03:05:13 +01:00
|
|
|
inputs[| 2] = nodeValue(2, "Size", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 16);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
2022-01-19 03:05:13 +01:00
|
|
|
inputs[| 3] = nodeValue(3, "Anti-Aliasing ", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
inputs[| 4] = nodeValue(4, "Character range", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 32, 128 ])
|
2022-01-19 03:05:13 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.vector);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
inputs[| 5] = nodeValue(5, "Color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_white);
|
|
|
|
|
|
|
|
inputs[| 6] = nodeValue(6, "Fixed dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, def_surf_size2, VALUE_TAG.dimension_2d )
|
|
|
|
.setDisplay(VALUE_DISPLAY.vector)
|
|
|
|
.setVisible(true, false);
|
|
|
|
|
|
|
|
inputs[| 7] = nodeValue(7, "Horizontal alignment", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0 )
|
|
|
|
.setDisplay(VALUE_DISPLAY.enum_button, [ s_inspector_text_halign, s_inspector_text_halign, s_inspector_text_halign]);
|
|
|
|
|
|
|
|
inputs[| 8] = nodeValue(8, "Vertical alignment", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 0 )
|
|
|
|
.setDisplay(VALUE_DISPLAY.enum_button, [ s_inspector_text_valign, s_inspector_text_valign, s_inspector_text_valign ]);
|
|
|
|
|
|
|
|
inputs[| 9] = nodeValue(9, "Output dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1 )
|
2022-01-19 03:05:13 +01:00
|
|
|
.setDisplay(VALUE_DISPLAY.enum_scroll, [ "Fixed", "Dynamic" ]);
|
2022-01-13 05:24:03 +01:00
|
|
|
|
|
|
|
input_display_list = [
|
|
|
|
["Output", true], 9, 6,
|
|
|
|
["Text", false], 0, 7, 8, 5,
|
|
|
|
["Font properties", false], 1, 2, 3, 4
|
|
|
|
];
|
|
|
|
|
|
|
|
outputs[| 0] = nodeValue(0, "Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, surface_create(1, 1));
|
|
|
|
|
|
|
|
_font_current = "";
|
|
|
|
_size_current = 0;
|
|
|
|
_aa_current = false;
|
|
|
|
_rang_current = [0, 0];
|
|
|
|
|
|
|
|
static generateFont = function(_path, _size, _aa, _range) {
|
|
|
|
if(ANIMATOR.is_playing) return;
|
|
|
|
|
|
|
|
if(_path == _font_current && _size == _size_current && _aa == _aa_current && _rang_current[0] == _range[0] && _rang_current[1] == _range[1]) return;
|
|
|
|
_font_current = _path;
|
|
|
|
_size_current = _size;
|
|
|
|
_aa_current = _aa;
|
|
|
|
_rang_current[0] = _range[0];
|
|
|
|
_rang_current[1] = _range[1];
|
|
|
|
|
|
|
|
if(file_exists(_path)) {
|
|
|
|
if(font != f_p0 && font_exists(font))
|
|
|
|
font_delete(font);
|
|
|
|
font_add_enable_aa(_aa);
|
|
|
|
font = font_add(_path, _size, false, false, _range[0], _range[1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-01-18 05:31:19 +01:00
|
|
|
static process_data = function(_outSurf, _data, _output_index) {
|
2022-01-13 05:24:03 +01:00
|
|
|
var str = _data[0];
|
|
|
|
var _font = _data[1];
|
|
|
|
var _size = _data[2];
|
|
|
|
var _aa = _data[3];
|
|
|
|
var _range = _data[4];
|
|
|
|
var _col = _data[5];
|
|
|
|
|
|
|
|
var _dim_type = _data[9];
|
2022-01-19 06:11:17 +01:00
|
|
|
inputs[| 6].setVisible(!_dim_type);
|
2022-01-13 05:24:03 +01:00
|
|
|
var _dim = _data[6];
|
|
|
|
|
|
|
|
var ww, hh;
|
|
|
|
|
|
|
|
generateFont(_font, _size, _aa, _range);
|
|
|
|
|
|
|
|
draw_set_font(font);
|
|
|
|
if(_dim_type == 0) {
|
|
|
|
ww = _dim[0];
|
|
|
|
hh = _dim[1];
|
|
|
|
} else {
|
|
|
|
ww = max(1, string_width(str));
|
|
|
|
hh = max(1, string_height(str));
|
|
|
|
}
|
|
|
|
|
|
|
|
if(is_surface(_outSurf))
|
|
|
|
surface_size_to(_outSurf, ww, hh);
|
|
|
|
|
|
|
|
surface_set_target(_outSurf);
|
|
|
|
draw_clear_alpha(0, 0);
|
|
|
|
BLEND_ADD
|
|
|
|
|
|
|
|
if(_dim[0] != 0 && _dim[1] != 0) {
|
|
|
|
var _hali = _data[7];
|
|
|
|
var _vali = _data[8];
|
|
|
|
|
|
|
|
var tx = 0, ty = 0;
|
|
|
|
draw_set_text(font, fa_left, fa_top, _col);
|
|
|
|
switch(_hali) {
|
|
|
|
case 0 : draw_set_halign(fa_left); tx = 0; break;
|
|
|
|
case 1 : draw_set_halign(fa_center); tx = ww / 2; break;
|
|
|
|
case 2 : draw_set_halign(fa_right); tx = ww; break;
|
|
|
|
}
|
|
|
|
switch(_vali) {
|
|
|
|
case 0 : draw_set_valign(fa_top); ty = 0; break;
|
|
|
|
case 1 : draw_set_valign(fa_middle); ty = hh / 2; break;
|
|
|
|
case 2 : draw_set_valign(fa_bottom); ty = hh; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
draw_text(tx, ty, str);
|
|
|
|
} else {
|
|
|
|
draw_set_text(font, fa_left, fa_top, _col);
|
|
|
|
draw_text(0, 0, str);
|
|
|
|
}
|
|
|
|
|
|
|
|
BLEND_NORMAL
|
|
|
|
surface_reset_target();
|
|
|
|
}
|
|
|
|
}
|