mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-12 07:16:49 +01:00
ide test
This commit is contained in:
parent
e0c50eb23a
commit
34e70c96a0
11 changed files with 47 additions and 39 deletions
|
@ -120,10 +120,10 @@ event_inherited();
|
|||
draw_set_text(font, align, fa_center, clickable? COLORS._main_text : COLORS._main_text_sub);
|
||||
if(align == fa_center) {
|
||||
var _xc = _spr? hght + (_dw - hght) / 2 : _dw / 2;
|
||||
draw_text_cut(_xc, _ly + hght / 2, txt, _dw);
|
||||
draw_text_add(_xc, _ly + hght / 2, txt);
|
||||
|
||||
} else if(align == fa_left)
|
||||
draw_text_cut(text_pad + _spr * hght, _ly + hght / 2, txt, _dw);
|
||||
draw_text_add(text_pad + _spr * hght, _ly + hght / 2, txt);
|
||||
|
||||
} else if(sprite_exists(txt)) {
|
||||
draw_sprite_ext(txt, i, _dw / 2, _ly + hght / 2);
|
||||
|
@ -159,4 +159,6 @@ event_inherited();
|
|||
|
||||
return _h;
|
||||
});
|
||||
|
||||
sc_content.scroll_resize = false;
|
||||
#endregion
|
||||
|
|
|
@ -231,4 +231,6 @@ event_inherited();
|
|||
|
||||
return _h;
|
||||
});
|
||||
|
||||
sc_content.scroll_resize = false;
|
||||
#endregion
|
||||
|
|
|
@ -47,11 +47,8 @@
|
|||
directory_verify(DIRECTORY);
|
||||
|
||||
APP_LOCATION = program_directory;
|
||||
if(OS == os_macosx)
|
||||
APP_LOCATION = string_replace(APP_LOCATION, "/Contents/MacOS/", "/Contents/Resources/");
|
||||
|
||||
if(string_pos("GameMakerStudio2/Cache/runtimes", APP_LOCATION))
|
||||
APP_LOCATION = working_directory;
|
||||
if(OS == os_macosx) APP_LOCATION = string_replace(APP_LOCATION, "/Contents/MacOS/", "/Contents/Resources/");
|
||||
if(RUN_IDE) APP_LOCATION = "D:/Project/MakhamDev/LTS-PixelComposer/PixelComposer/datafiles/";
|
||||
|
||||
print($"===================== WORKING DIRECTORIES =====================\n\t{working_directory}\n\t{DIRECTORY}");
|
||||
directory_verify($"{DIRECTORY}log");
|
||||
|
|
|
@ -152,9 +152,10 @@ function draw_text_bbox_cut(bbox, text, scale = 1) {
|
|||
draw_text_cut(bbox.xc, bbox.yc, text, bbox.w, ss * scale);
|
||||
}
|
||||
|
||||
function draw_text_cut(x, y, str, w, scale = 1) {
|
||||
function draw_text_cut(x, y, str, w, scale = 1, _add = false) {
|
||||
INLINE
|
||||
BLEND_ALPHA_MULP;
|
||||
if(_add) { BLEND_ADD }
|
||||
else { BLEND_ALPHA_MULP }
|
||||
draw_text_transformed(round(x), round(y), string_cut(str, w,, scale), scale, scale, 0);
|
||||
BLEND_NORMAL;
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
#endregion
|
||||
|
||||
#region ======================================================================= MAIN =======================================================================
|
||||
globalvar OS, DEBUG, THEME, COLOR_KEYS;
|
||||
globalvar OS, DEBUG, THEME, COLOR_KEYS, RUN_IDE;
|
||||
globalvar CMD, CMDIN;
|
||||
globalvar FPS_REAL;
|
||||
|
||||
|
@ -30,6 +30,7 @@
|
|||
CMD = [];
|
||||
CMDIN = [];
|
||||
FPS_REAL = 0;
|
||||
RUN_IDE = GM_build_type == "run";
|
||||
|
||||
DEBUG = false;
|
||||
THEME = new Theme();
|
||||
|
|
|
@ -117,6 +117,7 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
];
|
||||
|
||||
export_template = new Inspector_Custom_Renderer(function(_x, _y, _w, _m, _hover, _focus) {
|
||||
|
||||
var _tx = _x + ui(10);
|
||||
var _ty = _y;
|
||||
var _tw = _w - ui(8);
|
||||
|
@ -172,8 +173,9 @@ function Node_Export(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
|
|||
}
|
||||
draw_set_alpha(1);
|
||||
|
||||
var hh = _th + ui(116);
|
||||
var hh = _th + ui(16 + 20 * array_length(template_guide));
|
||||
var _cy = _y + _th + ui(8);
|
||||
|
||||
for( var i = 0, n = array_length(template_guide); i < n; i++ ) {
|
||||
var _yy = _cy + ui(20) * i;
|
||||
|
||||
|
|
|
@ -57,8 +57,10 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
newOutput(1, nodeValue_Output("Path", self, VALUE_TYPE.path, ""))
|
||||
.setVisible(true, true);
|
||||
|
||||
detail = new Inspector_Label("Gif file");
|
||||
|
||||
input_display_list = [
|
||||
["Image", false], 0,
|
||||
["Image", false], 0, detail,
|
||||
["Output", false], 2,
|
||||
["Animation", false], 1, 3, 4, 7,
|
||||
["Custom Frame Order", false, 5], 6,
|
||||
|
@ -77,7 +79,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
array_push(attributeEditors, [ "File Watcher", function() { return attributes.file_checker; },
|
||||
new checkBox(function() { attributes.file_checker = !attributes.file_checker; }) ]);
|
||||
|
||||
on_drop_file = function(path) { #region
|
||||
on_drop_file = function(path) {
|
||||
inputs[0].setValue(path);
|
||||
|
||||
if(updatePaths(path)) {
|
||||
|
@ -86,16 +88,16 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
}
|
||||
|
||||
return false;
|
||||
} #endregion
|
||||
}
|
||||
|
||||
insp1UpdateTooltip = __txt("Refresh");
|
||||
insp1UpdateIcon = [ THEME.refresh_icon, 1, COLORS._main_value_positive ];
|
||||
|
||||
static onInspector1Update = function() { #region
|
||||
static onInspector1Update = function() {
|
||||
updatePaths(path_get(getInputData(0)));
|
||||
} #endregion
|
||||
}
|
||||
|
||||
function updatePaths(path = path_current) { #region
|
||||
function updatePaths(path = path_current) {
|
||||
if(path == -1) return false;
|
||||
|
||||
var ext = string_lower(filename_ext(path));
|
||||
|
@ -120,9 +122,9 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
edit_time = max(edit_time, file_get_modify_s(path_current));
|
||||
|
||||
return true;
|
||||
} #endregion
|
||||
}
|
||||
|
||||
static step = function() { #region
|
||||
static step = function() {
|
||||
var _arr = getInputData(2);
|
||||
var _lop = getInputData(3);
|
||||
var _cus = getInputData(5);
|
||||
|
@ -136,6 +138,7 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
surfaces = [];
|
||||
spr = spr_builder._spr;
|
||||
//print($"{spr}: {sprite_get_width(spr)}, {sprite_get_height(spr)}");
|
||||
detail.text = $"{filename_name(path_current)}\n{sprite_get_number(spr)} frames";
|
||||
|
||||
triggerRender();
|
||||
loading = 0;
|
||||
|
@ -153,9 +156,9 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
}
|
||||
|
||||
}
|
||||
} #endregion
|
||||
}
|
||||
|
||||
static update = function(frame = CURRENT_FRAME) { #region
|
||||
static update = function(frame = CURRENT_FRAME) {
|
||||
var path = path_get(getInputData(0));
|
||||
if(path_current != path) updatePaths(path);
|
||||
|
||||
|
@ -222,15 +225,15 @@ function Node_Image_gif(_x, _y, _group = noone) : Node(_x, _y, _group) construct
|
|||
surface_set_shader(_outsurf);
|
||||
if(_drw) draw_sprite(spr, _frm, 0, 0);
|
||||
surface_reset_shader();
|
||||
} #endregion
|
||||
}
|
||||
|
||||
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) { #region
|
||||
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
|
||||
if(loading) draw_sprite_ui(THEME.loading, 0, xx + w * _s / 2, yy + h * _s / 2, _s, _s, current_time / 2, COLORS._main_icon, 1);
|
||||
} #endregion
|
||||
}
|
||||
|
||||
static onDestroy = function() { #region
|
||||
static onDestroy = function() {
|
||||
if(sprite_exists(spr)) sprite_flush(spr);
|
||||
} #endregion
|
||||
}
|
||||
|
||||
static dropPath = function(path) {
|
||||
if(is_array(path)) path = array_safe_get(path, 0);
|
||||
|
|
|
@ -631,7 +631,7 @@ function Panel_Inspector() : PanelContent() constructor {
|
|||
var lby = yy + ui(12);
|
||||
draw_set_alpha(0.5);
|
||||
draw_set_text(f_p1, fa_center, fa_center, COLORS._main_text_sub);
|
||||
draw_text_add(xc, lby, edt);
|
||||
draw_text(xc, lby, edt);
|
||||
|
||||
var lbw = string_width(edt) / 2;
|
||||
draw_set_color(COLORS._main_text_sub);
|
||||
|
@ -658,7 +658,7 @@ function Panel_Inspector() : PanelContent() constructor {
|
|||
}
|
||||
|
||||
draw_set_text(f_p1, fa_left, fa_center, COLORS._main_text);
|
||||
draw_text_alpha(ui(8), yy + hg / 2, edt[0]);
|
||||
draw_text(ui(8), yy + hg / 2, edt[0]);
|
||||
|
||||
var _param = new widgetParam(wx0, yy, ww, hg, val, {}, _m, x + contentPane.x, y + contentPane.y);
|
||||
_param.s = hg;
|
||||
|
@ -1015,7 +1015,7 @@ function Panel_Inspector() : PanelContent() constructor {
|
|||
contentPane = new scrollPane(content_w, content_h, function(_y, _m) {
|
||||
var con_w = contentPane.surface_w - ui(4);
|
||||
|
||||
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
||||
draw_clear_alpha(COLORS.panel_bg_clear_inner, 1);
|
||||
|
||||
if(point_in_rectangle(_m[0], _m[1], 0, 0, con_w, content_h) && mouse_press(mb_left, pFOCUS))
|
||||
prop_selecting = noone;
|
||||
|
|
|
@ -667,10 +667,8 @@ function Panel_Menu() : PanelContent() constructor {
|
|||
if(PROJECT.safeMode) txt += $"[{__txt("SAFE MODE")}] ";
|
||||
if(PROJECT.readonly) txt += $"[{__txt("READ ONLY")}] ";
|
||||
|
||||
txt += PROJECT.path == ""? __txt("Untitled") : filename_name(PROJECT.path);
|
||||
txt += PROJECT.path == ""? __txt("Untitled.pxc") : filename_name(PROJECT.path);
|
||||
if(PROJECT.modified) txt += "*";
|
||||
txt += " - Pixel Composer";
|
||||
if(DEMO) txt += " DEMO";
|
||||
|
||||
var tx0, tx1, tcx;
|
||||
var ty0, ty1;
|
||||
|
@ -705,6 +703,7 @@ function Panel_Menu() : PanelContent() constructor {
|
|||
if(hori) {
|
||||
tbx0 = tcx - tw / 2;
|
||||
tby0 = ty1 / 2 - ui(14);
|
||||
|
||||
} else {
|
||||
tbx0 = tx0;
|
||||
tby0 = ty0;
|
||||
|
@ -732,10 +731,10 @@ function Panel_Menu() : PanelContent() constructor {
|
|||
}
|
||||
|
||||
if(hori) {
|
||||
draw_set_text(f_p0b, fa_center, fa_center, COLORS._main_text_sub);
|
||||
draw_set_text(f_p0b, fa_center, fa_center, COLORS._main_text);
|
||||
draw_text_int(tcx, (ty0 + ty1) / 2, tc);
|
||||
} else {
|
||||
draw_set_text(f_p0b, fa_left, fa_center, COLORS._main_text_sub);
|
||||
draw_set_text(f_p0b, fa_left, fa_center, COLORS._main_text);
|
||||
draw_text_int(tx0 + ui(8), tby0 + th / 2, tc);
|
||||
}
|
||||
|
||||
|
|
|
@ -156,7 +156,7 @@
|
|||
#region //////////////////////////////////////////////////////////////////////// PATHS /////////////////////////////////////////////////////////////////////////
|
||||
|
||||
PREFERENCES.temp_path = "%DIR%/temp/";
|
||||
PREFERENCES.ImageMagick_path = "%APP%/imagemagick/";
|
||||
PREFERENCES.ImageMagick_path = "%APP%/ImageMagick/";
|
||||
PREFERENCES.webp_path = "%APP%/webp/";
|
||||
PREFERENCES.gifski_path = "%APP%/gifski/";
|
||||
PREFERENCES.ffmpeg_path = "%APP%/ffmpeg/";
|
||||
|
|
|
@ -17,6 +17,7 @@ function scrollPane(_w, _h, ondraw) : widget() constructor {
|
|||
is_scroll = true;
|
||||
always_scroll = true;
|
||||
show_scroll = true;
|
||||
scroll_resize = true;
|
||||
|
||||
scroll_step = 64;
|
||||
scroll_lock = false;
|
||||
|
@ -36,7 +37,7 @@ function scrollPane(_w, _h, ondraw) : widget() constructor {
|
|||
static resize = function(_w, _h) {
|
||||
w = _w;
|
||||
h = _h;
|
||||
surface_w = _w - ui(12);
|
||||
surface_w = _w - ui(12) * (is_scroll || scroll_resize);
|
||||
surface_h = _h;
|
||||
}
|
||||
|
||||
|
@ -106,7 +107,7 @@ function scrollPane(_w, _h, ondraw) : widget() constructor {
|
|||
scroll_y_to += pen_scroll_py;
|
||||
}
|
||||
|
||||
if(show_scroll && (abs(content_h) > 0 || always_scroll)) {
|
||||
if(show_scroll && (abs(content_h) > 0 || (always_scroll && scroll_resize))) {
|
||||
var _p = PEN_USE && (is_scrolling || point_in_rectangle(x + mx, y + my, x + w - scroll_w - 2, y, x + w, y + surface_h));
|
||||
scroll_w = lerp_float(scroll_w, _p? 12 : scroll_s, 5);
|
||||
|
||||
|
|
Loading…
Reference in a new issue