mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-26 12:58:49 +01:00
- [Node Action] Add expression support.
+ Follow path action now comes with expression for automating path progress.
This commit is contained in:
parent
d07cb1ce70
commit
468ebbd5f3
8 changed files with 23 additions and 5522 deletions
|
@ -256,7 +256,6 @@
|
||||||
"IncludedFiles": [
|
"IncludedFiles": [
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"ApolloHelp.html","ConfigValues":{"Itch":{"CopyToMask":"0",},},"CopyToMask":-1,"filePath":"datafiles",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"ApolloHelp.html","ConfigValues":{"Itch":{"CopyToMask":"0",},},"CopyToMask":-1,"filePath":"datafiles",},
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Actions.zip","CopyToMask":-1,"filePath":"datafiles/data",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Actions.zip","CopyToMask":-1,"filePath":"datafiles/data",},
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"icons.ai","CopyToMask":-1,"filePath":"datafiles/data/Actions",},
|
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Armature Build.json","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Armature Build.json","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Armature Build.png","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Armature Build.png","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
||||||
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Follow Path.json","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
{"resourceType":"GMIncludedFile","resourceVersion":"1.0","name":"Follow Path.json","CopyToMask":-1,"filePath":"datafiles/data/Actions/Nodes",},
|
||||||
|
|
Binary file not shown.
|
@ -5,7 +5,7 @@
|
||||||
"location": ["Transform", "Transformations"],
|
"location": ["Transform", "Transformations"],
|
||||||
"sprPath": "./Follow Path.png",
|
"sprPath": "./Follow Path.png",
|
||||||
"nodes": [
|
"nodes": [
|
||||||
{ "node": "Node_Path", "y": 64 },
|
{ "node": "Node_Path", "y": 64, "setValues": [ { "index": 0, "expression": "Project.progress" } ] },
|
||||||
{ "node": "Node_Transform", "setValues": [ { "index": 2, "unit": "constant" } ] }
|
{ "node": "Node_Transform", "setValues": [ { "index": 2, "unit": "constant" } ] }
|
||||||
],
|
],
|
||||||
"connections": [
|
"connections": [
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -8,6 +8,9 @@
|
||||||
if(!directory_exists(root))
|
if(!directory_exists(root))
|
||||||
directory_create(root);
|
directory_create(root);
|
||||||
|
|
||||||
|
zip_unzip("data/Actions.zip", DIRECTORY);
|
||||||
|
|
||||||
|
return;
|
||||||
var _l = root + "/version";
|
var _l = root + "/version";
|
||||||
if(file_exists(_l)) {
|
if(file_exists(_l)) {
|
||||||
var res = json_load_struct(_l);
|
var res = json_load_struct(_l);
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
static getName = function() { return name; }
|
static getName = function() { return name; }
|
||||||
static getTooltip = function() { return tooltip; }
|
static getTooltip = function() { return tooltip; }
|
||||||
|
|
||||||
static build = function(_x = 0, _y = 0, _group = PANEL_GRAPH.getCurrentContext(), _param = {}) {
|
static build = function(_x = 0, _y = 0, _group = PANEL_GRAPH.getCurrentContext(), _param = {}) { #region
|
||||||
var _n = [];
|
var _n = [];
|
||||||
for( var i = 0, n = array_length(nodes); i < n; i++ ) {
|
for( var i = 0, n = array_length(nodes); i < n; i++ ) {
|
||||||
var __n = nodes[i];
|
var __n = nodes[i];
|
||||||
|
@ -39,6 +39,8 @@
|
||||||
_index.setValue(_setVal.value);
|
_index.setValue(_setVal.value);
|
||||||
if(struct_has(_setVal, "unit"))
|
if(struct_has(_setVal, "unit"))
|
||||||
_index.unit.setMode(_setVal.unit);
|
_index.unit.setMode(_setVal.unit);
|
||||||
|
if(struct_has(_setVal, "expression"))
|
||||||
|
_index.setExpression(_setVal.expression);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,14 +52,14 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
return _n;
|
return _n;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static serialize = function() {
|
static serialize = function() { #region
|
||||||
var map = { name, tooltip, nodes, connections, tags };
|
var map = { name, tooltip, nodes, connections, tags };
|
||||||
return map;
|
return map;
|
||||||
}
|
} #endregion
|
||||||
|
|
||||||
static deserialize = function(path) {
|
static deserialize = function(path) { #region
|
||||||
var map = json_load_struct(path);
|
var map = json_load_struct(path);
|
||||||
|
|
||||||
name = struct_try_get(map, "name", "");
|
name = struct_try_get(map, "name", "");
|
||||||
|
@ -81,11 +83,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
} #endregion
|
||||||
}
|
}
|
||||||
|
|
||||||
function __initNodeActions(list) {
|
function __initNodeActions(list) {
|
||||||
var root = DIRECTORY + "Actions";
|
var root = $"{DIRECTORY}Actions";
|
||||||
if(!directory_exists(root)) directory_create(root);
|
if(!directory_exists(root)) directory_create(root);
|
||||||
|
|
||||||
root += "/Nodes";
|
root += "/Nodes";
|
||||||
|
|
|
@ -34,7 +34,7 @@ function Node_Path_Wave(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
|
|
||||||
static getLength = function(ind = 0) {
|
static getLength = function(ind = 0) {
|
||||||
var _path = getInputData(0);
|
var _path = getInputData(0);
|
||||||
var _fre = getInputData(1);
|
var _fre = getInputData(1); _fre = max(1, abs(_fre));
|
||||||
var _amo = getInputData(2);
|
var _amo = getInputData(2);
|
||||||
|
|
||||||
var _len = struct_has(_path, "getLength")? _path.getLength(ind) : 0;
|
var _len = struct_has(_path, "getLength")? _path.getLength(ind) : 0;
|
||||||
|
@ -45,7 +45,7 @@ function Node_Path_Wave(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
|
|
||||||
static getAccuLength = function(ind = 0) {
|
static getAccuLength = function(ind = 0) {
|
||||||
var _path = getInputData(0);
|
var _path = getInputData(0);
|
||||||
var _fre = getInputData(1);
|
var _fre = getInputData(1); _fre = max(1, abs(_fre));
|
||||||
var _amo = getInputData(2);
|
var _amo = getInputData(2);
|
||||||
|
|
||||||
var _len = struct_has(_path, "getAccuLength")? _path.getAccuLength(ind) : [];
|
var _len = struct_has(_path, "getAccuLength")? _path.getAccuLength(ind) : [];
|
||||||
|
@ -59,7 +59,7 @@ function Node_Path_Wave(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
||||||
|
|
||||||
static getPointRatio = function(_rat, ind = 0) {
|
static getPointRatio = function(_rat, ind = 0) {
|
||||||
var _path = getInputData(0);
|
var _path = getInputData(0);
|
||||||
var _fre = getInputData(1);
|
var _fre = getInputData(1); _fre = max(0.01, abs(_fre));
|
||||||
var _amo = getInputData(2);
|
var _amo = getInputData(2);
|
||||||
var _shf = getInputData(3);
|
var _shf = getInputData(3);
|
||||||
var _smt = getInputData(4);
|
var _smt = getInputData(4);
|
||||||
|
|
|
@ -1206,6 +1206,12 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
|
||||||
return true;
|
return true;
|
||||||
} #endregion
|
} #endregion
|
||||||
|
|
||||||
|
static setExpression = function(_expression) { #region
|
||||||
|
expUse = true;
|
||||||
|
expression = _expression;
|
||||||
|
expressionUpdate();
|
||||||
|
} #endregion
|
||||||
|
|
||||||
static expressionUpdate = function() { #region
|
static expressionUpdate = function() { #region
|
||||||
expTree = evaluateFunctionList(expression);
|
expTree = evaluateFunctionList(expression);
|
||||||
resetCache();
|
resetCache();
|
||||||
|
|
Loading…
Reference in a new issue