mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-11-14 14:33:53 +01:00
124 lines
3.2 KiB
Plaintext
124 lines
3.2 KiB
Plaintext
function Node_create_SVG_path(_x, _y, path) {
|
|
if(!file_exists_empty(path)) return noone;
|
|
|
|
var node = new Node_SVG(_x, _y, PANEL_GRAPH.getCurrentContext()).skipDefault();
|
|
node.inputs[0].setValue(path);
|
|
node.doUpdate();
|
|
return node;
|
|
}
|
|
|
|
function Node_SVG(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|
name = "SVG";
|
|
color = COLORS.node_blend_input;
|
|
|
|
newInput(0, nodeValue_Path("Path", self, ""))
|
|
.setDisplay(VALUE_DISPLAY.path_load, { filter: "Scalable Vector Graphics|*.svg" });
|
|
|
|
newInput(1, nodeValue_Float("Scale", self, 1));
|
|
|
|
newOutput(0, nodeValue_Output("Surface out", self, VALUE_TYPE.surface, noone));
|
|
|
|
newOutput(1, nodeValue_Output("SVG Struct", self, VALUE_TYPE.struct, {}));
|
|
|
|
attribute_surface_depth();
|
|
|
|
rawContent = noone;
|
|
content = {};
|
|
edit_time = 0;
|
|
curr_path = "";
|
|
|
|
attributes.check_splice = true;
|
|
attributes.file_checker = true;
|
|
array_push(attributeEditors, [ "File Watcher", function() { return attributes.file_checker; },
|
|
new checkBox(function() { attributes.file_checker = !attributes.file_checker; }) ]);
|
|
|
|
on_drop_file = function(path) {
|
|
inputs[0].setValue(path);
|
|
|
|
if(readFile(path)) {
|
|
doUpdate();
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
function readFile(path) {
|
|
curr_path = path;
|
|
if(!file_exists_empty(path))
|
|
return noone;
|
|
|
|
edit_time = file_get_modify_s(path);
|
|
var ext = string_lower(filename_ext(path));
|
|
var _name = filename_name_only(path);
|
|
|
|
if(ext != ".svg") return;
|
|
|
|
var _rawContent = file_read_all(path);
|
|
var _st = string_pos("<svg", _rawContent);
|
|
var _end = string_length(_rawContent);
|
|
_rawContent = string_copy(_rawContent, _st, _end - _st + 1);
|
|
|
|
rawContent = SnapFromXML(_rawContent);
|
|
content = svg_parse(rawContent);
|
|
|
|
return;
|
|
}
|
|
|
|
insp1UpdateTooltip = __txt("Refresh");
|
|
insp1UpdateIcon = [ THEME.refresh_icon, 1, COLORS._main_value_positive ];
|
|
|
|
static onInspector1Update = function() {
|
|
readFile(path_get(getInputData(0)));
|
|
triggerRender();
|
|
}
|
|
|
|
static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
|
var _scale = getInputData(1);
|
|
|
|
if(is_instanceof(content, SVG))
|
|
content.drawOverlay(hover, active, _x, _y, _s * _scale, _mx, _my, _snx, _sny);
|
|
}
|
|
|
|
static step = function() {
|
|
var path = path_get(getInputData(0));
|
|
if(!file_exists_empty(path)) return;
|
|
|
|
var _modi = file_get_modify_s(path);
|
|
if(attributes.file_checker && _modi > edit_time) {
|
|
readFile(path);
|
|
triggerRender();
|
|
}
|
|
}
|
|
|
|
static update = function(frame = CURRENT_FRAME) {
|
|
var path = path_get(getInputData(0));
|
|
if(path != curr_path)
|
|
readFile(path);
|
|
|
|
if(!is_instanceof(content, SVG)) return;
|
|
outputs[1].setValue(path);
|
|
|
|
var _scale = getInputData(1);
|
|
var _outsurf = outputs[0].getValue();
|
|
|
|
var ww = content.width * _scale;
|
|
var hh = content.height * _scale;
|
|
|
|
_outsurf = surface_verify(_outsurf, ww, hh, attrDepth());
|
|
|
|
surface_set_shader(_outsurf, noone);
|
|
content.draw(_scale);
|
|
surface_reset_shader();
|
|
|
|
outputs[0].setValue(_outsurf);
|
|
outputs[1].setValue(rawContent);
|
|
}
|
|
|
|
static dropPath = function(path) {
|
|
if(is_array(path)) path = array_safe_get(path, 0);
|
|
if(!file_exists_empty(path)) return;
|
|
|
|
inputs[0].setValue(path);
|
|
}
|
|
} |