From 27eddb8ac4a702ab411eb4af2755c6899b9d1ebb Mon Sep 17 00:00:00 2001 From: Sebastien Benard Date: Wed, 20 Sep 2023 18:12:34 +0200 Subject: [PATCH] Fixed crash in createTileRectPicker (#928, #927) --- src/electron.renderer/misc/JsTools.hx | 76 ++++++++++++++------------- 1 file changed, 40 insertions(+), 36 deletions(-) diff --git a/src/electron.renderer/misc/JsTools.hx b/src/electron.renderer/misc/JsTools.hx index 36c69fcc2..5823e1c8d 100644 --- a/src/electron.renderer/misc/JsTools.hx +++ b/src/electron.renderer/misc/JsTools.hx @@ -1133,47 +1133,51 @@ class JsTools { var jTileCanvas = new J(''); if( tilesetId!=null ) { - if( active ) - jTileCanvas.addClass("active"); - var td = Editor.ME.project.defs.getTilesetDef(tilesetId); - - if( cur==null ) { - // No tile selected + if( td==null ) jTileCanvas.addClass("empty"); - } else { - // Tile rect - jTileCanvas.attr("width", cur.w); - jTileCanvas.attr("height", cur.h); - var scale = 35 / M.fmax(cur.w, cur.h); - jTileCanvas.css("width", cur.w * scale ); - jTileCanvas.css("height", cur.h * scale ); - td.drawTileRectToCanvas(jTileCanvas, cur); - } - ui.Tip.attach(jTileCanvas, "Use LEFT click to pick a tile or RIGHT click to remove it."); + if( active ) + jTileCanvas.addClass("active"); - // Open picker - if( active ) - jTileCanvas.mousedown( (ev:js.jquery.Event)->{ - switch ev.button { - case 0: - var m = new ui.Modal(); - m.addClass("singleTilePicker"); - - var tp = new ui.Tileset(m.jContent, td, RectOnly); - tp.useSavedSelections = false; - tp.setSelectedRect(cur); - tp.onSelectAnything = ()->{ - onPick( tp.getSelectedRect() ); - m.close(); - } - tp.focusOnSelection(true); + if( cur==null ) { + // No tile selected + jTileCanvas.addClass("empty"); + } + else { + // Tile rect + jTileCanvas.attr("width", cur.w); + jTileCanvas.attr("height", cur.h); + var scale = 35 / M.fmax(cur.w, cur.h); + jTileCanvas.css("width", cur.w * scale ); + jTileCanvas.css("height", cur.h * scale ); + td.drawTileRectToCanvas(jTileCanvas, cur); + } + ui.Tip.attach(jTileCanvas, "Use LEFT click to pick a tile or RIGHT click to remove it."); + + // Open picker + if( active ) + jTileCanvas.mousedown( (ev:js.jquery.Event)->{ + switch ev.button { + case 0: + var m = new ui.Modal(); + m.addClass("singleTilePicker"); + + var tp = new ui.Tileset(m.jContent, td, RectOnly); + tp.useSavedSelections = false; + tp.setSelectedRect(cur); + tp.onSelectAnything = ()->{ + onPick( tp.getSelectedRect() ); + m.close(); + } + tp.focusOnSelection(true); + + case _: + onPick(null); + } + }); + } - case _: - onPick(null); - } - }); } else { // Invalid tileset