function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e7) { throw _e7; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e8) { didErr = true; err = _e8; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } /*: * @plugindesc Live Map Editor - 1.12.02 * * <pluginName:CycloneMapEditor> * @author Hudell * @url https://makerdevs.com/plugin/cyclone-map-editor * * @help * =========================================================================== * 88 * 88 * 88 * ,adPPYba, 8b d8 ,adPPYba, 88 ,adPPYba, 8b,dPPYba, ,adPPYba, * a8" "" `8b d8' a8" "" 88 a8" "8a 88P' `"8a a8P_____88 * 8b `8b d8' 8b 88 8b d8 88 88 8PP""""""" * "8a, ,aa `8b,d8' "8a, ,aa 88 "8a, ,a8" 88 88 "8b, ,aa * `"Ybbd8"' Y88' `"Ybbd8"' 88 `"YbbdP"' 88 88 `"Ybbd8"' * d8' * d8' MV * Live Map Editor by Hudell * =========================================================================== * Terms of Use * =========================================================================== * 1. For support, feature requests or bug reports, you may contact me through * any of the following channels: * * 1.a. Opening an issue on the plugin's GitHub repository: * https://github.com/Hudell/cyclone-engine * 1.b. Opening threads on the plugin's itch.io page * 1.c. Tagging my user on Rpg Maker related sub-reddits, such as r/rpgmaker * * 2. This plugin is released under the Apache License 2.0 (Apache-2.0). * * 3. You can send me your own changes to this plugin if you wish to see them * included in an update, by registering a Pull Request on the plugin's GitHub * repository. * * 4. This plugin is provided as is. While I'll often read feedback and offer * updates to my plugins, I am in no obligation to do so. * * 5. I'm not responsible for anything created with this plugin. * =========================================================================== * Change Log * =========================================================================== * 2022-07-29 - Version 1.12.02 * * Added support for custom event hitboxes * 2021-01-27 - Version 1.12.00 * * Added option to generate 48x48 tilesets when using other sizes. * 2020-11-05 - Version 1.11.00 * * General bug fixes * 2020-10-10 - Version 1.10.00 * * Added tileset tabs * * Moved layer list to left side of the screen * * General bug fixes * * 2020-10-09 - Version 1.09.00 * * General bug fixes * * Added support to Cyclone Magic v1.1 * * 2020-10-07 - Version 1.08.00 * * Added support to Cyclone Extra Tilesets v1.1 * * 2020-09-22 - Version 1.07.00 * * Several quality-of-life updates * * Added support to Cyclone Magic * * Added support to Cyclone Extra Tilesets * * 2020-09-18 - Version 1.06.01 * * Fixed "Default Collision Blocks" param options. * * 2020-09-15 - Version 1.06.00 * * New option to view tile properties such as tags, passability, bush, * ladder and so on. * * 2020-09-14 - Version 1.05.01 * * Fixed small delay on integration between movement and map editor. * * 2020-09-14 - Version 1.05.00 * * Added new collision options; * * Changed data compression algorithm; * * 2020-09-10 - Version 1.04.00 * * Added option to customize the collision in blocks of 1/4 of a tile. * * Added options to export the collision map to an image * * Changed the editor to force a larger screen when the game uses a small * resolution. * * Added option to toggle event visibility. * * 2020-08-30 - Version 1.03.00 * * Added options to export the map as images * * 2020-08-29 - Version 1.02.00 * * First MV Compatible version * =========================================================================== * * @param regionIcons * @text Region Icons * @type struct<RegionIcon>[] * @desc Configure certain regions to display an icon instead of the number * * @param Status Bar * * @param showMapId * @text Show Map Id * @parent Status Bar * @type boolean * @default true * @desc Should the Map Id be visible in the status bar? * * @param showTilesetId * @text Show Tileset Id * @parent Status Bar * @type boolean * @default true * @desc Should the Tileset Id be visible in the status bar? * * @param showPosition * @text Show Position * @parent Status Bar * @type boolean * @default true * @desc Should the X and Y position in the status bar? * * @param showCellTiles * @text Show Cell Tiles * @parent Status Bar * @type boolean * @default true * @desc Should the id of the current position tiles be displayed in the status bar? * * @param showRegionId * @text Show Region Id * @parent Status Bar * @type boolean * @default true * @desc Should the region id of the current position be displayed in the status bar? * * @param showTag * @text Show Terrain Tag * @parent Status Bar * @type boolean * @default true * @desc Should the terrain tag of the current position be displayed in the status bar? * * @param showCollision * @text Show Collision * @parent Status Bar * @type boolean * @default true * @desc Should the collision of the current position be displayed in the status bar? * * @param showLadder * @text Show Ladder * @parent Status Bar * @type boolean * @default true * @desc Should status bar indicate if the current position is a ladder? * * @param showBush * @text Show Bush * @parent Status Bar * @type boolean * @default true * @desc Should the status bar indicate if the current position is a bush? * * @param showCounter * @text Show Counter * @parent Status Bar * @type boolean * @default true * @desc Should the status bar indicate if the current position is a counter? * * @param showDamageFloor * @text Show Damage Floor * @parent Status Bar * @type boolean * @default true * @desc Should the status bar indicate if the current position is a damage floor tile? * * @param collisionStepCount * @text Default Collision Blocks * @type select * @default 1 * @desc How many collision blocks per tile should the editor show? * @option 4 * @option 2 * @option 1 * **/ /*~struct~RegionIcon: * @param regionId * @text Region Id * @type number * @desc The regionId to display an icon on * * @param icon * @text Icon * @type string * @desc Right click to select icon index */ (function () { if (Utils.RPGMAKER_NAME === 'MV') { window.globalThis = window; ImageManager.iconWidth = Window_Base._iconWidth; ImageManager.iconHeight = Window_Base._iconHeight; ImageManager.faceWidth = Window_Base._faceWidth; ImageManager.faceHeight = Window_Base._faceHeight; } // ColorManager polyfill for MV if (Utils.RPGMAKER_NAME === 'MV') { window.ColorManager = /*#__PURE__*/function () { function ColorManager() { _classCallCheck(this, ColorManager); } _createClass(ColorManager, null, [{ key: "loadWindowskin", value: function loadWindowskin() { this._windowskin = ImageManager.loadSystem('Window'); } }, { key: "textColor", value: function textColor(n) { var px = 96 + n % 8 * 12 + 6; var py = 144 + Math.floor(n / 8) * 12 + 6; return this._windowskin.getPixel(px, py); } }, { key: "normalColor", value: function normalColor() { return this.textColor(0); } }, { key: "systemColor", value: function systemColor() { return this.textColor(16); } }, { key: "crisisColor", value: function crisisColor() { return this.textColor(17); } }, { key: "deathColor", value: function deathColor() { return this.textColor(18); } }, { key: "gaugeBackColor", value: function gaugeBackColor() { return this.textColor(19); } }, { key: "hpGaugeColor1", value: function hpGaugeColor1() { return this.textColor(20); } }, { key: "hpGaugeColor2", value: function hpGaugeColor2() { return this.textColor(21); } }, { key: "mpGaugeColor1", value: function mpGaugeColor1() { return this.textColor(22); } }, { key: "mpGaugeColor2", value: function mpGaugeColor2() { return this.textColor(23); } }, { key: "mpCostColor", value: function mpCostColor() { return this.textColor(23); } }, { key: "powerUpColor", value: function powerUpColor() { return this.textColor(24); } }, { key: "powerDownColor", value: function powerDownColor() { return this.textColor(25); } }, { key: "ctGaugeColor1", value: function ctGaugeColor1() { return this.textColor(26); } }, { key: "ctGaugeColor2", value: function ctGaugeColor2() { return this.textColor(27); } }, { key: "tpGaugeColor1", value: function tpGaugeColor1() { return this.textColor(28); } }, { key: "tpGaugeColor2", value: function tpGaugeColor2() { return this.textColor(29); } }, { key: "tpCostColor", value: function tpCostColor() { return this.textColor(29); } }, { key: "pendingColor", value: function pendingColor() { return this._windowskin.getPixel(120, 120); } }, { key: "hpColor", value: function hpColor(actor) { if (!actor) { return this.normalColor(); } else if (actor.isDead()) { return this.deathColor(); } else if (actor.isDying()) { return this.crisisColor(); } else { return this.normalColor(); } } }, { key: "mpColor", value: function mpColor() { return this.normalColor(); } }, { key: "tpColor", value: function tpColor() { return this.normalColor(); } }, { key: "paramchangeTextColor", value: function paramchangeTextColor(change) { if (change > 0) { return this.powerUpColor(); } else if (change < 0) { return this.powerDownColor(); } else { return this.normalColor(); } } }, { key: "damageColor", value: function damageColor(colorType) { switch (colorType) { case 0: // HP damage return '#ffffff'; case 1: // HP recover return '#b9ffb5'; case 2: // MP damage return '#ffff90'; case 3: // MP recover return '#80b0ff'; default: return '#808080'; } } }, { key: "outlineColor", value: function outlineColor() { return 'rgba(0, 0, 0, 0.6)'; } }, { key: "dimColor1", value: function dimColor1() { return 'rgba(0, 0, 0, 0.6)'; } }, { key: "dimColor2", value: function dimColor2() { return 'rgba(0, 0, 0, 0)'; } }, { key: "itemBackColor1", value: function itemBackColor1() { return 'rgba(32, 32, 32, 0.5)'; } }, { key: "itemBackColor2", value: function itemBackColor2() { return 'rgba(0, 0, 0, 0.5)'; } }]); return ColorManager; }(); var oldLoadSystemImages = Scene_Boot.loadSystemImages; Scene_Boot.loadSystemImages = function () { oldLoadSystemImages.call(this); ColorManager.loadWindowskin(); }; } if (Utils.RPGMAKER_NAME === 'MV') { Window_Selectable.prototype.hitIndex = function () { var touchPos = new Point(TouchInput.x, TouchInput.y); var localPos = this.worldTransform.applyInverse(touchPos); return this.hitTest(localPos.x, localPos.y); }; } if (Utils.RPGMAKER_NAME === 'MV') { Scene_Map.prototype.isAnyButtonPressed = function () { return false; }; } if (Utils.RPGMAKER_NAME === 'MV') { var oldTouchInputMouseMove = TouchInput._onMouseMove; TouchInput._onMouseMove = function (event) { oldTouchInputMouseMove.call(this, event); var x = Graphics.pageToCanvasX(event.pageX); var y = Graphics.pageToCanvasY(event.pageY); this._x = x; this._y = y; }; } Bitmap.prototype.strokeRect = function (x, y, width, height, color) { var context = this.context; context.save(); context.strokeStyle = color; context.strokeRect(x, y, width, height); context.restore(); this._baseTexture.update(); }; globalThis.CyclonePatcher = /*#__PURE__*/function () { function _class() { _classCallCheck(this, _class); } _createClass(_class, null, [{ key: "initialize", value: function initialize(t) { this.pluginName = t, this.superClasses = new Map(); } }, { key: "_descriptorIsProperty", value: function _descriptorIsProperty(t) { return t.get || t.set || !t.value || "function" != typeof t.value; } }, { key: "_getAllClassDescriptors", value: function _getAllClassDescriptors(t) { var e = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1; if (t === Object) return {}; var r = Object.getOwnPropertyDescriptors(e ? t.prototype : t); var s = {}; if (t.prototype) { var _r = Object.getPrototypeOf(t.prototype).constructor; _r !== Object && (s = this._getAllClassDescriptors(_r, e)); } return Object.assign({}, s, r); } }, { key: "_assignDescriptor", value: function _assignDescriptor(t, e, r, s) { var a = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !1; if (this._descriptorIsProperty(r)) r.get || r.set ? Object.defineProperty(t, s, { get: r.get, set: r.set, enumerable: r.enumerable, configurable: r.configurable }) : Object.defineProperty(t, s, { value: r.value, enumerable: r.enumerable, configurable: r.configurable });else { var _r2 = s; if (a) for (; (_r2 in t);) { _r2 = "_".concat(_r2); } t[_r2] = e[s]; } } }, { key: "_applyPatch", value: function _applyPatch(t, e, r, s) { var a = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : !1; var n = this._getAllClassDescriptors(t, a), i = a ? t.prototype : t, o = a ? e.prototype : e, l = Object.getOwnPropertyDescriptors(o); var u = !1; for (var _t in l) { if (s.includes(_t)) continue; if (_t in n) { u = !0; var _e2 = n[_t]; this._assignDescriptor(r, i, _e2, _t, !0); } var _e = l[_t]; this._assignDescriptor(i, o, _e, _t); } return u; } }, { key: "patchClass", value: function patchClass(t, e) { var r = this.superClasses && this.superClasses[t.name] || {}, s = {}, a = {}, n = e(a, s); if ("function" != typeof n) throw new Error("Invalid class patch for ".concat(t.name)); var i = Object.getOwnPropertyNames( /*#__PURE__*/function () { function _class2() { _classCallCheck(this, _class2); } return _class2; }()), o = Object.getOwnPropertyNames( /*#__PURE__*/function () { function _class3() { _classCallCheck(this, _class3); } return _class3; }().prototype), l = this._applyPatch(t, n, r, i), u = this._applyPatch(t, n, s, o, !0); if (l) { var _t2 = Object.getOwnPropertyDescriptors(r); for (var _e3 in _t2) { this._assignDescriptor(a, r, _t2[_e3], _e3); } u && (a.$prototype = s); } else Object.assign(a, s); this.superClasses && (this.superClasses[t.name] = a); } }]); return _class; }(); var t = Object.freeze(["TRUE", "ON", "1", "YES", "T", "V"]); var e = /*#__PURE__*/function (_CyclonePatcher) { _inherits(e, _CyclonePatcher); var _super = _createSuper(e); function e() { _classCallCheck(this, e); return _super.apply(this, arguments); } _createClass(e, null, [{ key: "initialize", value: function initialize(t) { _get(_getPrototypeOf(e), "initialize", this).call(this, t), this.fileName = void 0, this.params = {}, this.structs = new Map(), this.eventListeners = new Map(), this.structs.set("Dictionary", { name: { type: "string", defaultValue: "" }, value: { type: "string", defaultValue: "" } }); } }, { key: "register", value: function register() { var t = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var e = this.loadAllParams(); this.params = this.loadParamMap(t, e); } }, { key: "loadAllParams", value: function loadAllParams() { var _iterator = _createForOfIteratorHelper(globalThis.$plugins), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var _t3 = _step.value; if (!_t3 || !_t3.status) continue; if (!_t3.description || !_t3.description.includes("<pluginName:".concat(this.pluginName))) continue; this.fileName = _t3.name; var _e4 = new Map(); for (var r in _t3.parameters) { r && !r.startsWith("-") && _e4.set(r, _t3.parameters[r]); } return _e4; } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } } }, { key: "loadParamMap", value: function loadParamMap(t, e) { var r = {}; for (var s in t) { if (t.hasOwnProperty(s)) try { r[s] = this.parseParam(s, t, e); } catch (t) { console.error("CycloneEngine crashed while trying to parse a parameter value (".concat(s, "). Please report the following error to Hudell:")), console.log(t); } } return r; } }, { key: "registerEvent", value: function registerEvent(t, e) { this.eventListeners.has(t) || this.eventListeners.set(t, new Set()); this.eventListeners.get(t).add(e); } }, { key: "removeEventListener", value: function removeEventListener(t, e) { if (!this.eventListeners.has(t)) return; this.eventListeners.get(t)["delete"](e); } }, { key: "shouldReturnCallbackResult", value: function shouldReturnCallbackResult(t, _ref) { var e = _ref.abortOnTrue, r = _ref.abortOnFalse, s = _ref.returnOnValue; return !(!1 !== t || !r) || !(!0 !== t || !e) || !(void 0 === t || !s); } }, { key: "runEvent", value: function runEvent(t) { var _ref2 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, _ref2$abortOnTrue = _ref2.abortOnTrue, e = _ref2$abortOnTrue === void 0 ? !1 : _ref2$abortOnTrue, _ref2$abortOnFalse = _ref2.abortOnFalse, r = _ref2$abortOnFalse === void 0 ? !1 : _ref2$abortOnFalse, _ref2$returnOnValue = _ref2.returnOnValue, s = _ref2$returnOnValue === void 0 ? !1 : _ref2$returnOnValue; if (!this.eventListeners.has(t)) return; var n = this.eventListeners.get(t); for (var _len = arguments.length, a = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { a[_key - 2] = arguments[_key]; } var _iterator2 = _createForOfIteratorHelper(n), _step2; try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { var _t4 = _step2.value; if ("number" == typeof _t4) { this.runCommonEvent(_t4); continue; } if ("function" != typeof _t4) { console.error("CycloneEngine: Invalid callback type:"), console.log(_t4); continue; } var _n = _t4.apply(void 0, a); if (this.shouldReturnCallbackResult(_n, { abortOnTrue: e, abortOnFalse: r, returnOnValue: s })) return _n; } } catch (err) { _iterator2.e(err); } finally { _iterator2.f(); } } }, { key: "runCommonEvent", value: function runCommonEvent(t) { var _this = this; var e = globalThis.$dataCommonEvents[t]; if (!e) return; var r = new Game_Interpreter(1); if (r.setup(e.list, 0), !this._interpreters) { this._interpreters = new Set(); var _t5 = SceneManager.updateMain; SceneManager.updateMain = function () { _t5.call(SceneManager), _this.update(); }; } this._interpreters.add(r); } }, { key: "update", value: function update() { if (this._interpreters) { var _iterator3 = _createForOfIteratorHelper(this._interpreters), _step3; try { for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { var _t6 = _step3.value; _t6.update(), _t6.isRunning() || this._interpreters["delete"](_t6); } } catch (err) { _iterator3.e(err); } finally { _iterator3.f(); } } } }, { key: "getPluginFileName", value: function getPluginFileName() { var _this$fileName; return (_this$fileName = this.fileName) !== null && _this$fileName !== void 0 ? _this$fileName : this.pluginName; } }, { key: "isTrue", value: function isTrue(e) { return "string" != typeof e ? Boolean(e) : t.includes(e.toUpperCase()); } }, { key: "isFalse", value: function isFalse(t) { return !this.isTrue(t); } }, { key: "getIntParam", value: function getIntParam(_ref3) { var t = _ref3.value, e = _ref3.defaultValue; try { var r = parseInt(t); return isNaN(r) ? e : r; } catch (r) { return "" !== t && console.error("Cyclone Engine plugin ".concat(this.pluginName, ": Param is expected to be an integer number, but the received value was '").concat(t, "'.")), e; } } }, { key: "getFloatParam", value: function getFloatParam(_ref4) { var t = _ref4.value, e = _ref4.defaultValue; try { var r = parseFloat(t.replace(",", ".")); return isNaN(r) ? e : r; } catch (r) { return "" !== t && console.error("Cyclone Engine plugin ".concat(this.pluginName, ": Param is expected to be a number, but the received value was '").concat(t, "'.")), e; } } }, { key: "getIntListParam", value: function getIntListParam(_ref5) { var _this2 = this; var t = _ref5.value; return this.parseArray((t !== null && t !== void 0 ? t : "").trim(), function (t) { try { return parseInt(t.trim()); } catch (e) { return "" !== t && console.error("Cyclone Engine plugin ".concat(_this2.pluginName, ": Param is expected to be a list of integer numbers, but one of the items was '").concat(t, "'.")), 0; } }); } }, { key: "parseStructArrayParam", value: function parseStructArrayParam(_ref6) { var t = _ref6.data, e = _ref6.type; var r = []; var _iterator4 = _createForOfIteratorHelper(t), _step4; try { for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) { var s = _step4.value; var _t7 = this.parseStructParam({ value: s, defaultValue: "", type: e }); _t7 && r.push(_t7); } } catch (err) { _iterator4.e(err); } finally { _iterator4.f(); } return r; } }, { key: "getFloatListParam", value: function getFloatListParam(_ref7) { var _this3 = this; var t = _ref7.value; return this.parseArray((t || "").trim(), function (t) { try { return parseFloat(t.trim()); } catch (e) { return "" !== t && console.error("Cyclone Engine plugin ".concat(_this3.pluginName, ": Param ").concat(name, " is expected to be a list of numbers, but one of the items was '").concat(t, "'.")), 0; } }); } }, { key: "getParam", value: function getParam(_ref8) { var t = _ref8.key, e = _ref8.value, r = _ref8.defaultValue, s = _ref8.type; try { if (s.endsWith("[]")) return this.parseArrayParam({ key: t, value: e, type: s }); if (s.startsWith("struct<")) return this.parseStructParam({ key: t, value: e, defaultValue: r, type: s }); if (void 0 === e) return r; switch (s) { case "int": return this.getIntParam({ value: e, defaultValue: r }); case "float": return this.getFloatParam({ value: e, defaultValue: r }); case "boolean": return "boolean" == typeof e ? e : this.isTrue(String(e).trim()); default: return e; } } catch (e) { throw t && console.error(t), e; } } }, { key: "getPluginParam", value: function getPluginParam(t) { return this.params.get(t); } }, { key: "defaultValueForType", value: function defaultValueForType(t) { switch (t) { case "int": case "float": return 0; case "boolean": return !1; } return ""; } }, { key: "parseParam", value: function parseParam(t, e, r) { var _r$get; var s = e[t]; s && "string" == typeof s && (s = { type: s, defaultValue: this.defaultValueForType(s) }); var _s = s, _s$name = _s.name, a = _s$name === void 0 ? t : _s$name, _s$type = _s.type, n = _s$type === void 0 ? "string" : _s$type, _s$defaultValue = _s.defaultValue, i = _s$defaultValue === void 0 ? "" : _s$defaultValue; var o; if (r) o = (_r$get = r.get(a)) !== null && _r$get !== void 0 ? _r$get : i;else { var _value; o = (_value = (this.getPluginParam(a) || {}).value) !== null && _value !== void 0 ? _value : i; } return this.getParam({ key: t, value: o, defaultValue: i, type: n }); } }, { key: "parseArrayParam", value: function parseArrayParam(_ref9) { var t = _ref9.value, e = _ref9.type; var r = this.parseArray(t); if (!r || !r.length) return r; var s = e.substr(0, e.length - 2), a = []; var _iterator5 = _createForOfIteratorHelper(r), _step5; try { for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) { var _t8 = _step5.value; var _e5 = this.defaultValueForType(s); a.push(this.getParam({ value: _t8, type: s, defaultValue: _e5 })); } } catch (err) { _iterator5.e(err); } finally { _iterator5.f(); } return a; } }, { key: "getRegexMatch", value: function getRegexMatch(t, e, r) { var s = t.match(e); if (s) return s[r]; } }, { key: "parseStructData", value: function parseStructData(t, e) { for (var r in t) { if (!t.hasOwnProperty(r)) continue; var s = t[r]; "string" == typeof s && (s = { type: s, defaultValue: this.defaultValueForType(s) }), e[r] = this.getParam({ key: r, value: e[r], defaultValue: s.defaultValue, type: s.type }); } return e; } }, { key: "parseStructParam", value: function parseStructParam(_ref10) { var t = _ref10.key, e = _ref10.value, r = _ref10.defaultValue, s = _ref10.type; var a; if (e) try { a = JSON.parse(e); } catch (r) { console.error("Cyclone Engine failed to parse param structure: ", t, e), console.error(r); } if (!a) try { a = JSON.parse(r); } catch (e) { throw console.error("Cyclone Engine failed to parse default value: ", t, r), e; } var n = this.getRegexMatch(s, /struct<(.*)>/i, 1); if (!n) return console.error("Unknown plugin param type: ".concat(s, " (").concat(t || "", ")")), a; var i = this.structs.get(n); return i ? this.parseStructData(i, a) : (console.error("Unknown param structure type: ".concat(n, " (").concat(t || "", ")")), a); } }, { key: "parseList", value: function parseList(t, e) { var r = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ","; var s = t; s.startsWith("[") && (s = s.substr(1)), s.endsWith("]") && (s = s.substr(0, s.length - 1)); var a = s.split(r || ","); return e ? a.map(function (t) { return e(t); }) : a; } }, { key: "parseArray", value: function parseArray(t, e) { var r; try { r = JSON.parse(t); } catch (t) { return []; } return r && r.length ? e ? r.map(function (t) { return e(t); }) : r : []; } }, { key: "registerCommand", value: function registerCommand(t, e, r) { var _this4 = this; var s = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : []; return "function" == typeof e ? PluginManager.registerCommand(this.getPluginFileName(), t, e) : PluginManager.registerCommand(this.getPluginFileName(), t, function (t) { var s = new Map(); for (var _e6 in t) { t.hasOwnProperty(_e6) && s.set(_e6, t[_e6]); } var a = _this4.loadParamMap(e, s); return Object.assign(t, a), r(t); }); } }]); return e; }(CyclonePatcher); globalThis.CyclonePlugin = e; var Layers = { shadows: 4, regions: 5, events: 6, auto: 7, collisions: 8, tags: 9, blend: 10 }; var Tools = { eraser: 'eraser', pencil: 'pencil', rectangle: 'rectangle', fill: 'fill', passage: 'passage', passage4: 'passage4', ladder: 'ladder', bush: 'bush', counter: 'counter', damage: 'damage', terrain: 'terrain' }; var tilePropTools = [Tools.passage, Tools.passage4, Tools.ladder, Tools.bush, Tools.counter, Tools.damage, Tools.terrain]; var TilePassageType = { free: 0, blocked: 1, star: 2 }; var MapshotTileMap = /*#__PURE__*/function (_Bitmap) { _inherits(MapshotTileMap, _Bitmap); var _super2 = _createSuper(MapshotTileMap); function MapshotTileMap() { var _this5; _classCallCheck(this, MapshotTileMap); var tileWidth = $gameMap.tileWidth(); var tileHeight = $gameMap.tileHeight(); var width = $gameMap.width() * tileWidth; var height = $gameMap.height() * tileHeight; _this5 = _super2.call(this, width, height); _this5.flags = $gameMap.tileset().flags; return _this5; } _createClass(MapshotTileMap, [{ key: "drawSingleLayer", value: function drawSingleLayer(layerIndex) { var width = $gameMap.width(); var height = $gameMap.height(); for (var y = 0; y < height; y++) { for (var _x = 0; _x < width; _x++) { this.drawLayerSpot(_x, y, layerIndex); } } } }, { key: "drawLayerSpot", value: function drawLayerSpot(x, y, z) { var _$dataMap$data$index; var filterFn = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : undefined; var index = CycloneMapEditor.tileIndex(x, y, z); var tileId = (_$dataMap$data$index = $dataMap.data[index]) !== null && _$dataMap$data$index !== void 0 ? _$dataMap$data$index : 0; if (filterFn && !filterFn(tileId)) { return; } var drawX = x * $gameMap.tileWidth(); var drawY = y * $gameMap.tileHeight(); this.drawTile(tileId, drawX, drawY); } }, { key: "isHigherTile", value: function isHigherTile(tileId) { return this.flags[tileId] & 0x10; } }, { key: "drawLowerTiles", value: function drawLowerTiles() { var _this6 = this; var width = $gameMap.width(); var height = $gameMap.height(); var filterFn = function filterFn(tileId) { return !_this6.isHigherTile(tileId); }; for (var z = 0; z <= 3; z++) { for (var y = 0; y < height; y++) { for (var _x2 = 0; _x2 < width; _x2++) { this.drawLayerSpot(_x2, y, z, filterFn); } } } } }, { key: "drawUpperTiles", value: function drawUpperTiles() { var _this7 = this; var width = $gameMap.width(); var height = $gameMap.height(); var filterFn = function filterFn(tileId) { return _this7.isHigherTile(tileId); }; for (var z = 0; z <= 3; z++) { for (var y = 0; y < height; y++) { for (var _x3 = 0; _x3 < width; _x3++) { this.drawLayerSpot(_x3, y, z, filterFn); } } } } }, { key: "drawEvents", value: function drawEvents() { var priority = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined; var events = SceneManager._scene._spriteset._tilemap.children.filter(function (child) { return child instanceof Sprite_Character; }); var _iterator6 = _createForOfIteratorHelper(events), _step6; try { for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) { var sprite = _step6.value; if (sprite._character !== null) { if (sprite._character instanceof Game_Player || sprite._character instanceof Game_Follower || sprite._character instanceof Game_Vehicle) { continue; } } sprite.update(); if (sprite._characterName === '' && sprite._tileId === 0) { continue; } if (priority !== undefined && sprite._character._priorityType !== priority) { continue; } var _x4 = sprite.x - sprite._frame.width / 2 + $gameMap._displayX * $gameMap.tileWidth(); var y = sprite.y - sprite._frame.height + $gameMap._displayY * $gameMap.tileHeight(); this.blt(sprite.bitmap, sprite._frame.x, sprite._frame.y, sprite._frame.width, sprite._frame.height, _x4, y, sprite._frame.width, sprite._frame.height); } } catch (err) { _iterator6.e(err); } finally { _iterator6.f(); } } }, { key: "drawDefaultCollision", value: function drawDefaultCollision() { var width = $gameMap.width(); var height = $gameMap.height(); for (var y = 0; y < height; y++) { for (var _x5 = 0; _x5 < width; _x5++) { var drawWidth = CycloneMapEditor.tileWidth; var drawHeight = CycloneMapEditor.tileHeight; var drawX = _x5 * drawWidth; var drawY = y * drawHeight; var downBlocked = !$gameMap.isPassable(_x5, y, 2); var upBlocked = !$gameMap.isPassable(_x5, y, 8); var leftBlocked = !$gameMap.isPassable(_x5, y, 4); var rightBlocked = !$gameMap.isPassable(_x5, y, 6); if (downBlocked && upBlocked && leftBlocked && rightBlocked) { this.fillRect(drawX, drawY, drawWidth, drawHeight, '#FF0000'); continue; } var pieceHeight = Math.floor(drawHeight / 4); var pieceWidth = Math.floor(drawWidth / 4); if (downBlocked) { this.fillRect(drawX, drawY + drawHeight - pieceHeight, drawWidth, pieceHeight, '#FF00FF'); } if (upBlocked) { this.fillRect(drawX, drawY, drawWidth, pieceHeight, '#FF00FF'); } if (leftBlocked) { this.fillRect(drawX, drawY, pieceWidth, drawHeight, '#FF00FF'); } if (rightBlocked) { this.fillRect(drawX + drawWidth - pieceWidth, drawY, pieceWidth, drawHeight, '#FF00FF'); } } } } }, { key: "drawCustomCollision", value: function drawCustomCollision() { var customCollisionTable = CycloneMapEditor.customCollisionTable; var height = $gameMap.height(); var width = $gameMap.width(); var tileWidth = CycloneMapEditor.tileWidth; var tileHeight = CycloneMapEditor.tileHeight; var drawWidth = tileWidth / 4; var drawHeight = tileHeight / 4; var colors = ['#00FF00', '#FF0000']; var collisionHeight = height * 4; var collisionWidth = width * 4; for (var y = 0; y < height; y++) { for (var _x6 = 0; _x6 < width; _x6++) { for (var cellX = 0; cellX < 4; cellX++) { for (var cellY = 0; cellY < 4; cellY++) { var intX = Math.floor(_x6 * 4) + cellX; var intY = Math.floor(y * 4) + cellY; var index = intY % collisionHeight * collisionWidth + intX % collisionWidth; // eslint-disable-next-line max-depth if (customCollisionTable[index]) { var drawX = intX * drawWidth; var drawY = intY * drawHeight; this.clearRect(drawX, drawY, drawWidth, drawHeight); var colorIndex = customCollisionTable[index] - 1; var color = colors[colorIndex % colors.length]; this.fillRect(drawX, drawY, drawWidth, drawHeight, color); } } } } } } }]); return MapshotTileMap; }(Bitmap); var LZString = function () { function o(o, r) { if (!t[o]) { t[o] = {}; for (var n = 0; n < o.length; n++) { t[o][o.charAt(n)] = n; } } return t[o][r]; } var r = String.fromCharCode, n = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=", e = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$", t = {}, i = { compressToBase64: function compressToBase64(o) { if (null == o) return ""; var r = i._compress(o, 6, function (o) { return n.charAt(o); }); switch (r.length % 4) { default: case 0: return r; case 1: return r + "==="; case 2: return r + "=="; case 3: return r + "="; } }, decompressFromBase64: function decompressFromBase64(r) { return null == r ? "" : "" == r ? null : i._decompress(r.length, 32, function (e) { return o(n, r.charAt(e)); }); }, compressToUTF16: function compressToUTF16(o) { return null == o ? "" : i._compress(o, 15, function (o) { return r(o + 32); }) + " "; }, decompressFromUTF16: function decompressFromUTF16(o) { return null == o ? "" : "" == o ? null : i._decompress(o.length, 16384, function (r) { return o.charCodeAt(r) - 32; }); }, compressToUint8Array: function compressToUint8Array(o) { for (var r = i.compress(o), n = new Uint8Array(2 * r.length), e = 0, t = r.length; t > e; e++) { var s = r.charCodeAt(e); n[2 * e] = s >>> 8, n[2 * e + 1] = s % 256; } return n; }, decompressFromUint8Array: function decompressFromUint8Array(o) { if (null === o || void 0 === o) return i.decompress(o); for (var n = new Array(o.length / 2), e = 0, t = n.length; t > e; e++) { n[e] = 256 * o[2 * e] + o[2 * e + 1]; } var s = []; return n.forEach(function (o) { s.push(r(o)); }), i.decompress(s.join("")); }, compressToEncodedURIComponent: function compressToEncodedURIComponent(o) { return null == o ? "" : i._compress(o, 6, function (o) { return e.charAt(o); }); }, decompressFromEncodedURIComponent: function decompressFromEncodedURIComponent(r) { return null == r ? "" : "" == r ? null : (r = r.replace(/ /g, "+"), i._decompress(r.length, 32, function (n) { return o(e, r.charAt(n)); })); }, compress: function compress(o) { return i._compress(o, 16, function (o) { return r(o); }); }, _compress: function _compress(o, r, n) { if (null == o) return ""; var e, t, i, s = {}, p = {}, u = "", c = "", a = "", l = 2, f = 3, h = 2, d = [], m = 0, v = 0; for (i = 0; i < o.length; i += 1) { if (u = o.charAt(i), Object.prototype.hasOwnProperty.call(s, u) || (s[u] = f++, p[u] = !0), c = a + u, Object.prototype.hasOwnProperty.call(s, c)) a = c;else { if (Object.prototype.hasOwnProperty.call(p, a)) { if (a.charCodeAt(0) < 256) { for (e = 0; h > e; e++) { m <<= 1, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++; } for (t = a.charCodeAt(0), e = 0; 8 > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } } else { for (t = 1, e = 0; h > e; e++) { m = m << 1 | t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t = 0; } for (t = a.charCodeAt(0), e = 0; 16 > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } } l--, 0 == l && (l = Math.pow(2, h), h++), delete p[a]; } else for (t = s[a], e = 0; h > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } l--, 0 == l && (l = Math.pow(2, h), h++), s[c] = f++, a = String(u); } } if ("" !== a) { if (Object.prototype.hasOwnProperty.call(p, a)) { if (a.charCodeAt(0) < 256) { for (e = 0; h > e; e++) { m <<= 1, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++; } for (t = a.charCodeAt(0), e = 0; 8 > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } } else { for (t = 1, e = 0; h > e; e++) { m = m << 1 | t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t = 0; } for (t = a.charCodeAt(0), e = 0; 16 > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } } l--, 0 == l && (l = Math.pow(2, h), h++), delete p[a]; } else for (t = s[a], e = 0; h > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } l--, 0 == l && (l = Math.pow(2, h), h++); } for (t = 2, e = 0; h > e; e++) { m = m << 1 | 1 & t, v == r - 1 ? (v = 0, d.push(n(m)), m = 0) : v++, t >>= 1; } for (;;) { if (m <<= 1, v == r - 1) { d.push(n(m)); break; } v++; } return d.join(""); }, decompress: function decompress(o) { return null == o ? "" : "" == o ? null : i._decompress(o.length, 32768, function (r) { return o.charCodeAt(r); }); }, _decompress: function _decompress(o, n, e) { var i, s, p, u, c, a, l, f = [], h = 4, d = 4, m = 3, v = "", w = [], A = { val: e(0), position: n, index: 1 }; for (i = 0; 3 > i; i += 1) { f[i] = i; } for (p = 0, c = Math.pow(2, 2), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } switch (p) { case 0: for (p = 0, c = Math.pow(2, 8), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } l = r(p); break; case 1: for (p = 0, c = Math.pow(2, 16), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } l = r(p); break; case 2: return ""; } for (f[3] = l, s = l, w.push(l);;) { if (A.index > o) return ""; for (p = 0, c = Math.pow(2, m), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } switch (l = p) { case 0: for (p = 0, c = Math.pow(2, 8), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } f[d++] = r(p), l = d - 1, h--; break; case 1: for (p = 0, c = Math.pow(2, 16), a = 1; a != c;) { u = A.val & A.position, A.position >>= 1, 0 == A.position && (A.position = n, A.val = e(A.index++)), p |= (u > 0 ? 1 : 0) * a, a <<= 1; } f[d++] = r(p), l = d - 1, h--; break; case 2: return w.join(""); } if (0 == h && (h = Math.pow(2, m), m++), f[l]) v = f[l];else { if (l !== d) return null; v = s + s.charAt(0); } w.push(v), f[d++] = s + v.charAt(0), h--, s = v, 0 == h && (h = Math.pow(2, m), m++); } } }; return i; }(); "function" == typeof define && define.amd ? define(function () { return LZString; }) : "undefined" != typeof module && null != module && (module.exports = LZString); function throttle(fn, delay) { var _this8 = this; var timeout; var latestArgs; var needsCalling = false; var call = function call() { timeout = setTimeout(function () { if (needsCalling) { call(); } else { timeout = false; } needsCalling = false; }, delay); fn.call.apply(fn, [_this8].concat(_toConsumableArray(latestArgs))); }; var debounced = function debounced() { for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { args[_key2] = arguments[_key2]; } latestArgs = args; if (timeout) { needsCalling = true; return; } call(); }; return debounced; } function debounce(fn, delay) { var clearTimer; return function () { for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { args[_key3] = arguments[_key3]; } var context = this; clearTimeout(clearTimer); clearTimer = setTimeout(function () { return fn.call.apply(fn, [context].concat(args)); }, delay); }; } var DirectionHelper = /*#__PURE__*/function () { function DirectionHelper() { _classCallCheck(this, DirectionHelper); } _createClass(DirectionHelper, null, [{ key: "goesLeft", value: function goesLeft(d) { return d && d % 3 === 1; } }, { key: "goesRight", value: function goesRight(d) { return d && d % 3 === 0; } }, { key: "goesUp", value: function goesUp(d) { return d >= 7 && d <= 9; } }, { key: "goesDown", value: function goesDown(d) { return d >= 1 && d <= 3; } }, { key: "isDiagonal", value: function isDiagonal(d) { return this.isVertical(d) && this.isHorizontal(d); } }, { key: "isVertical", value: function isVertical(d) { return this.goesDown(d) || this.goesUp(d); } }, { key: "isHorizontal", value: function isHorizontal(d) { return this.goesLeft(d) || this.goesRight(d); } }, { key: "shareADirection", value: function shareADirection(dir1, dir2) { if (this.goesDown(dir1) && this.goesDown(dir2)) { return true; } if (this.goesLeft(dir1) && this.goesLeft(dir2)) { return true; } if (this.goesRight(dir1) && this.goesRight(dir2)) { return true; } if (this.goesUp(dir1) && this.goesUp(dir2)) { return true; } return false; } }, { key: "getFirstDirection", value: function getFirstDirection(diagonalDirection) { if (!diagonalDirection) { return diagonalDirection; } if (diagonalDirection > 6) { return 8; } if (diagonalDirection < 4) { return 2; } return diagonalDirection; } }, { key: "getAlternativeDirection", value: function getAlternativeDirection(direction, diagonalDirection) { if (direction === diagonalDirection) { return direction; } switch (diagonalDirection) { case 7: return direction == 8 ? 4 : 8; case 9: return direction == 8 ? 6 : 8; case 1: return direction == 2 ? 4 : 2; case 3: return direction == 2 ? 6 : 2; } return direction; } }]); return DirectionHelper; }(); function _logImage(canvas, text) { var url = canvas.toDataURL(); var scale = 1; var img = new Image(); function getBox(width, height) { return { string: '+', style: "font-size: 1px; padding: ".concat(Math.floor(height / 2), "px ").concat(Math.floor(width / 2), "px; line-height: ").concat(height, "px;") }; } img.onload = function () { var dim = getBox(this.width * scale, this.height * scale); if (text) { console.log(text); } console.log("%c".concat(dim.string), "".concat(dim.style, "background: url('").concat(url, "'); background-size: ").concat(this.width * scale, "px ").concat(this.height * scale, "px; color: transparent;")); }; img.src = url; } function getTilesetIndex(tileId) { if (tileId >= Tilemap.TILE_ID_A5 + 256 && tileId < Tilemap.TILE_ID_A1) { return 11; } if (Tilemap.isTileA1(tileId)) { return 0; } if (Tilemap.isTileA2(tileId)) { return 1; } if (Tilemap.isTileA3(tileId)) { return 2; } if (Tilemap.isTileA4(tileId)) { return 3; } if (Tilemap.isTileA5(tileId)) { return 4; } return 5 + Math.floor(tileId / 256); } var layerVisibility = [true, true, true, true, true, false, true, false, false, false, false]; var editorActive = true; var windowWidth = 216; var mapCaches = {}; var customCollisionTable = {}; var tileBlendingTable = {}; var currentLayer = 7; var currentTab = 'A'; var currentTileId = undefined; var tileCols = 1; var tileRows = 1; var selectedTileList = []; var multiLayerSelection = []; var tileWidth = 48; var tileHeight = 48; var currentTool = 'pencil'; var lastDrawingTool = 'pencil'; var wasPressing = false; var isRightButtonDown = false; var wasRightButtonDown = false; var rectangleStartMouseX = 0; var rectangleStartMouseY = 0; var rectangleStartX = 0; var rectangleStartY = 0; var rectangleWidth = 0; var rectangleHeight = 0; var rectangleBackWidth = 0; var rectangleBackHeight = 0; var tabs = ['A', 'B', 'C', 'D', 'E']; var changeHistory = []; var undoHistory = []; var currentChange = false; var previewChanges = {}; var messySelection = false; var showGrid = true; var statusTileId = 0; var statusMapX = 0; var statusMapY = 0; var statusTile1 = 0; var statusTile2 = 0; var statusTile3 = 0; var statusTile4 = 0; var statusRegion = 0; var statusTag = 0; var statusCollision = 0; var statusBush = false; var statusCounter = false; var statusDamage = false; var statusLadder = false; var currentZoom = 1; var puzzleMode = false; var circleData = false; var smallCircleData = false; var _ = ''; var o = true; var x = false; var autoTileShapeTable = [// o means there's a compatible tile on that position, // x means there is no compatible tile on that position // _ means that position doesn't matter [o, o, o, o, o, o, o, o], // 0 [x, o, o, o, o, o, o, o], // 1 [o, o, x, o, o, o, o, o], // 2 [x, o, x, o, o, o, o, o], // 3 [o, o, o, o, o, o, o, x], // 4 [x, o, o, o, o, o, o, x], // 5 [o, o, x, o, o, o, o, x], // 6 [x, o, x, o, o, o, o, x], // 7 [o, o, o, o, o, x, o, o], // 8 [x, o, o, o, o, x, o, o], // 9 [o, o, x, o, o, x, o, o], //10 [x, o, x, o, o, x, o, o], //11 [o, o, o, o, o, x, o, x], //12 [x, o, o, o, o, x, o, x], //13 [o, o, x, o, o, x, o, x], //14 [x, o, x, o, o, x, o, x], //15 [_, o, o, x, o, _, o, o], //16 [_, o, x, x, o, _, o, o], //17 [_, o, o, x, o, _, o, x], //18 [_, o, x, x, o, _, o, x], //19 [_, x, _, o, o, o, o, o], //20 [_, x, _, o, o, o, o, x], //21 [_, x, _, o, o, x, o, o], //22 [_, x, _, o, o, x, o, x], //23 [o, o, _, o, x, o, o, _], //24 [o, o, _, o, x, x, o, _], //25 [x, o, _, o, x, o, o, _], //26 [x, o, _, o, x, x, o, _], //27 [o, o, o, o, o, _, x, _], //28 [x, o, o, o, o, _, x, _], //29 [o, o, x, o, o, _, x, _], //30 [x, o, x, o, o, _, x, _], //31 [_, o, _, x, x, _, o, _], //32 [_, x, _, o, o, _, x, _], //33 [_, x, _, x, o, _, o, o], //34 [_, x, _, x, o, _, o, x], //35 [_, x, _, o, x, o, o, _], //36 [_, x, _, o, x, x, o, _], //37 [o, o, _, o, x, _, x, _], //38 [x, o, _, o, x, _, x, _], //39 [_, o, o, x, o, _, x, _], //40 [_, o, x, x, o, _, x, _], //41 [_, x, _, x, x, _, o, _], //42 [_, x, _, x, o, _, x, _], //43 [_, o, _, x, x, _, x, _], //44 [_, x, _, o, x, _, x, _], //45 [_, x, _, x, x, _, x, _] //46 ]; var highLayerAutotiles = [1, 2, 3, 20, 21, 22, 23, 28, 29, 30, 31, 36, 37, 38, 39, 44, 45, 46, 47]; var refreshGrid = throttle(function () { SceneManager._scene._mapEditorGrid.refresh(); }, 50); var _refreshTilemap = throttle(function () { SceneManager._scene._spriteset._tilemap.refresh(); }, 200); var refreshCollision = throttle(function () { if (TouchInput.isPressed()) { setTimeout(function () { refreshCollision(); }, 1); return; } if (window.CycloneMovement) { window.CycloneMovement.setupCollision(); } }, 200); var refreshMagic = throttle(function () { if (TouchInput.isPressed()) { setTimeout(function () { refreshMagic(); }, 1); return; } if (window.CycloneMagic) { window.CycloneMagic.loadMagic(); forceBlenderRefresh(true); } }); var forceBlenderRefresh = throttle(function () { CycloneMapEditor$1.forceBlenderRefresh.apply(CycloneMapEditor$1, arguments); }, 50); var saveExtraData = throttle(function () { var refreshCollisionToo = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (TouchInput.isPressed()) { setTimeout(function () { saveExtraData(refreshCollisionToo); }, 1); return; } CycloneMapEditor$1.saveExtraData(); if (refreshCollisionToo) { refreshCollision(); refreshMagic(); } }, 200); var fullRefresh = debounce(function () { saveExtraData(true); }, 500); var CycloneMapEditor$1 = /*#__PURE__*/function (_CyclonePlugin) { _inherits(CycloneMapEditor$1, _CyclonePlugin); var _super3 = _createSuper(CycloneMapEditor$1); function CycloneMapEditor$1() { _classCallCheck(this, CycloneMapEditor$1); return _super3.apply(this, arguments); } _createClass(CycloneMapEditor$1, null, [{ key: "register", value: function register() { var _this9 = this; _get(_getPrototypeOf(CycloneMapEditor$1), "initialize", this).call(this, 'CycloneMapEditor'); this.structs.set('CycloneRegionIcon', { regionId: 'int', icon: 'int' }); _get(_getPrototypeOf(CycloneMapEditor$1), "register", this).call(this, { regionIcons: { type: 'struct<CycloneRegionIcon>[]', defaultValue: '[]' }, showMapId: { type: 'boolean', defaultValue: true }, showTilesetId: { type: 'boolean', defaultValue: true }, showPosition: { type: 'boolean', defaultValue: true }, showCellTiles: { type: 'boolean', defaultValue: true }, showRegionId: { type: 'boolean', defaultValue: true }, showTag: { type: 'boolean', defaultValue: true }, showCollision: { type: 'boolean', defaultValue: true }, showLadder: { type: 'boolean', defaultValue: true }, showBush: { type: 'boolean', defaultValue: true }, showCounter: { type: 'boolean', defaultValue: true }, showDamageFloor: { type: 'boolean', defaultValue: true }, collisionStepCount: { type: 'int', defaultValue: 1 } }); document.addEventListener('keydown', function () { _this9.onKeyDown.apply(_this9, arguments); }); document.addEventListener('keypress', function () { _this9.onKeyPress.apply(_this9, arguments); }); document.addEventListener('keyup', function () { _this9.onKeyUp.apply(_this9, arguments); }); var regionIcons = this.params.regionIcons; this.regionIcons = new Map(); if (regionIcons) { var _iterator7 = _createForOfIteratorHelper(regionIcons), _step7; try { for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) { var _step7$value = _step7.value, regionId = _step7$value.regionId, icon = _step7$value.icon; if (regionId && icon) { this.regionIcons.set(regionId, icon); } } } catch (err) { _iterator7.e(err); } finally { _iterator7.f(); } } } }, { key: "mapEditorScene", value: function mapEditorScene() { return Scene_Map; } }, { key: "isMapEditorScene", value: function isMapEditorScene() { return SceneManager._scene instanceof this.mapEditorScene(); } }, { key: "makeMenuEvent", value: function makeMenuEvent(fn) { return function () { if (TouchInput.isPressed()) { return; } fn(); }; } }, { key: "addFileMenu", value: function addFileMenu(menu) { var fileMenu = new nw.Menu(); fileMenu.append(new nw.MenuItem({ label: 'Save Current Map', key: 's', modifiers: 'ctrl', click: this.makeMenuEvent(function () { CycloneMapEditor$1.saveButton(); }) })); fileMenu.append(new nw.MenuItem({ label: 'Reload Current Map', key: 'r', modifiers: 'ctrl', click: this.makeMenuEvent(function () { CycloneMapEditor$1.reloadButton(); }) })); fileMenu.append(new nw.MenuItem({ type: 'separator' })); fileMenu.append(new nw.MenuItem({ label: 'Exit', click: this.makeMenuEvent(function () { window.close(); }) })); menu.append(new nw.MenuItem({ label: 'File', submenu: fileMenu })); } }, { key: "addEditMenu", value: function addEditMenu(menu) { var editMenu = new nw.Menu(); editMenu.append(new nw.MenuItem({ label: 'Undo', key: 'z', modifiers: 'ctrl', click: this.makeMenuEvent(function () { CycloneMapEditor$1.undoButton(); }) })); editMenu.append(new nw.MenuItem({ label: 'Redo', key: 'y', modifiers: 'ctrl', click: this.makeMenuEvent(function () { CycloneMapEditor$1.redoButton(); }) })); editMenu.append(new nw.MenuItem({ type: 'separator' })); this.showGridMenu = new nw.MenuItem({ label: 'Show Grid', type: 'checkbox', checked: showGrid, key: 'g', modifiers: 'ctrl', click: this.makeMenuEvent(function () { CycloneMapEditor$1.showGridButton(); }) }); editMenu.append(this.showGridMenu); // const zoomMenu = new nw.Menu(); // this.zoom100Menu = new nw.MenuItem({ // label: '100%', // type: 'checkbox', // checked: currentZoom === 1, // click: this.makeMenuEvent(() => { // this.currentZoom = 1; // }), // }); // zoomMenu.append(this.zoom100Menu); // this.zoom150Menu = new nw.MenuItem({ // label: '150%', // type: 'checkbox', // checked: currentZoom === 1.5, // click: this.makeMenuEvent(() => { // this.currentZoom = 1.5; // }), // }); // zoomMenu.append(this.zoom150Menu); // this.zoom200Menu = new nw.MenuItem({ // label: '200%', // type: 'checkbox', // checked: currentZoom === 2, // click: this.makeMenuEvent(() => { // this.currentZoom = 2; // }), // }); // zoomMenu.append(this.zoom200Menu); // this.zoom400Menu = new nw.MenuItem({ // label: '400%', // type: 'checkbox', // checked: currentZoom === 4, // click: this.makeMenuEvent(() => { // this.currentZoom = 4; // }), // }); // zoomMenu.append(this.zoom400Menu); // editMenu.append(new nw.MenuItem({ // label: 'Zoom', // submenu: zoomMenu, // })); menu.append(new nw.MenuItem({ label: 'Edit', submenu: editMenu })); } }, { key: "addMapMenu", value: function addMapMenu(menu) { var mapMenu = new nw.Menu(); mapMenu.append(new nw.MenuItem({ label: 'Scroll Up', key: 'w', click: function click() { $gameMap.scrollUp(3); } })); mapMenu.append(new nw.MenuItem({ label: 'Scroll Left', key: 'a', click: function click() { $gameMap.scrollLeft(3); } })); mapMenu.append(new nw.MenuItem({ label: 'Scroll Down', key: 's', click: function click() { $gameMap.scrollDown(3); } })); mapMenu.append(new nw.MenuItem({ label: 'Scroll Right', key: 'd', click: function click() { $gameMap.scrollRight(3); } })); menu.append(new nw.MenuItem({ label: 'Map', submenu: mapMenu })); } }, { key: "addModeMenu", value: function addModeMenu(menu) { var modeMenu = new nw.Menu(); this.pencilMenu = new nw.MenuItem({ label: 'Pencil', type: 'checkbox', checked: currentTool === 'pencil', key: 'p', click: this.makeMenuEvent(function () { CycloneMapEditor$1.pencilButton(); }) }); modeMenu.append(this.pencilMenu); this.rectangleMenu = new nw.MenuItem({ label: 'Rectangle', type: 'checkbox', checked: currentTool === 'rectangle', key: 'r', click: this.makeMenuEvent(function () { CycloneMapEditor$1.rectangleButton(); }) }); modeMenu.append(this.rectangleMenu); this.fillMenu = new nw.MenuItem({ label: 'Flood Fill', type: 'checkbox', checked: currentTool === 'fill', key: 'f', click: this.makeMenuEvent(function () { CycloneMapEditor$1.fillButton(); }) }); modeMenu.append(this.fillMenu); modeMenu.append(new nw.MenuItem({ type: 'separator' })); this.puzzleMenu = new nw.MenuItem({ label: 'Magic Mode', type: 'checkbox', checked: puzzleMode, click: this.makeMenuEvent(function () { CycloneMapEditor$1.puzzleButton(); }) }); modeMenu.append(this.puzzleMenu); modeMenu.append(new nw.MenuItem({ type: 'separator' })); this.eraserMenu = new nw.MenuItem({ label: 'Eraser', type: 'checkbox', checked: currentTool === 'eraser', key: 'e', click: this.makeMenuEvent(function () { CycloneMapEditor$1.eraserButton(); }) }); modeMenu.append(this.eraserMenu); modeMenu.append(new nw.MenuItem({ type: 'separator' })); var tilesetPropsMenu = new nw.Menu(); this.tilePassageMenu = new nw.MenuItem({ label: 'Passage', type: 'checkbox', checked: currentTool === Tools.passage, key: 'p', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.passage); }) }); tilesetPropsMenu.append(this.tilePassageMenu); this.tilePassage4Menu = new nw.MenuItem({ label: 'Passage (4 dir)', type: 'checkbox', checked: currentTool === Tools.passage4, key: 'o', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.passage4); }) }); tilesetPropsMenu.append(this.tilePassage4Menu); this.tileLadderMenu = new nw.MenuItem({ label: 'Ladder', type: 'checkbox', checked: currentTool === Tools.ladder, key: 'l', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.ladder); }) }); tilesetPropsMenu.append(this.tileLadderMenu); this.tileBushMenu = new nw.MenuItem({ label: 'Bush', type: 'checkbox', checked: currentTool === Tools.bush, key: 'b', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.bush); }) }); tilesetPropsMenu.append(this.tileBushMenu); this.tileCounterMenu = new nw.MenuItem({ label: 'Counter', type: 'checkbox', checked: currentTool === Tools.counter, key: 'c', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.counter); }) }); tilesetPropsMenu.append(this.tileCounterMenu); this.tileDamageMenu = new nw.MenuItem({ label: 'Damage', type: 'checkbox', checked: currentTool === Tools.damage, key: 'd', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.damage); }) }); tilesetPropsMenu.append(this.tileDamageMenu); this.tileTerrainMenu = new nw.MenuItem({ label: 'Terrain Tag', type: 'checkbox', checked: currentTool === Tools.terrain, key: 't', modifiers: 'shift', click: this.makeMenuEvent(function () { CycloneMapEditor$1.toolButton(Tools.terrain); }) }); tilesetPropsMenu.append(this.tileTerrainMenu); modeMenu.append(new nw.MenuItem({ label: 'Tile Properties', submenu: tilesetPropsMenu })); menu.append(new nw.MenuItem({ label: 'Mode', submenu: modeMenu })); } }, { key: "addLayerMenu", value: function addLayerMenu(menu) { var layerMenu = new nw.Menu(); this.autoLayerButton = new nw.MenuItem({ label: 'Automatic', type: 'checkbox', checked: currentLayer === 7, key: '0', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(7); }) }); this.layer1Button = new nw.MenuItem({ label: 'Layer 1', type: 'checkbox', checked: currentLayer === 0, key: '1', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(0); }) }); this.layer2Button = new nw.MenuItem({ label: 'Layer 2', type: 'checkbox', checked: currentLayer === 1, key: '2', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(1); }) }); this.layer3Button = new nw.MenuItem({ label: 'Layer 3', type: 'checkbox', checked: currentLayer === 2, key: '3', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(2); }) }); this.layer4Button = new nw.MenuItem({ label: 'Layer 4', type: 'checkbox', checked: currentLayer === 3, key: '4', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(3); }) }); layerMenu.append(this.autoLayerButton); layerMenu.append(this.layer1Button); layerMenu.append(this.layer2Button); layerMenu.append(this.layer3Button); layerMenu.append(this.layer4Button); layerMenu.append(new nw.MenuItem({ type: 'separator' })); this.shadowsButton = new nw.MenuItem({ label: 'Shadows', type: 'checkbox', checked: currentLayer === 4, key: '5', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(4); }) }); layerMenu.append(this.shadowsButton); this.regionsButton = new nw.MenuItem({ label: 'Regions', type: 'checkbox', checked: currentLayer === 5, key: '6', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(5); }) }); layerMenu.append(this.regionsButton); this.eventsButton = new nw.MenuItem({ label: 'Events', type: 'checkbox', checked: currentLayer === 6, key: '7', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(6); }) }); layerMenu.append(this.eventsButton); layerMenu.append(new nw.MenuItem({ type: 'separator' })); this.collisionsButton = new nw.MenuItem({ label: 'Collisions', type: 'checkbox', checked: currentLayer === 8, key: '8', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(8); }) }); layerMenu.append(this.collisionsButton); this.tagsButton = new nw.MenuItem({ label: 'Tags', type: 'checkbox', checked: currentLayer === 9, key: '9', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(9); }) }); layerMenu.append(this.tagsButton); menu.append(new nw.MenuItem({ label: 'Layer', submenu: layerMenu })); } }, { key: "addBlendMenu", value: function addBlendMenu(menu) { var blendMenu = new nw.Menu(); this.blendButton = new nw.MenuItem({ label: 'Blend Layer', type: 'checkbox', checked: currentLayer === 10, key: 'B', click: this.makeMenuEvent(function () { CycloneMapEditor$1.changeCurrentLayer(10); CycloneMapEditor$1.updateCurrentTool(); }) }); blendMenu.append(this.blendButton); blendMenu.append(new nw.MenuItem({ type: 'separator' })); blendMenu.append(new nw.MenuItem({ label: 'Remove blend effect', click: this.makeMenuEvent(function () { CycloneMapEditor$1.removeAllBlendsButton(); }) })); blendMenu.append(new nw.MenuItem({ label: 'Optimize blend effect', click: this.makeMenuEvent(function () { CycloneMapEditor$1.optimizeBlendsButton(); }) })); menu.append(new nw.MenuItem({ label: 'Blend', submenu: blendMenu })); } }, { key: "addTilesetMenu", value: function addTilesetMenu(menu) { var _this10 = this; var tilesetMenu = new nw.Menu(); this._mainTilesetMenu = new nw.MenuItem({ label: 'Main Tileset', enabled: false }); tilesetMenu.append(this._mainTilesetMenu); this._extraTilesetMenu = new nw.Menu(); var _iterator8 = _createForOfIteratorHelper($dataTilesets), _step8; try { var _loop = function _loop() { var tileset = _step8.value; if (!tileset) { return "continue"; } var tilesetNames = tileset.tilesetNames; if (!tilesetNames[5] && !tilesetNames[6]) { return "continue"; } var menuItem = new nw.MenuItem({ label: "".concat(tileset.id.padZero(4), " ").concat(tileset.name), enabled: true, type: 'checkbox', click: _this10.makeMenuEvent(function () { _this10.toggleTileset(tileset.id); }) }); _this10._extraTilesetMenu.append(menuItem); }; for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) { var _ret = _loop(); if (_ret === "continue") continue; } } catch (err) { _iterator8.e(err); } finally { _iterator8.f(); } this._extraTilesetMenuItem = new nw.MenuItem({ label: 'Extra Tileset', submenu: this._extraTilesetMenu }); tilesetMenu.append(this._extraTilesetMenuItem); menu.append(new nw.MenuItem({ label: 'Tilesets', submenu: tilesetMenu })); } }, { key: "addJumpMenu", value: function addJumpMenu(menu) { var a1 = Tilemap.TILE_ID_A1; var a2 = Tilemap.TILE_ID_A2; var a3 = Tilemap.TILE_ID_A3; var a4 = Tilemap.TILE_ID_A4; var b = Tilemap.TILE_ID_B; var c = Tilemap.TILE_ID_C; var d = Tilemap.TILE_ID_D; var e = Tilemap.TILE_ID_E; var f = Tilemap.TILE_ID_E + 256; var g = Tilemap.TILE_ID_E + 512; var a5 = Tilemap.TILE_ID_A5; var h = Tilemap.TILE_ID_A5 + 256; var jumpToTabMenu = new nw.Menu(); jumpToTabMenu.append(new nw.MenuItem({ label: 'AutoTiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([a1, a2, a3, a4]); }) })); jumpToTabMenu.append(new nw.MenuItem({ label: 'A5 Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToTile(a5); }) })); jumpToTabMenu.append(new nw.MenuItem({ label: 'B Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([b, c, d, e, f, g, a5]); }) })); jumpToTabMenu.append(new nw.MenuItem({ label: 'C Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([c, d, e, f, g, a5]); }) })); jumpToTabMenu.append(new nw.MenuItem({ label: 'D Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([d, e, f, g, a5]); }) })); jumpToTabMenu.append(new nw.MenuItem({ label: 'E Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([e, f, g, a5]); }) })); this._jumpToExtraBMenu = new nw.MenuItem({ label: 'Extra B Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([f, g, a5]); }) }); jumpToTabMenu.append(this._jumpToExtraBMenu); this._jumpToExtraCMenu = new nw.MenuItem({ label: 'Extra C Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([g, a5]); }) }); jumpToTabMenu.append(this._jumpToExtraCMenu); this._jumpToExtraDMenu = new nw.MenuItem({ label: 'Extra D Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.jumpToOneTileOf([h, a5]); }) }); jumpToTabMenu.append(this._jumpToExtraDMenu); menu.append(new nw.MenuItem({ label: 'Jump To', submenu: jumpToTabMenu })); } }, { key: "refreshTilesetMenu", value: function refreshTilesetMenu() { if (!this._extraTilesetMenu) { return; } var tileset = $gameMap.tileset(); this._mainTilesetMenu.label = "".concat(tileset.id.padZero(4), " ").concat(tileset.name); var _iterator9 = _createForOfIteratorHelper(this._extraTilesetMenu.items), _step9; try { for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) { var item = _step9.value; var id = parseInt(item.label.substring(0, 4), 10); if (id === $gameMap._tilesetId) { item.checked = false; item.enabled = false; continue; } item.enabled = true; item.checked = $gameMap._extraTilesetId === id; } } catch (err) { _iterator9.e(err); } finally { _iterator9.f(); } } }, { key: "addToolsMenu", value: function addToolsMenu(menu) { var toolsMenu = new nw.Menu(); var resizeTilesets = new nw.MenuItem({ label: 'Generate 48x48 Tilesets', enabled: $gameMap.tileWidth() !== 48 || $gameMap.tileHeight() !== 48, click: this.makeMenuEvent(function () { var width = $gameMap.tileWidth(); var height = $gameMap.tileHeight(); var message; if (globalThis.CycloneMaps && CycloneMaps.params.tilesetPath) { var realPath = CycloneMaps.params.tilesetPath; var fakePath = 'img/tilesets/'; message = "This option will replace the 48x48 files on ".concat(fakePath, " with resized copies of the ").concat(width, "x").concat(height, " files on ").concat(realPath, ". Are you SURE you want to do this?"); } else { message = "This option will replace the files on /img/tilesets with resized copies of your ".concat(width, "x").concat(height, " tilesets. Are you SURE you want to do this?"); } CycloneMapEditor$1.resizeTilesets(message); }) }); toolsMenu.append(resizeTilesets); menu.append(new nw.MenuItem({ label: 'Tools', submenu: toolsMenu })); } }, { key: "addExportMenu", value: function addExportMenu(menu) { var exportMenu = new nw.Menu(); var exportLayersMenu = new nw.Menu(); exportLayersMenu.append(new nw.MenuItem({ label: 'Layer 1', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportSingleLayer(0); }) })); exportLayersMenu.append(new nw.MenuItem({ label: 'Layer 2', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportSingleLayer(1); }) })); exportLayersMenu.append(new nw.MenuItem({ label: 'Layer 3', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportSingleLayer(2); }) })); exportLayersMenu.append(new nw.MenuItem({ label: 'Layer 4', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportSingleLayer(3); }) })); exportMenu.append(new nw.MenuItem({ label: 'Layers', submenu: exportLayersMenu })); var exportRenderedMapMenu = new nw.Menu(); exportRenderedMapMenu.append(new nw.MenuItem({ label: 'Lower Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportLowerTiles(); }) })); exportRenderedMapMenu.append(new nw.MenuItem({ label: 'Upper Tiles', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportUpperTiles(); }) })); exportRenderedMapMenu.append(new nw.MenuItem({ type: 'separator' })); exportRenderedMapMenu.append(new nw.MenuItem({ label: 'Whole Map', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportWholeMap(); }) })); exportMenu.append(new nw.MenuItem({ label: 'Rendered Map', submenu: exportRenderedMapMenu })); var exportEventsMenu = new nw.Menu(); exportEventsMenu.append(new nw.MenuItem({ label: 'Low Events', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportLowEvents(); }) })); exportEventsMenu.append(new nw.MenuItem({ label: 'Normal Events', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportNormalEvents(); }) })); exportEventsMenu.append(new nw.MenuItem({ label: 'High Events', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportHighEvents(); }) })); exportEventsMenu.append(new nw.MenuItem({ type: 'separator' })); exportEventsMenu.append(new nw.MenuItem({ label: 'All Events', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportAllEvents(); }) })); exportMenu.append(new nw.MenuItem({ label: 'Events', submenu: exportEventsMenu })); var exportCollisionsMenu = new nw.Menu(); exportCollisionsMenu.append(new nw.MenuItem({ label: 'Custom Collision', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportCustomCollision(); }) })); exportCollisionsMenu.append(new nw.MenuItem({ label: 'Full Collision', click: this.makeMenuEvent(function () { CycloneMapEditor$1.exportFullCollision(); }) })); exportMenu.append(new nw.MenuItem({ label: 'Collision', submenu: exportCollisionsMenu })); menu.append(new nw.MenuItem({ label: 'Export', submenu: exportMenu })); } }, { key: "addHelpMenu", value: function addHelpMenu(menu) { var helpMenu = new nw.Menu(); helpMenu.append(new nw.MenuItem({ label: 'Plugin Page', key: 'F1', click: this.makeMenuEvent(function () { if (!globalThis.require) { return; } require('nw.gui').Shell.openExternal('https://makerdevs.com/plugin/cyclone-map-editor'); }) })); helpMenu.append(new nw.MenuItem({ label: 'Extra Tilesets Add-on', click: this.makeMenuEvent(function () { if (!globalThis.require) { return; } require('nw.gui').Shell.openExternal('https://hudell.itch.io/cyclone-extra-tilesets'); }) })); helpMenu.append(new nw.MenuItem({ label: 'Magic (Tile Blend) Add-on', click: this.makeMenuEvent(function () { if (!globalThis.require) { return; } require('nw.gui').Shell.openExternal('https://hudell.itch.io/cyclone-magic'); }) })); menu.append(new nw.MenuItem({ label: 'Help', submenu: helpMenu })); } }, { key: "addMenuBar", value: function addMenuBar() { if (!Utils.isNwjs()) { return; } if (this.menu) { return this.refreshMenuVisibility(); } var menu = new nw.Menu({ type: 'menubar' }); this.addFileMenu(menu); this.addEditMenu(menu); this.addMapMenu(menu); this.addModeMenu(menu); this.addLayerMenu(menu); this.addBlendMenu(menu); this.addTilesetMenu(menu); this.addJumpMenu(menu); this.addToolsMenu(menu); this.addExportMenu(menu); this.addHelpMenu(menu); this.menu = menu; this.refreshTilesetMenu(); this.refreshMenuVisibility(); } }, { key: "clearAllData", value: function clearAllData() { changeHistory = []; undoHistory = []; rectangleStartMouseX = 0; rectangleStartMouseY = 0; rectangleStartX = 0; rectangleStartY = 0; rectangleWidth = 0; rectangleHeight = 0; rectangleBackWidth = 0; rectangleBackHeight = 0; customCollisionTable = {}; tileBlendingTable = {}; this.clearSelection(); } }, { key: "toggleTileset", value: function toggleTileset(id) { if ($gameMap._extraTilesetId === id) { $gameMap._extraTilesetId = 0; } else { $gameMap._extraTilesetId = id; } $gameMap.buildTilesetFlags && $gameMap.buildTilesetFlags(); this.refreshTilesetMenu(); this.refreshMapEditor(); if (!this.jumpToTile(Tilemap.TILE_ID_E + 256) && !this.jumpToTile(Tilemap.TILE_ID_E + 512)) { this.jumpToLastTile(); } } }, { key: "applyExtraData", value: function applyExtraData(data) { customCollisionTable = {}; tileBlendingTable = {}; $gameMap._extraTilesetId = 0; var radix = (data === null || data === void 0 ? void 0 : data.radix) || 10; if (data === null || data === void 0 ? void 0 : data.collision) { for (var i = 0; i < data.collision.length; i++) { var col = parseInt(data.collision[i], radix) || 0; if (col) { customCollisionTable[i] = col; } } } if (data === null || data === void 0 ? void 0 : data.magic) { for (var tileId in data.magic) { if (!data.magic[tileId]) { continue; } var line = data.magic[tileId]; var buffer = new ArrayBuffer(line.length); var list = new Uint8Array(buffer); for (var _i = line.indexOf('1'); _i < line.length; _i++) { if (line[_i] !== '0') { list[_i] = Number(line[_i]); } } tileBlendingTable[tileId] = list; } } if (data === null || data === void 0 ? void 0 : data.extraTilesetId) { $gameMap._extraTilesetId = data.extraTilesetId; } this.refreshTilesetMenu(); this.refreshMapEditor(); } }, { key: "dataVersion", value: function dataVersion() { return '02'; } }, { key: "compress", value: function compress(data) { return "v=".concat(this.dataVersion(), ";") + LZString.compressToBase64(data); } }, { key: "decompress", value: function decompress(data) { if (!data.startsWith('v=')) { return LZString.decompress(data); } var idx = data.indexOf(';') + 1; return LZString.decompressFromBase64(data.substring(idx)); } }, { key: "parseExtraData", value: function parseExtraData(note) { var json; try { json = this.decompress(note); } catch (e) { console.error('Failed to decompress data from CycloneMapEditor event.'); console.log(note); console.log(e); return; } var data; try { data = JSON.parse(json); } catch (e) { console.error('Failed to parse extra data.'); console.log(json); console.log(e); return; } this.applyExtraData(data); } }, { key: "loadExtraData", value: function loadExtraData() { // Check if there's any event called CycloneMapEditor var _iterator10 = _createForOfIteratorHelper($dataMap.events), _step10; try { for (_iterator10.s(); !(_step10 = _iterator10.n()).done;) { var event = _step10.value; if (!event) { continue; } if (event.name !== 'CycloneMapEditor') { continue; } this.parseExtraData(event.note); return; } } catch (err) { _iterator10.e(err); } finally { _iterator10.f(); } } }, { key: "getExtraData", value: function getExtraData() { var _window$CycloneMagic; var radix = 36; var collision = new Array($dataMap.width * $dataMap.height * 16); for (var i = 0; i < collision.length; i++) { if (customCollisionTable[i]) { if (customCollisionTable[i] >= radix) { throw new Error('Invalid collision value: ', customCollisionTable[i]); } collision[i] = Number(customCollisionTable[i]).toString(radix); } else { collision[i] = '0'; } } var magic = {}; for (var tileId in tileBlendingTable) { if (!tileBlendingTable[tileId]) { continue; } var line = tileBlendingTable[tileId].join(''); if (!line.includes('1')) { continue; } magic[tileId] = line; } var puzzle = ((_window$CycloneMagic = window.CycloneMagic) === null || _window$CycloneMagic === void 0 ? void 0 : _window$CycloneMagic.puzzleTiles) || undefined; return { radix: radix, collision: collision.join(''), magic: magic, puzzle: puzzle, extraTilesetId: $gameMap._extraTilesetId }; } }, { key: "getExtraDataJson", value: function getExtraDataJson() { return this.compress(JSON.stringify(this.getExtraData(), null, 0)); } }, { key: "saveExtraData", value: function saveExtraData() { var data = this.getExtraDataJson(); // Check if there's any event called CycloneMapEditor var _iterator11 = _createForOfIteratorHelper($dataMap.events), _step11; try { for (_iterator11.s(); !(_step11 = _iterator11.n()).done;) { var event = _step11.value; if (!event) { continue; } if (event.name !== 'CycloneMapEditor') { continue; } event.note = data; return; } // Create a new event then } catch (err) { _iterator11.e(err); } finally { _iterator11.f(); } $dataMap.events.push({ id: $dataMap.events.length, name: 'CycloneMapEditor', note: data, pages: [], x: $dataMap.width, y: $dataMap.height }); } }, { key: "clearSelection", value: function clearSelection() { currentTileId = undefined; tileCols = 1; tileRows = 1; selectedTileList = []; multiLayerSelection = []; } }, { key: "shouldDisplayMenu", value: function shouldDisplayMenu() { if (!editorActive) { return false; } if (!this.isMapEditorScene()) { return false; } return true; } }, { key: "isFullScreen", value: function isFullScreen() { return Graphics._isFullScreen(); } }, { key: "refreshScreenSize", value: function refreshScreenSize() { var _this11 = this; if (this.resizeTimeout) { clearTimeout(this.resizeTimeout); } if (this.isFullScreen()) { return; } this.resizeTimeout = setTimeout(function () { // Adds a second timeout to block the show/hide functionality for a little while _this11.resizeTimeout = setTimeout(function () { _this11.resizeTimeout = false; }, 500); var xDelta = Graphics.width - window.innerWidth; var yDelta = Graphics.height - window.innerHeight; if (xDelta !== 0 || yDelta !== 0) { window.moveBy(-xDelta / 2, -yDelta / 2); window.resizeBy(xDelta, yDelta); } }, 20); } }, { key: "enablePluginOptions", value: function enablePluginOptions() { if (this.blendButton) { this.blendButton.enabled = Boolean(window.CycloneMagic); } if (this.puzzleMenu) { this.puzzleMenu.enabled = Boolean(window.CycloneMagic); } if (this._extraTilesetMenuItem) { this._extraTilesetMenuItem.enabled = Boolean(window.CycloneExtraTilesets); } if (this._jumpToExtraBMenu) { this._jumpToExtraBMenu.enabled = Boolean(window.CycloneExtraTilesets); } if (this._jumpToExtraCMenu) { this._jumpToExtraCMenu.enabled = Boolean(window.CycloneExtraTilesets); } if (this._jumpToExtraDMenu) { this._jumpToExtraDMenu.enabled = Boolean(window.CycloneExtraTilesets); } } }, { key: "refreshMenuVisibility", value: function refreshMenuVisibility() { if (!Utils.isNwjs()) { return; } var display = this.shouldDisplayMenu(); var win = nw.Window.get(); this.enablePluginOptions(); if (display && win.menu === this.menu) { return; } if (display) { win.menu = this.menu; } else { win.menu = null; } this.refreshScreenSize(); } }, { key: "logImage", value: function logImage(canvas, text) { _logImage(canvas, text); } }, { key: "isTabValid", value: function isTabValid(tab) { var tileset = $gameMap.tileset(); if (!tileset) { return false; } var names = tileset.tilesetNames; if (tab === 'A') { return Boolean(names[0] || names[1] || names[2] || names[3] || names[4]); } var tilesetIndex = tabs.indexOf(tab) + 4; return Boolean(names[tilesetIndex]); } }, { key: "validTabs", value: function validTabs() { var _this12 = this; return tabs.filter(function (tab) { return _this12.isTabValid(tab); }); } }, { key: "areRegionsVisible", value: function areRegionsVisible() { return layerVisibility[5]; } }, { key: "isLayerVisible", value: function isLayerVisible(index) { if (index >= 8 && index <= 10) { return currentLayer === index; } if (index === 7) { return true; } return layerVisibility[index]; } }, { key: "selectPreviousTab", value: function selectPreviousTab() { var validTabs = this.validTabs(); var oldIndex = validTabs.indexOf(currentTab).clamp(0, validTabs.length - 1); var index = oldIndex === 0 ? validTabs.length - 1 : oldIndex - 1; this.changeCurrentTab(validTabs[index % validTabs.length]); } }, { key: "selectNextTab", value: function selectNextTab() { var validTabs = this.validTabs(); var oldIndex = validTabs.indexOf(currentTab).clamp(0, validTabs.length - 1); var index = oldIndex + 1; this.changeCurrentTab(validTabs[index % validTabs.length]); } }, { key: "onKeyDown", value: function onKeyDown(event) { if (!editorActive) { return; } // const scene = SceneManager._scene; if (!this.isMapEditorScene()) { return; } if (event.keyCode === 8 || event.keyCode === 46) { this.eraserButton(); return; } if (event.keyCode === 33) { this.selectPreviousTab(); return; } if (event.keyCode === 34) { this.selectNextTab(); return; } } }, { key: "checkNumKeys", value: function checkNumKeys(code) { switch (code) { case 'Numpad0': this.changeCurrentLayer(7); break; case 'Numpad1': this.changeCurrentLayer(0); break; case 'Numpad2': this.changeCurrentLayer(1); break; case 'Numpad3': this.changeCurrentLayer(2); break; case 'Numpad4': this.changeCurrentLayer(3); break; case 'Numpad5': this.changeCurrentLayer(4); break; case 'Numpad6': this.changeCurrentLayer(5); break; case 'Numpad7': this.changeCurrentLayer(6); break; case 'Numpad8': this.changeCurrentLayer(8); break; case 'Numpad9': this.changeCurrentLayer(9); break; } } }, { key: "checkLayerKeys", value: function checkLayerKeys(key) { switch (key) { case '0': this.changeCurrentLayer(7); break; case '1': this.changeCurrentLayer(0); break; case '2': this.changeCurrentLayer(1); break; case '3': this.changeCurrentLayer(2); break; case '4': this.changeCurrentLayer(3); break; case '5': this.changeCurrentLayer(4); break; case '6': this.changeCurrentLayer(5); break; case '8': this.changeCurrentLayer(8); break; case '9': this.changeCurrentLayer(9); break; } } }, { key: "checkScrollKeys", value: function checkScrollKeys(key) { switch (key.toLowerCase()) { case 'w': $gameMap.scrollUp(3); break; case 'a': $gameMap.scrollLeft(3); break; case 's': $gameMap.scrollDown(3); break; case 'd': $gameMap.scrollRight(3); break; } } }, { key: "sceneToReload", value: function sceneToReload() { return Scene_Map; } }, { key: "loadMapFile", value: function loadMapFile() { var _this13 = this; SceneManager._scene._mapEditorCommands.hide(); delete mapCaches[$gameMap._mapId]; var fileName = "Map".concat($gameMap._mapId.padZero(3), ".json"); var xhr = new XMLHttpRequest(); var url = "data/".concat(fileName); xhr.open('GET', url); xhr.overrideMimeType('application/json'); xhr.onload = function () { try { var data = JSON.parse(xhr.responseText); // eslint-disable-next-line no-global-assign $dataMap = data; SoundManager.playLoad(); SceneManager["goto"](_this13.sceneToReload()); } catch (e) { alert('Failed to parse map data.'); SceneManager._scene.refreshMapEditorWindows(); } }; xhr.onerror = function () { alert('Failed to load map file from disk.'); SceneManager._scene.refreshMapEditorWindows(); }; xhr.send(); } }, { key: "downloadMapshot", value: function downloadMapshot(bitmap, fileName) { var imageType = 'png'; var imageQuality = 1; var urlData = bitmap.canvas.toDataURL(imageType, imageQuality); var strippedData = urlData.replace(/^data:image\/png;base64,/, ''); var data = atob(strippedData); var buffer = new ArrayBuffer(data.length); var view = new Uint8Array(buffer); for (var i = 0; i < data.length; i++) { view[i] = data.charCodeAt(i) & 0xff; } var blob = new Blob([buffer], { type: 'application/octet-stream' }); var url = URL.createObjectURL(blob); var iframe = document.getElementsByName('image_download')[0]; if (!iframe) { iframe = document.createElement('iframe'); iframe.setAttribute('name', 'image_download'); iframe.style.display = 'none'; document.body.appendChild(iframe); } var element = document.createElement('a'); element.setAttribute('href', url); element.setAttribute('download', fileName + '.png'); element.setAttribute('target', 'image_download'); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } }, { key: "resizeTilesets", value: function resizeTilesets(message) { var tileset = $dataTilesets[$dataMap.tilesetId]; if (!tileset) { return alert('Tileset data not found.'); } if (!Utils.isNwjs()) { return alert('This feature can only be used on a computer with a non web-version.'); } var fileNames = tileset.tilesetNames; var existingFiles = []; var fs = require('fs'); var _iterator12 = _createForOfIteratorHelper(fileNames), _step12; try { for (_iterator12.s(); !(_step12 = _iterator12.n()).done;) { var fileName = _step12.value; if (!fileName) { continue; } if (fs.existsSync("img/tilesets/".concat(fileName, ".png"))) { existingFiles.push(fileName); } } } catch (err) { _iterator12.e(err); } finally { _iterator12.f(); } if (existingFiles.length) { var overwrittenFilesMessage = "Files that will be replaced: ".concat(existingFiles.join(', ')); var newMessage = "".concat(message, "\n").concat(overwrittenFilesMessage); if (!confirm(newMessage)) { return; } } this.doResizeTiles(fileNames); } }, { key: "doResizeTiles", value: function doResizeTiles(fileNames) { var width = $gameMap.tileWidth(); var height = $gameMap.tileHeight(); var fs = require('fs'); var _iterator13 = _createForOfIteratorHelper(fileNames), _step13; try { for (_iterator13.s(); !(_step13 = _iterator13.n()).done;) { var fileName = _step13.value; if (!fileName) { continue; } var bitmap = ImageManager.loadTileset(fileName); if (!bitmap) { continue; } var newWidth = Math.floor(bitmap.width / width * 48); var newHeight = Math.floor(bitmap.height / height * 48); var newBitmap = new Bitmap(newWidth, newHeight); newBitmap.blt(bitmap, 0, 0, bitmap.width, bitmap.height, 0, 0, newWidth, newHeight); var urlData = newBitmap.canvas.toDataURL('image/png', 70); var base64Data = urlData.replace(/^data:image\/png;base64,/, ''); fs.writeFileSync("img/tilesets/".concat(fileName, ".png"), base64Data, 'base64'); } } catch (err) { _iterator13.e(err); } finally { _iterator13.f(); } } }, { key: "exportSingleLayer", value: function exportSingleLayer(layerIndex) { var tilemap = new MapshotTileMap(); tilemap.drawSingleLayer(layerIndex); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Layer").concat(layerIndex + 1)); } }, { key: "exportLowerTiles", value: function exportLowerTiles() { var tilemap = new MapshotTileMap(); tilemap.drawLowerTiles(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Lower")); } }, { key: "exportUpperTiles", value: function exportUpperTiles() { var tilemap = new MapshotTileMap(); tilemap.drawUpperTiles(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Upper")); } }, { key: "exportWholeMap", value: function exportWholeMap() { var tilemap = new MapshotTileMap(); tilemap.drawLowerTiles(); tilemap.drawUpperTiles(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3))); } }, { key: "exportLowEvents", value: function exportLowEvents() { var tilemap = new MapshotTileMap(); tilemap.drawEvents(0); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Events_0")); } }, { key: "exportNormalEvents", value: function exportNormalEvents() { var tilemap = new MapshotTileMap(); tilemap.drawEvents(1); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Events_1")); } }, { key: "exportHighEvents", value: function exportHighEvents() { var tilemap = new MapshotTileMap(); tilemap.drawEvents(2); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Events_2")); } }, { key: "exportAllEvents", value: function exportAllEvents() { var tilemap = new MapshotTileMap(); tilemap.drawEvents(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Events")); } }, { key: "exportCustomCollision", value: function exportCustomCollision() { var tilemap = new MapshotTileMap(); tilemap.drawCustomCollision(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_Collision")); } }, { key: "exportFullCollision", value: function exportFullCollision() { var tilemap = new MapshotTileMap(); tilemap.drawDefaultCollision(); tilemap.drawCustomCollision(); this.downloadMapshot(tilemap, "Map".concat($gameMap._mapId.padZero(3), "_FullCollision")); } }, { key: "undoButton", value: function undoButton() { if (!this.isMapEditorScene()) { return; } if (changeHistory.length) { this.undoLastChange(); } } }, { key: "redoButton", value: function redoButton() { if (!this.isMapEditorScene()) { return; } if (undoHistory.length) { this.redoLastUndoneChange(); } } }, { key: "removeAllBlendsButton", value: function removeAllBlendsButton() { if (confirm('Are you sure you want to remove all blend effects on this map?')) { this.removeAllBlends(); } } }, { key: "optimizeBlendsButton", value: function optimizeBlendsButton() { if (confirm('This option will remove the blend from tiles that are completely hidden by the effect and change the tile itself to transparent. Optimize now?')) { this.optimizeBlends(); } } // eslint-disable-next-line complexity }, { key: "getCollisionSymbol", value: function getCollisionSymbol(x, y) { var downCollision = !$gameMap.isPassable(x, y, 2); var leftCollision = !$gameMap.isPassable(x, y, 4); var rightCollision = !$gameMap.isPassable(x, y, 6); var upCollision = !$gameMap.isPassable(x, y, 8); if (downCollision && leftCollision && rightCollision && upCollision) { return 'X'; } if (!downCollision && !leftCollision && !rightCollision && !downCollision) { return 'O'; } var collisions = ''; if (downCollision) { collisions += 'd:X '; } else { collisions += 'd:O '; } if (leftCollision) { collisions += 'l:X '; } else { collisions += 'l:O '; } if (rightCollision) { collisions += 'r:X '; } else { collisions += 'r:O '; } if (upCollision) { collisions += 'u:X '; } else { collisions += 'u:O '; } return collisions; } // eslint-disable-next-line complexity }, { key: "updateStatus", value: function updateStatus() { var _ref11 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, tileId = _ref11.tileId, mapX = _ref11.mapX, mapY = _ref11.mapY, tile1 = _ref11.tile1, tile2 = _ref11.tile2, tile3 = _ref11.tile3, tile4 = _ref11.tile4; var oldTileId = statusTileId; var oldX = statusMapX; var oldY = statusMapY; var oldTile1 = statusTile1; var oldTile2 = statusTile2; var oldTile3 = statusTile3; var oldTile4 = statusTile4; statusTileId = tileId !== null && tileId !== void 0 ? tileId : statusTileId; statusMapX = mapX !== null && mapX !== void 0 ? mapX : statusMapX; statusMapY = mapY !== null && mapY !== void 0 ? mapY : statusMapY; statusTile1 = tile1 !== null && tile1 !== void 0 ? tile1 : statusTile1; statusTile2 = tile2 !== null && tile2 !== void 0 ? tile2 : statusTile2; statusTile3 = tile3 !== null && tile3 !== void 0 ? tile3 : statusTile3; statusTile4 = tile4 !== null && tile4 !== void 0 ? tile4 : statusTile4; var changedPos = oldX !== statusMapX || oldY !== statusMapY; if (changedPos) { statusRegion = $gameMap.regionId(statusMapX, statusMapY); statusTag = $gameMap.terrainTag(statusMapX, statusMapY); statusBush = $gameMap.isBush(statusMapX, statusMapY); statusCounter = $gameMap.isCounter(statusMapX, statusMapY); statusDamage = $gameMap.isDamageFloor(statusMapX, statusMapY); statusLadder = $gameMap.isLadder(statusMapX, statusMapY); statusCollision = this.getCollisionSymbol(statusMapX, statusMapY); } var changedTile = oldTile1 !== statusTile1 || oldTile2 !== statusTile2 || oldTile3 !== statusTile3 || oldTile4 !== statusTile4; var changed = changedTile || oldTileId !== statusTileId || changedPos; if (!changed) { return; } if (this.isMapEditorScene()) { SceneManager._scene._mapEditorStatus.refresh(); } } }, { key: "showGridButton", value: function showGridButton() { if (!this.isMapEditorScene()) { return; } showGrid = !showGrid; this.showGridButton.checked = showGrid; SceneManager._scene._mapEditorGrid.refresh(); } }, { key: "selectHigherLayer", value: function selectHigherLayer(x, y) { if (currentLayer === Layers.collisions) { return; } for (var z = 3; z >= 0; z--) { var tileIndex = this.tileIndex(x, y, z); var tileId = $dataMap.data[tileIndex]; if (tileId) { this.changeCurrentLayer(z); return; } } } }, { key: "updateCurrentTool", value: function updateCurrentTool() { rectangleWidth = 0; rectangleHeight = 0; rectangleBackWidth = 0; rectangleBackHeight = 0; rectangleStartX = 0; rectangleStartY = 0; rectangleStartMouseX = 0; rectangleStartMouseY = 0; if (Utils.isNwjs()) { this.pencilMenu.checked = currentTool === Tools.pencil; this.rectangleMenu.checked = currentTool === Tools.rectangle; this.fillMenu.checked = currentTool === Tools.fill; this.puzzleMenu.checked = puzzleMode; this.eraserMenu.checked = currentTool === Tools.eraser; this.tilePassageMenu.checked = currentTool === Tools.passage; this.tilePassage4Menu.checked = currentTool === Tools.passage4; this.tileLadderMenu.checked = currentTool === Tools.ladder; this.tileBushMenu.checked = currentTool === Tools.bush; this.tileCounterMenu.checked = currentTool === Tools.counter; this.tileDamageMenu.checked = currentTool === Tools.damage; this.tileTerrainMenu.checked = currentTool === Tools.terrain; } this.refreshMapEditor(); } }, { key: "pencilButton", value: function pencilButton() { this.toolButton(Tools.pencil); } }, { key: "rectangleButton", value: function rectangleButton() { this.toolButton(Tools.rectangle); } }, { key: "fillButton", value: function fillButton() { this.toolButton(Tools.fill); } }, { key: "eraserButton", value: function eraserButton() { this.toolButton(Tools.eraser); } }, { key: "puzzleButton", value: function puzzleButton() { if (!this.isMapEditorScene()) { return; } puzzleMode = !puzzleMode; if (puzzleMode) { if (currentTool !== Tools.eraser) { currentTool = Tools.pencil; } if (CycloneMapEditor$1.currentLayer !== 1) { this.changeCurrentLayer(1); } } this.clearSelection(); this.updateCurrentTool(); } }, { key: "toolButton", value: function toolButton(toolType) { if (!this.isMapEditorScene()) { return; } if (puzzleMode && ![Tools.pencil, Tools.eraser].includes(toolType)) { return; } currentTool = toolType; if ([Tools.pencil, Tools.rectangle].includes(toolType)) { lastDrawingTool = toolType; } this.updateCurrentTool(); } }, { key: "_doWebSave", value: function _doWebSave(json, fileName) { var element = document.createElement('a'); element.setAttribute('href', "data:text/plain;charset=utf-8,".concat(encodeURIComponent(json))); element.setAttribute('download', fileName); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } }, { key: "_doLocalSave", value: function _doLocalSave(json, fileName) { var fs = require('fs'); var path = require('path'); var projectFolder = path.dirname(process.mainModule.filename); var dataFolder = path.join(projectFolder, 'data'); var filePath = path.join(dataFolder, fileName); fs.writeFileSync(filePath, json); } }, { key: "_makeMapJson", value: function _makeMapJson() { var _map$note; var map = _objectSpread(_objectSpread({}, $dataMap), {}, { data: _toConsumableArray($dataMap.data) }); var size = map.width * map.height; var extraTiles = new Array(size * 4); var anyExtraTile = false; for (var i = 0; i < extraTiles.length; i++) { if (map.data[i] >= Tilemap.TILE_ID_E + 256 && map.data[i] < Tilemap.TILE_ID_A5) { extraTiles[i] = map.data[i]; map.data[i] = 0; anyExtraTile = true; } else if (map.data[i] >= Tilemap.TILE_ID_A5 + 256 && map.data[i] < Tilemap.TILE_ID_A1) { extraTiles[i] = map.data[i]; map.data[i] = 0; anyExtraTile = true; } else { extraTiles[i] = 0; } } var extraTilesTag = ''; if (anyExtraTile) { var compressed = LZString.compressToBase64(JSON.stringify(extraTiles, null, 0)); extraTilesTag = "<CycloneExtraTiles>".concat(compressed, "</CycloneExtraTiles>"); } if ((_map$note = map.note) === null || _map$note === void 0 ? void 0 : _map$note.includes('<CycloneExtraTiles>')) { map.note = map.note.replace(/<CycloneExtraTiles>.*<\/CycloneExtraTiles>/i, extraTilesTag); } else { var _map$note2; map.note = "".concat((_map$note2 = map.note) !== null && _map$note2 !== void 0 ? _map$note2 : '', "\n").concat(extraTilesTag); } return JSON.stringify(map, null, 0); } }, { key: "_doSave", value: function _doSave() { this.saveExtraData(); var fileName = "Map".concat($gameMap._mapId.padZero(3), ".json"); var json = this._makeMapJson(); if (Utils.isNwjs()) { this._doLocalSave(json, fileName); } else { this._doWebSave(json, fileName); } SoundManager.playSave(); } }, { key: "saveButton", value: function saveButton() { if (!this.isMapEditorScene()) { return; } if (!confirm('Are you sure you want to SAVE the map file?')) { SceneManager._scene.refreshMapEditorWindows(); return; } SceneManager._scene._mapEditorCommands.hide(); this._doSave(); SceneManager._scene.refreshMapEditorWindows(); } }, { key: "reloadButton", value: function reloadButton() { if (!this.isMapEditorScene()) { return; } if (!confirm('Are you sure you want to RELOAD the map file?')) { SceneManager._scene.refreshMapEditorWindows(); return; } this.clearAllData(); this.loadMapFile(); } }, { key: "onKeyPress", value: function onKeyPress(event) { if (editorActive) { if (!Utils.isNwjs()) { this.checkScrollKeys(event.key); } } } }, { key: "checkWebShortcuts", value: function checkWebShortcuts(key) { switch (key) { case 'e': return this.eraserButton(); case 'r': return this.rectangleButton(); case 'p': return this.pencilButton(); case 'f': return this.fillButton(); } } }, { key: "checkControlKeys", value: function checkControlKeys(code) { switch (code) { case 'KeyZ': this.undoButton(); return true; case 'KeyY': this.redoButton(); return true; case 'KeyS': this.saveButton(); return true; case 'KeyR': this.reloadButton(); return true; case 'KeyG': this.showGridButton(); return true; } } }, { key: "onKeyUp", value: function onKeyUp(event) { if (!Utils.isNwjs()) { if (Input.isPressed('shift') || Input.isPressed('control')) { if (this.checkControlKeys(event.code)) { event.preventDefault(); } return; } this.checkWebShortcuts(event.key); this.checkLayerKeys(event.key); } if (event.key === 'h') { this.toggleMapEditor(); return; } this.checkNumKeys(event.code); } }, { key: "toggleMapEditor", value: function toggleMapEditor() { if (this.resizeTimeout) { return; } var scene = SceneManager._scene; if (!this.isMapEditorScene()) { return; } scene.toggleMapEditor(); } }, { key: "refreshMapEditor", value: function refreshMapEditor() { var scene = SceneManager._scene; if (!this.isMapEditorScene()) { return; } scene.refreshMapEditorWindows(); } }, { key: "getTileIdTilesetIndex", value: function getTileIdTilesetIndex(tileId) { if (tileId !== 0) { if (!Tilemap.isVisibleTile(tileId)) { return -1; } } return getTilesetIndex(tileId); } }, { key: "getTilesetName", value: function getTilesetName(tileId) { var tileset = $gameMap.tileset(); if (!tileset) { return; } var tilesetIndex = this.getTileIdTilesetIndex(tileId); if (tilesetIndex < 0) { return; } if (tilesetIndex < tileset.tilesetNames.length) { return tileset.tilesetNames[tilesetIndex]; } if (!window.CycloneExtraTilesets) { return; } var extraTileset = $gameMap.extraTileset(); if (!extraTileset) { return; } var extraIndex = tilesetIndex - 9; var newIndex = extraIndex + 5; return extraTileset.tilesetNames[newIndex]; } }, { key: "loadTilesetBitmap", value: function loadTilesetBitmap(tileId) { var realFileName = this.getTilesetName(tileId); if (realFileName) { return ImageManager.loadTileset(realFileName); } } }, { key: "deselectShadowOrRegion", value: function deselectShadowOrRegion(newLayerIndex) { // coming from or to shadows/regions, then de-select the current index if (currentLayer === 4 || currentLayer === 5 || newLayerIndex === 4 || newLayerIndex === 5) { this.clearSelection(); } } }, { key: "changeCurrentLayer", value: function changeCurrentLayer(newIndex) { if (newIndex >= layerVisibility.length) { return; } if (newIndex !== 1 && puzzleMode) { puzzleMode = false; this.updateCurrentTool(); } this.deselectShadowOrRegion(newIndex); currentLayer = newIndex; if (Utils.isNwjs()) { this.layer1Button.checked = newIndex === 0; this.layer2Button.checked = newIndex === 1; this.layer3Button.checked = newIndex === 2; this.layer4Button.checked = newIndex === 3; this.shadowsButton.checked = newIndex === 4; this.regionsButton.checked = newIndex === 5; this.eventsButton.checked = newIndex === 6; this.autoLayerButton.checked = newIndex === 7; this.collisionsButton.checked = newIndex === 8; this.tagsButton.checked = newIndex === 9; this.blendButton.checked = newIndex === 10; } if (this.isMapEditorScene()) { SceneManager._scene._mapEditorLayerListWindow.refresh(); SceneManager._scene._mapEditorWindow.refresh(); SceneManager._scene._mapEditorStatus.refresh(); SceneManager._scene._mapEditorGrid.refresh(); SceneManager._scene._spriteset._mapEditorCursor.updateDrawing(); } } }, { key: "changeCurrentTab", value: function changeCurrentTab(tabLetter) { currentTab = tabLetter; this.refreshMapEditor(); } }, { key: "tileIndex", value: function tileIndex(x, y, z) { return (z * $gameMap.height() + y % $gameMap.height()) * $gameMap.width() + x % $gameMap.width(); } }, { key: "indexPositionX", value: function indexPositionX(index, z) { var y = this.indexPositionY(index, z); return index - this.tileIndex(0, y, z); } }, { key: "indexPositionY", value: function indexPositionY(index, z) { return Math.floor(index / $gameMap.width() - z * $gameMap.height()); } }, { key: "getCurrentTileAtPosition", value: function getCurrentTileAtPosition(x, y, z) { var _$dataMap$data$tileIn; var skipPreview = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; if (x < 0 || y < 0 || x >= $gameMap.width() || y >= $gameMap.height()) { return 0; } var tileIndex = this.tileIndex(x, y, z); if (!skipPreview) { if (previewChanges[tileIndex] !== undefined) { return previewChanges[tileIndex]; } } return (_$dataMap$data$tileIn = $dataMap.data[tileIndex]) !== null && _$dataMap$data$tileIn !== void 0 ? _$dataMap$data$tileIn : 0; } }, { key: "isSameKindTile", value: function isSameKindTile(tileId, x, y, z) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; return Tilemap.isSameKindTile(tileId, this.getCurrentTileAtPosition(x, y, z, skipPreview)); } }, { key: "getWallColumnTypeForPosition", value: function getWallColumnTypeForPosition(x, y, z, tileId) { var _this14 = this; var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; // wall auto tiles need the left and right columns to have the same amount of rows for it to match var hasLeftColumn = true; var hasRightColumn = true; var compareWallAutoTileLine = function compareWallAutoTileLine(newY, sameCenter) { var leftTileId = _this14.getCurrentTileAtPosition(x - 1, newY, z, skipPreview); var rightTileId = _this14.getCurrentTileAtPosition(x + 1, newY, z, skipPreview); if (sameCenter) { if (!Tilemap.isSameKindTile(tileId, leftTileId)) { hasLeftColumn = false; } if (!Tilemap.isSameKindTile(tileId, rightTileId)) { hasRightColumn = false; } } else { if (Tilemap.isSameKindTile(tileId, leftTileId)) { hasLeftColumn = false; } if (Tilemap.isSameKindTile(tileId, rightTileId)) { hasRightColumn = false; } } }; for (var newY = y; y < $gameMap.height(); y++) { var centerTileId = this.getCurrentTileAtPosition(x, newY, z, skipPreview); var sameCenter = Tilemap.isSameKindTile(tileId, centerTileId); compareWallAutoTileLine(newY, sameCenter); if (!sameCenter) { break; } } for (var _newY = y - 1; y >= 0; y--) { var _centerTileId = this.getCurrentTileAtPosition(x, _newY, z, skipPreview); var _sameCenter = Tilemap.isSameKindTile(tileId, _centerTileId); compareWallAutoTileLine(_newY, _sameCenter); if (!_sameCenter) { break; } } if (hasLeftColumn) { if (hasRightColumn) { return 1; } return 2; } if (hasRightColumn) { return 0; } return 3; } }, { key: "getWaterfallShapeForPosition", value: function getWaterfallShapeForPosition(x, y, z, tileId) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; var left = this.isSameKindTile(tileId, x - 1, y, z, skipPreview); var right = this.isSameKindTile(tileId, x + 1, y, z, skipPreview); if (left && right) { return 0; } if (left) { return 1; } if (right) { return 2; } return 3; } }, { key: "getWallShapeForPosition", value: function getWallShapeForPosition(x, y, z, tileId) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; var columnType = this.getWallColumnTypeForPosition(x, y, z, tileId, skipPreview); var shape = 0; var above = this.isSameKindTile(tileId, x, y - 1, z, skipPreview); var below = this.isSameKindTile(tileId, x, y + 1, z, skipPreview); if (above && below) { shape = 0; } else if (above) { shape = 8; } else if (below) { shape = 2; } else { shape = 10; } switch (columnType) { case 0: shape += 1; break; case 2: shape += 4; break; case 3: shape += 5; break; } return shape; } }, { key: "getShapeForConfiguration", value: function getShapeForConfiguration(configuration) { for (var shape = 0; shape < autoTileShapeTable.length; shape++) { var shapeData = autoTileShapeTable[shape]; var valid = true; for (var i = 0; i < configuration.length; i++) { var config = shapeData[i]; if (config === true) { if (!configuration[i]) { valid = false; break; } } else if (config === false) { if (configuration[i]) { valid = false; break; } } } if (valid) { return shape; } } return 46; } }, { key: "isAutotileMatch", value: function isAutotileMatch(tileId, x, y, z) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; if (!$gameMap.isValid(x, y)) { return true; } var otherTileId = this.getCurrentTileAtPosition(x, y, z, skipPreview); if (Tilemap.isSameKindTile(tileId, otherTileId)) { return true; } var specialTiles = [5, 7, 13]; var leftKind = Tilemap.getAutotileKind(tileId); var rightKind = Tilemap.getAutotileKind(otherTileId); var leftSpecial = specialTiles.includes(leftKind); var rightSpecial = specialTiles.includes(rightKind); if (leftSpecial !== rightSpecial) { return true; } return false; } }, { key: "getAutoTileShapeForPosition", value: function getAutoTileShapeForPosition(x, y, z, tileId) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; if (Tilemap.isWallSideTile(tileId) || Tilemap.isRoofTile(tileId)) { return this.getWallShapeForPosition(x, y, z, tileId, skipPreview); } if (Tilemap.isWaterfallTile(tileId)) { return this.getWaterfallShapeForPosition(x, y, z, tileId, skipPreview); } var a = this.isAutotileMatch(tileId, x - 1, y - 1, z, skipPreview); var b = this.isAutotileMatch(tileId, x, y - 1, z, skipPreview); var c = this.isAutotileMatch(tileId, x + 1, y - 1, z, skipPreview); var d = this.isAutotileMatch(tileId, x - 1, y, z, skipPreview); var e = this.isAutotileMatch(tileId, x + 1, y, z, skipPreview); var f = this.isAutotileMatch(tileId, x - 1, y + 1, z, skipPreview); var g = this.isAutotileMatch(tileId, x, y + 1, z, skipPreview); var h = this.isAutotileMatch(tileId, x + 1, y + 1, z, skipPreview); var config = [a, b, c, d, e, f, g, h]; return this.getShapeForConfiguration(config); } }, { key: "isShiftMapping", value: function isShiftMapping() { if (Input.isPressed('shift')) { return true; } if (SceneManager._scene._mapEditorWindow._manualTileSelected !== undefined) { return true; } return false; } }, { key: "changeAutoTileShapeForPosition", value: function changeAutoTileShapeForPosition(x, y, z, tileId) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; if (z >= 4 || this.isShiftMapping()) { return tileId; } var shape = this.getAutoTileShapeForPosition(x, y, z, tileId, skipPreview); return Tilemap.TILE_ID_A1 + Math.floor((tileId - Tilemap.TILE_ID_A1) / 48) * 48 + shape; } }, { key: "resetTileShape", value: function resetTileShape(x, y, z) { var previewOnly = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; if (x < 0 || x >= $gameMap.width()) { return; } if (y < 0 || y >= $gameMap.height()) { return; } var tileId = this.getCurrentTileAtPosition(x, y, z, !previewOnly); if (Tilemap.isAutotile(tileId)) { var effectiveTileId = this.changeAutoTileShapeForPosition(x, y, z, tileId, !previewOnly); if (tileId !== effectiveTileId) { this.setMapTile(x, y, z, effectiveTileId, false, previewOnly); } } } }, { key: "resetCurrentChange", value: function resetCurrentChange() { currentChange = { tiles: {}, collision: {}, blend: {}, puzzle: {} }; } }, { key: "undoLastChange", value: function undoLastChange() { if (this.changingTileProps) { return; } if (changeHistory.length === 0) { SoundManager.playBuzzer(); return; } var lastChange = changeHistory.pop(); this.resetCurrentChange(); var size = $gameMap.tileWidth() * $gameMap.tileHeight(); for (var tileIndex in lastChange.tiles) { currentChange.tiles[tileIndex] = $dataMap.data[tileIndex]; $dataMap.data[tileIndex] = lastChange.tiles[tileIndex]; } for (var _tileIndex in lastChange.puzzle) { currentChange.puzzle[_tileIndex] = CycloneMagic.puzzleTiles[_tileIndex]; CycloneMagic.puzzleTiles[_tileIndex] = lastChange.puzzle[_tileIndex]; } for (var _tileIndex2 in lastChange.collision) { currentChange.collision[_tileIndex2] = customCollisionTable[_tileIndex2]; customCollisionTable[_tileIndex2] = lastChange.collision[_tileIndex2]; } for (var _tileIndex3 in lastChange.blend) { if (!tileBlendingTable[_tileIndex3]) { var buffer = new ArrayBuffer(size); tileBlendingTable[_tileIndex3] = new Int8Array(buffer); } var tilePixels = tileBlendingTable[_tileIndex3]; currentChange.blend[_tileIndex3] = {}; for (var pixelIndex in lastChange.blend[_tileIndex3]) { currentChange.blend[_tileIndex3][pixelIndex] = tilePixels[pixelIndex]; tilePixels[pixelIndex] = lastChange.blend[_tileIndex3][pixelIndex]; } } undoHistory.push(currentChange); currentChange = false; SceneManager._scene._mapEditorCommands.redraw(); SceneManager._scene._mapEditorGrid.refresh(); mapCaches[$gameMap._mapId] = $dataMap; this.refreshTilemap(); saveExtraData(true); } }, { key: "redoLastUndoneChange", value: function redoLastUndoneChange() { if (this.changingTileProps) { return; } if (undoHistory.length === 0) { SoundManager.playBuzzer(); return; } var lastChange = undoHistory.pop(); var size = $gameMap.tileWidth() * $gameMap.tileHeight(); this.resetCurrentChange(); var needsSaving = false; for (var tileIndex in lastChange.tiles) { currentChange.tiles[tileIndex] = $dataMap.data[tileIndex]; $dataMap.data[tileIndex] = lastChange.tiles[tileIndex]; } for (var _tileIndex4 in lastChange.puzzle) { currentChange.puzzle[_tileIndex4] = CycloneMagic.puzzleTiles[_tileIndex4]; CycloneMagic.puzzleTiles[_tileIndex4] = lastChange.puzzle[_tileIndex4]; } for (var _tileIndex5 in lastChange.collision) { currentChange.collision[_tileIndex5] = customCollisionTable[_tileIndex5]; customCollisionTable[_tileIndex5] = lastChange.collision[_tileIndex5]; needsSaving = true; } for (var _tileIndex6 in lastChange.blend) { if (!tileBlendingTable[_tileIndex6]) { var buffer = new ArrayBuffer(size); tileBlendingTable[_tileIndex6] = new Int8Array(buffer); } var tilePixels = tileBlendingTable[_tileIndex6]; currentChange.blend[_tileIndex6] = {}; for (var pixelIndex in lastChange.blend[_tileIndex6]) { currentChange.blend[_tileIndex6][pixelIndex] = tilePixels[pixelIndex]; tilePixels[pixelIndex] = lastChange.blend[_tileIndex6][pixelIndex]; needsSaving = true; } } this.logChange(false); if (needsSaving) { saveExtraData(true); } this.refreshTilemap(); } }, { key: "getCurrentLayerChangeType", value: function getCurrentLayerChangeType() { switch (currentLayer) { case Layers.collisions: return 'collision'; case Layers.blend: return 'blend'; default: return 'tile'; } } }, { key: "logChange", value: function logChange() { var clearUndo = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; if (!currentChange) { return; } var hasTiles = Object.keys(currentChange.tiles).length > 0; var hasBlend = Object.keys(currentChange.blend).length > 0; var hasCollision = Object.keys(currentChange.collision).length > 0; var hasPuzzle = Object.keys(currentChange.puzzle).length > 0; var hasChanges = hasTiles || hasBlend || hasCollision || hasPuzzle; if (hasChanges) { changeHistory.push(currentChange); if (clearUndo) { undoHistory = []; } } currentChange = false; while (changeHistory.length > 300) { changeHistory.shift(); } SceneManager._scene._mapEditorCommands.redraw(); SceneManager._scene._mapEditorGrid.refresh(); mapCaches[$gameMap._mapId] = $dataMap; fullRefresh(); } }, { key: "maybeUpdateTileNeighbors", value: function maybeUpdateTileNeighbors(x, y, z) { var expectedUpdate = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; var previewOnly = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; if (this.isShiftMapping()) { return; } if (!expectedUpdate) { return; } this.resetTileShape(x - 1, y - 1, z, previewOnly); this.resetTileShape(x, y - 1, z, previewOnly); this.resetTileShape(x + 1, y - 1, z, previewOnly); this.resetTileShape(x - 1, y, z, previewOnly); this.resetTileShape(x + 1, y, z, previewOnly); this.resetTileShape(x - 1, y + 1, z, previewOnly); this.resetTileShape(x, y + 1, z, previewOnly); this.resetTileShape(x + 1, y + 1, z, previewOnly); } }, { key: "getDefaultLayerForTileId", value: function getDefaultLayerForTileId(tileId) { if (!Tilemap.isAutotile(tileId)) { return 3; } if (tileId >= Tilemap.TILE_ID_A3) { return 0; } var kind = Tilemap.getAutotileKind(tileId); if (highLayerAutotiles.includes(kind)) { return 1; } return 0; } }, { key: "getItemsToChange", value: function getItemsToChange(x, y, z, tileId) { var skipPreview = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; var updateHigherLayers = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : true; if (z !== 7) { return [{ x: x, y: y, z: z, tileId: tileId }]; } // When using automatic mode, we may need to change more than one layer at the same time var items = []; var layerId = this.getDefaultLayerForTileId(tileId); if (layerId === 1 && Tilemap.isTileA1(tileId)) { items.push({ x: x, y: y, z: 0, tileId: Tilemap.TILE_ID_A1 }); } if (layerId === 3) { // If there's already something on the fourth layer, then move it to the third and place the new tile on the 4th var currentTile = this.getCurrentTileAtPosition(x, y, 3, skipPreview); if (currentTile === tileId && tileId !== 0) { return []; } if (currentTile) { items.push({ x: x, y: y, z: 2, tileId: currentTile }); } } items.push({ x: x, y: y, z: layerId, tileId: tileId }); // Remove anything above the new tile if (updateHigherLayers) { for (var i = layerId + 1; i <= 3; i++) { items.push({ x: x, y: y, z: i, tileId: 0 }); } } return items; } }, { key: "canEraseLayer", value: function canEraseLayer(layerIndex) { if (currentTool === 'eraser') { return true; } if (layerIndex >= 2) { return true; } if (multiLayerSelection.length) { return true; } if (currentLayer !== Layers.auto) { return true; } // The lower layers can only be erased with the pen in auto mode when there are multiple layers selected return false; } }, { key: "_eraseSingleLayerTile", value: function _eraseSingleLayerTile(x, y, z) { var updateNeighbors = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; var previewOnly = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; var forceErasure = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; if (!forceErasure && !this.canEraseLayer(z)) { return; } var tileIndex = this.tileIndex(x, y, z); if (previewOnly) { previewChanges[tileIndex] = 0; } else { var oldTile = $dataMap.data[tileIndex]; if (currentChange.tiles[tileIndex] === undefined && oldTile !== 0) { currentChange.tiles[tileIndex] = oldTile; } $dataMap.data[tileIndex] = 0; } } }, { key: "_eraseSingleMapTile", value: function _eraseSingleMapTile(x, y, z) { var updateNeighbors = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; var previewOnly = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; var forceErasure = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; if (z > 3 && z !== Layers.auto) { this._eraseSingleLayerTile(x, y, z, updateNeighbors, previewOnly, forceErasure); return; } for (var newZ = 0; newZ <= 3; newZ++) { if (newZ !== z && z !== Layers.auto) { continue; } this._eraseSingleLayerTile(x, y, newZ, updateNeighbors, previewOnly, forceErasure); this.maybeUpdateTileNeighbors(x, y, z, updateNeighbors, previewOnly); } } // eslint-disable-next-line complexity }, { key: "_getBlockCollision", value: function _getBlockCollision(i, j, count, tileId) { if (tileId <= 3) { return tileId; } var goesUp = false; var goesDown = false; var goesRight = false; var goesLeft = false; if (tileId >= 20) { var d = tileId - 20; goesUp = !DirectionHelper.goesUp(d); goesDown = !DirectionHelper.goesDown(d); goesLeft = !DirectionHelper.goesLeft(d); goesRight = !DirectionHelper.goesRight(d); } else if (tileId > 10) { var _d = tileId - 10; goesUp = DirectionHelper.goesUp(_d); goesDown = DirectionHelper.goesDown(_d); goesLeft = DirectionHelper.goesLeft(_d); goesRight = DirectionHelper.goesRight(_d); } else if (tileId === 4) { goesUp = true; goesDown = true; } else if (tileId === 5) { goesLeft = true; goesRight = true; } var up = goesUp && j === 0; var down = goesDown && j === count - 1; var left = goesLeft && i === 0; var right = goesRight && i === count - 1; if (up) { if (left) { if (right) { if (down) { return 20; } return 22; } if (down) { return 26; } return 17; } if (right) { if (down) { return 24; } return 19; } if (down) { return 4; } return 18; } if (down) { if (left) { if (right) { return 28; } return 11; } if (right) { return 13; } return 12; } if (left) { if (right) { return 5; } return 14; } if (right) { return 16; } return 1; } }, { key: "_applySingleCollision", value: function _applySingleCollision(x, y, tileId) { var previewOnly = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; if (previewOnly) { return; } var gridRatio = this.getGridRatio(); var count = 4 / gridRatio; for (var i = 0; i < count; i++) { for (var j = 0; j < count; j++) { var intX = Math.floor(x * 4) + i; var intY = Math.floor(y * 4) + j; var height = $gameMap.height() * 4; var width = $gameMap.width() * 4; var index = intY % height * width + intX % width; var blockCollision = this._getBlockCollision(i, j, count, tileId); var oldTile = customCollisionTable[index] || 0; if (currentChange.collision[index] === undefined && oldTile !== blockCollision) { currentChange.collision[index] = oldTile; } if (!blockCollision) { delete customCollisionTable[index]; continue; } customCollisionTable[index] = blockCollision; } } } }, { key: "_changePixelPositionBlend", value: function _changePixelPositionBlend(x, y, px, py, newBlend) { var _currentChange$blend$, _table$pixelIndex; var previewOnly = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; var tileWidth = $gameMap.tileWidth(); var tileHeight = $gameMap.tileHeight(); var fx = Math.floor(x) + Math.floor(px / tileWidth); var fy = Math.floor(y) + Math.floor(py / tileHeight); var pixelX = px % tileWidth; var pixelY = py % tileHeight; if (fx < 0 || fx >= $gameMap.width()) { return; } if (fy < 0 || fy >= $gameMap.height()) { return; } var tileIndex = this.tileIndex(fx, fy, 0); var size = tileWidth * tileHeight; var fullTable = previewOnly ? window.CycloneMagic.tileBlendingTable : tileBlendingTable; if (!fullTable[tileIndex]) { var buffer = new ArrayBuffer(size); fullTable[tileIndex] = new Int8Array(buffer); } var table = fullTable[tileIndex]; var pixelIndex = pixelY * tileWidth + pixelX; if (((_currentChange$blend$ = currentChange.blend[tileIndex]) === null || _currentChange$blend$ === void 0 ? void 0 : _currentChange$blend$[pixelIndex]) === undefined && ((_table$pixelIndex = table[pixelIndex]) !== null && _table$pixelIndex !== void 0 ? _table$pixelIndex : 0) !== newBlend) { var _table$pixelIndex2; if (currentChange.blend[tileIndex] === undefined) { currentChange.blend[tileIndex] = {}; } currentChange.blend[tileIndex][pixelIndex] = (_table$pixelIndex2 = table[pixelIndex]) !== null && _table$pixelIndex2 !== void 0 ? _table$pixelIndex2 : 0; } table[pixelIndex] = newBlend; } }, { key: "_changePositionBlend", value: function _changePositionBlend(x, y, newBlend) { var fx = Math.floor(x); var fy = Math.floor(y); var tileIndex = this.tileIndex(fx, fy, 0); var gridRatio = this.getGridRatio(); var tileWidth = $gameMap.tileWidth(); var tileHeight = $gameMap.tileHeight(); var size = tileWidth * tileHeight; if (!tileBlendingTable[tileIndex]) { var buffer = new ArrayBuffer(size); tileBlendingTable[tileIndex] = new Int8Array(buffer); } var table = tileBlendingTable[tileIndex]; var subX = x - fx; var subY = y - fy; var leftPx = Math.round(subX * tileWidth); var topPx = Math.round(subY * tileHeight); var blockWidth = Math.floor(tileWidth / gridRatio); var blockHeight = Math.floor(tileHeight / gridRatio); var rightPx = leftPx + blockWidth; var bottomPx = topPx + blockHeight; for (var px = leftPx; px < rightPx; px++) { for (var py = topPx; py < bottomPx; py++) { var _currentChange$blend$2, _table$pixelIndex3; var pixelIndex = py * tileWidth + px; if (((_currentChange$blend$2 = currentChange.blend[tileIndex]) === null || _currentChange$blend$2 === void 0 ? void 0 : _currentChange$blend$2[pixelIndex]) === undefined && ((_table$pixelIndex3 = table[pixelIndex]) !== null && _table$pixelIndex3 !== void 0 ? _table$pixelIndex3 : 0) !== newBlend) { var _table$pixelIndex4; if (currentChange.blend[tileIndex] === undefined) { currentChange.blend[tileIndex] = {}; } currentChange.blend[tileIndex][pixelIndex] = (_table$pixelIndex4 = table[pixelIndex]) !== null && _table$pixelIndex4 !== void 0 ? _table$pixelIndex4 : 0; } table[pixelIndex] = newBlend; } } } }, { key: "isPositionBlendSpriteReady", value: function isPositionBlendSpriteReady(x, y) { var _SceneManager$_scene$; if (!((_SceneManager$_scene$ = SceneManager._scene._spriteset) === null || _SceneManager$_scene$ === void 0 ? void 0 : _SceneManager$_scene$._blenderTileSprites)) { return false; } var _iterator14 = _createForOfIteratorHelper(SceneManager._scene._spriteset._blenderTileSprites), _step14; try { for (_iterator14.s(); !(_step14 = _iterator14.n()).done;) { var sprite = _step14.value; if (sprite._mapX === x && sprite._mapY === y) { return true; } } } catch (err) { _iterator14.e(err); } finally { _iterator14.f(); } return false; } }, { key: "forceBlenderRefresh", value: function forceBlenderRefresh() { var _SceneManager$_scene$2; var hardRefresh = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (!window.CycloneMagic) { return; } ((_SceneManager$_scene$2 = SceneManager._scene._spriteset) === null || _SceneManager$_scene$2 === void 0 ? void 0 : _SceneManager$_scene$2.forceBlenderRefresh) && SceneManager._scene._spriteset.forceBlenderRefresh(hardRefresh); } }, { key: "buildSmallCircle", value: function buildSmallCircle() { var width = tileWidth / 4; var height = tileHeight / 4; var bitmap = new Bitmap(width, height); bitmap.drawCircle(width / 2, height / 2, Math.min(width, height) / 2, '#0000FF'); bitmap.drawCircle(width / 2, height / 2, Math.min(width, height) / 2 - 2, '#00FF00'); var imageData = bitmap.context.getImageData(0, 0, width, height); smallCircleData = imageData.data; } }, { key: "buildCircle", value: function buildCircle() { var width = tileWidth / 2; var height = tileHeight / 2; var bitmap = new Bitmap(width, height); bitmap.drawCircle(width / 2, height / 2, Math.min(width, height) / 2, '#0000FF'); bitmap.drawCircle(width / 2, height / 2, Math.min(width, height) / 2 - 4, '#00FF00'); var imageData = bitmap.context.getImageData(0, 0, width, height); circleData = imageData.data; } }, { key: "getCircleData", value: function getCircleData() { if (circleData) { if (Input.isPressed('shift')) { return smallCircleData; } return circleData; } this.buildSmallCircle(); this.buildCircle(); return this.getCircleData(); } }, { key: "optimizeBlends", value: function optimizeBlends() { this.resetCurrentChange(); for (var _x7 = 0; _x7 < $gameMap.width(); _x7++) { for (var y = 0; y < $gameMap.height(); y++) { this.optimizeTileBlend(_x7, y); } } this.logChange(true); } }, { key: "removeAllBlends", value: function removeAllBlends() { this.resetCurrentChange(); for (var _x8 = 0; _x8 < $gameMap.width(); _x8++) { for (var y = 0; y < $gameMap.height(); y++) { this.removeTileBlend(_x8, y, false); } } this.logChange(true); } }, { key: "optimizeTileBlend", value: function optimizeTileBlend(x, y) { var fx = Math.floor(x); var fy = Math.floor(y); if (fx < 0 || fx >= $gameMap.width()) { return; } if (fy < 0 || fy >= $gameMap.height()) { return; } var tileIndex = this.tileIndex(fx, fy, 0); if (!tileBlendingTable[tileIndex]) { return; } var hasZero = tileBlendingTable[tileIndex].includes(0); var hasOne = tileBlendingTable[tileIndex].includes(1); if (hasZero === hasOne) { return; } // If it's all blended, then remove whatever tile is on layer 2 if (hasOne) { this._applySingleMapTile(x, y, 1, 0, false, false, true); } currentChange.blend[tileIndex] = tileBlendingTable[tileIndex]; delete tileBlendingTable[tileIndex]; } }, { key: "removeTileBlend", value: function removeTileBlend(x, y) { var previewOnly = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; if (previewOnly && !window.CycloneMagic) { return; } var fx = Math.floor(x); var fy = Math.floor(y); if (fx < 0 || fx >= $gameMap.width()) { return; } if (fy < 0 || fy >= $gameMap.height()) { return; } var tileIndex = this.tileIndex(fx, fy, 0); if (previewOnly) { if (window.CycloneMagic.tileBlendingTable[tileIndex]) { delete window.CycloneMagic.tileBlendingTable[tileIndex]; } return; } if (tileBlendingTable[tileIndex]) { currentChange.blend[tileIndex] = tileBlendingTable[tileIndex]; delete tileBlendingTable[tileIndex]; } } }, { key: "_applyBlendBrush", value: function _applyBlendBrush(x, y) { var previewOnly = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; if (previewOnly && !window.CycloneMagic) { return; } var tileWidth = $gameMap.tileWidth(); var tileHeight = $gameMap.tileHeight(); var divider = Input.isPressed('shift') ? 4 : 2; var width = tileWidth / divider; var height = tileHeight / divider; var pixels = this.getCircleData(); var index = -1; var tileX = Math.floor(x); var tileY = Math.floor(y); var pixelX = Math.floor((x - tileX) * tileWidth); var pixelY = Math.floor((y - tileY) * tileHeight); var newBlend = currentTool === Tools.eraser ? 0 : 1; for (var py = 0; py < height; py++) { for (var px = 0; px < width; px++) { index++; if (pixels[index * 4 + 1] > 0) { this._changePixelPositionBlend(x, y, pixelX + px, pixelY + py, newBlend, previewOnly); } else if (pixels[index * 4 + 2] > 0) { if (Math.randomInt(10) > 5) { this._changePixelPositionBlend(x, y, pixelX + px, pixelY + py, newBlend, previewOnly); } } } } if (previewOnly) { forceBlenderRefresh(); } else { // Let's do a quick refresh first and then save the data a little later if (window.CycloneMagic) { window.CycloneMagic.tileBlendingTable = tileBlendingTable; var maxTileX = tileX + Math.floor((pixelX + width) / tileWidth); var maxTileY = tileY + Math.floor((pixelY + height) / tileHeight); if (window.CycloneMagic) { for (var cacheX = tileX; cacheX <= maxTileX; cacheX++) { for (var cacheY = tileY; cacheY <= maxTileY; cacheY++) { window.CycloneMagic.clearPositionCache(cacheX, cacheY); } } } forceBlenderRefresh(); } } } }, { key: "_applySingleBlend", value: function _applySingleBlend(x, y) { if (currentTool === Tools.eraser) { this._changePositionBlend(x, y, 0); return; } this._changePositionBlend(x, y, 1); } }, { key: "_applyPuzzleTile", value: function _applyPuzzleTile(x, y, tileId, previewOnly) { var _window$CycloneMagic2, _CycloneMagic$puzzleT; if (!((_window$CycloneMagic2 = window.CycloneMagic) === null || _window$CycloneMagic2 === void 0 ? void 0 : _window$CycloneMagic2.puzzleTiles)) { return; } if (previewOnly) { return; } var width = $gameMap.width() * 2; var index = y * 2 * width + x * 2; var oldTile = (_CycloneMagic$puzzleT = CycloneMagic.puzzleTiles[index]) !== null && _CycloneMagic$puzzleT !== void 0 ? _CycloneMagic$puzzleT : 0; if (currentChange.puzzle[index] === undefined && oldTile !== tileId) { currentChange.puzzle[index] = oldTile; } if (tileId) { CycloneMagic.puzzleTiles[index] = tileId; } else if (CycloneMagic.puzzleTiles[index]) { delete CycloneMagic.puzzleTiles[index]; } } }, { key: "_applySingleMapTile", value: function _applySingleMapTile(x, y, z, tileId) { var updateNeighbors = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; var previewOnly = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; var forceErasure = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false; if (z === Layers.collisions) { return this._applySingleCollision(x, y, tileId, previewOnly); } if (z === 1 && puzzleMode) { this._applyPuzzleTile(x, y, tileId, previewOnly); return; } if (!tileId) { this._eraseSingleMapTile(x, y, z, updateNeighbors, previewOnly, forceErasure); return; } var itemsToChange = this.getItemsToChange(x, y, z, tileId, !previewOnly, updateNeighbors); var _iterator15 = _createForOfIteratorHelper(itemsToChange), _step15; try { for (_iterator15.s(); !(_step15 = _iterator15.n()).done;) { var _step15$value = _step15.value, _x9 = _step15$value.x, _y = _step15$value.y, _z = _step15$value.z, _tileId = _step15$value.tileId; if (_z > 5) { continue; } var tileIndex = this.tileIndex(_x9, _y, _z); var effectiveTileId = _tileId; if (Tilemap.isAutotile(_tileId)) { effectiveTileId = this.changeAutoTileShapeForPosition(_x9, _y, _z, _tileId, false); } if (_z === 1) { this.removeTileBlend(_x9, _y, previewOnly); } if (previewOnly) { previewChanges[tileIndex] = effectiveTileId; } else { var oldTile = $dataMap.data[tileIndex]; if (currentChange.tiles[tileIndex] === undefined && oldTile !== effectiveTileId) { currentChange.tiles[tileIndex] = oldTile; } $dataMap.data[tileIndex] = effectiveTileId; } this.maybeUpdateTileNeighbors(_x9, _y, _z, updateNeighbors, previewOnly); } } catch (err) { _iterator15.e(err); } finally { _iterator15.f(); } } }, { key: "setMapTile", value: function setMapTile(x, y, z, tileId) { var updateNeighbors = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; var previewOnly = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; if (!$gameMap.isValid(x, y)) { return; } if (currentLayer === Layers.blend) { if (!previewOnly) { CycloneMapEditor$1._applySingleBlend(x, y); } return; } if (currentTool !== 'eraser') { if (tileId === undefined) { return; } if (tileId === 0 && !this.canEraseLayer(z)) { return; } } this._applySingleMapTile(x, y, z, tileId, updateNeighbors, previewOnly); } }, { key: "getSelectedTileIndex", value: function getSelectedTileIndex(col, row) { if (currentTool === 'eraser') { return; } if (currentTileId === undefined) { return; } if (selectedTileList.length < tileCols * tileRows) { return; } var realCol = col % tileCols; var realRow = row % tileRows; return realRow * tileCols + realCol; } }, { key: "getSelectedTileCell", value: function getSelectedTileCell(col, row) { var index = this.getSelectedTileIndex(col, row); if (index || index === 0) { return selectedTileList[index]; } } }, { key: "setSelectionTileMaybeMultiLayer", value: function setSelectionTileMaybeMultiLayer(tileX, tileY, selectionCol, selectionRow) { var _effectiveLayer; var previewOnly = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; var effectiveLayer = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : undefined; effectiveLayer = (_effectiveLayer = effectiveLayer) !== null && _effectiveLayer !== void 0 ? _effectiveLayer : currentLayer; var index = this.getSelectedTileIndex(selectionCol, selectionRow); if (effectiveLayer === 7 && multiLayerSelection.length) { for (var z = 0; z <= 3; z++) { var _multiLayerSelection$; var tileId = (_multiLayerSelection$ = multiLayerSelection[z][index]) !== null && _multiLayerSelection$ !== void 0 ? _multiLayerSelection$ : 0; this.setMapTile(tileX, tileY, z, tileId, true, previewOnly); } } else { var _selectedTileList$ind; var _tileId2 = (_selectedTileList$ind = selectedTileList[index]) !== null && _selectedTileList$ind !== void 0 ? _selectedTileList$ind : 0; this.setMapTile(tileX, tileY, effectiveLayer, _tileId2, true, previewOnly); if (effectiveLayer === 2 && currentLayer === 7 && currentTool === 'eraser') { this.setMapTile(tileX, tileY, 3, 0, true, previewOnly); } } } }, { key: "canApplyRectangle", value: function canApplyRectangle() { return currentTileId !== undefined || currentTool === 'eraser' || currentLayer === Layers.blend; } }, { key: "isAutoEraser", value: function isAutoEraser() { return currentLayer === Layers.auto && currentTool === 'eraser' && !Input.isPressed('shift'); } }, { key: "getHighestLayerOnArea", value: function getHighestLayerOnArea(startX, startY, width, height) { var _this15 = this; var highestLayer = function () { for (var z = 3; z >= 1; z--) { for (var tileY = startY; tileY < startY + height; tileY++) { for (var tileX = startX; tileX < startX + width; tileX++) { var tileIndex = _this15.tileIndex(tileX, tileY, z); var tileId = $dataMap.data[tileIndex]; if (tileId > 0) { return z; } } } } return 0; }(); if (highestLayer === 3 && Input.isPressed('control')) { return 2; } return highestLayer; } }, { key: "applyRectangle", value: function applyRectangle(startX, startY, width, height) { var previewOnly = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; if (!this.canApplyRectangle()) { return; } this.ensureLayerVisibility(); var gridRatio = this.getGridRatio(); var initialRow = 0; var initialCol = 0; var rowIncrement = 1; var colIncrement = 1; if (rectangleBackWidth > 0) { initialCol = width * gridRatio - 1; colIncrement *= -1; } if (rectangleBackHeight > 0) { initialRow = height * gridRatio - 1; rowIncrement *= -1; } var selectionRow = initialRow; var selectionCol = initialCol; if (previewOnly) { previewChanges = {}; } else { this.resetCurrentChange(); } var effectiveLayer = currentLayer; if (this.isAutoEraser()) { effectiveLayer = this.getHighestLayerOnArea(startX, startY, width, height); } var tileIncrement = 1 / gridRatio; for (var tileY = startY; tileY < startY + height; tileY += tileIncrement) { selectionCol = initialCol; for (var tileX = startX; tileX < startX + width; tileX += tileIncrement) { this.setSelectionTileMaybeMultiLayer(tileX, tileY, selectionCol, selectionRow, previewOnly, effectiveLayer); selectionCol += colIncrement; } selectionRow += rowIncrement; } if (previewOnly) { SceneManager._scene._spriteset._tilemap.refresh(); this.maybeRefreshGrid(); } else { this.logChange(); this.refreshTilemap(); } } }, { key: "maybeRefreshGrid", value: function maybeRefreshGrid() { if (currentLayer !== Layers.regions) { return; } refreshGrid(); } }, { key: "refreshTilemap", value: function refreshTilemap() { previewChanges = {}; if (currentLayer === Layers.collisions || currentLayer === Layers.blend) { saveExtraData(true); } if (TouchInput.isLongPressed()) { _refreshTilemap(); } else { SceneManager._scene._spriteset._tilemap.refresh(); } refreshGrid(); } }, { key: "copyAutoRectangle", value: function copyAutoRectangle(startX, startY, width, height) { var _this16 = this; for (var z = 0; z <= 3; z++) { multiLayerSelection[z] = Array(width * height); } this.iterateRectangle(startX, startY, width, height, function (tileX, tileY, index) { for (var _z2 = 0; _z2 <= 3; _z2++) { var tileIndex = _this16.tileIndex(tileX, tileY, _z2); multiLayerSelection[_z2][index] = $dataMap.data[tileIndex] || 0; selectedTileList[index] = $dataMap.data[tileIndex] || selectedTileList[index] || 0; if (currentTileId === undefined) { currentTileId = selectedTileList[index]; } } }); } }, { key: "_selectTileIfNoneSelectedYet", value: function _selectTileIfNoneSelectedYet(tileId) { if (currentTileId === undefined) { currentTileId = tileId; } } }, { key: "_shouldSkipRemainingLayersCopy", value: function _shouldSkipRemainingLayersCopy(foundAny, z) { if (!foundAny) { return false; } if (Input.isPressed('control')) { return z !== 3; } return true; } }, { key: "iterateRectangle", value: function iterateRectangle(startX, startY, width, height, fn) { var index = 0; for (var tileY = startY; tileY < startY + height; tileY++) { for (var tileX = startX; tileX < startX + width; tileX++) { fn(tileX, tileY, index); index++; } } } }, { key: "copyHigherAutoRectangle", value: function copyHigherAutoRectangle(startX, startY, width, height) { var _this17 = this; for (var z = 0; z <= 3; z++) { multiLayerSelection[z] = Array(width * height); } var foundAny = false; var _loop2 = function _loop2(_z3) { if (!_this17.isLayerVisible(_z3)) { return "continue"; } _this17.iterateRectangle(startX, startY, width, height, function (tileX, tileY, index) { var tileIndex = _this17.tileIndex(tileX, tileY, _z3); multiLayerSelection[_z3][index] = $dataMap.data[tileIndex] || 0; selectedTileList[index] = $dataMap.data[tileIndex] || selectedTileList[index] || 0; _this17._selectTileIfNoneSelectedYet(selectedTileList[index]); if ($dataMap.data[tileIndex]) { foundAny = true; } }); if (_this17._shouldSkipRemainingLayersCopy(foundAny, _z3)) { return { v: void 0 }; } }; for (var _z3 = 3; _z3 >= 0; _z3--) { var _ret2 = _loop2(_z3); if (_ret2 === "continue") continue; if (_typeof(_ret2) === "object") return _ret2.v; } } }, { key: "copyHigherRectangle", value: function copyHigherRectangle(startX, startY, width, height) { var _this18 = this; var foundAny = false; var _loop3 = function _loop3(z) { if (!_this18.isLayerVisible(z)) { return "continue"; } _this18.iterateRectangle(startX, startY, width, height, function (tileX, tileY, index) { var tileIndex = _this18.tileIndex(tileX, tileY, z); selectedTileList[index] = selectedTileList[index] || $dataMap.data[tileIndex] || 0; _this18._selectTileIfNoneSelectedYet(selectedTileList[index]); if ($dataMap.data[tileIndex]) { foundAny = true; } }); if (_this18._shouldSkipRemainingLayersCopy(foundAny, z)) { return { v: void 0 }; } }; for (var z = 3; z >= 0; z--) { var _ret3 = _loop3(z); if (_ret3 === "continue") continue; if (_typeof(_ret3) === "object") return _ret3.v; } } }, { key: "copyManualRectangle", value: function copyManualRectangle(startX, startY, width, height) { var _this19 = this; this.iterateRectangle(startX, startY, width, height, function (tileX, tileY, index) { var tileIndex = _this19.tileIndex(tileX, tileY, currentLayer); selectedTileList[index] = $dataMap.data[tileIndex] || 0; _this19._selectTileIfNoneSelectedYet(selectedTileList[index]); }); } }, { key: "copyRectangle", value: function copyRectangle(startX, startY, width, height) { if (puzzleMode) { return; } if (!wasRightButtonDown) { return; } if (currentLayer === Layers.collisions) { return; } var gridRatio = this.getGridRatio(); multiLayerSelection = []; selectedTileList = Array(width * gridRatio * (height * gridRatio)); currentTileId = undefined; if (currentLayer === 7) { if (Input.isPressed('shift')) { this.copyHigherAutoRectangle(startX, startY, width, height); } else { this.copyAutoRectangle(startX, startY, width, height); } } else if (Input.isPressed('shift')) { this.copyHigherRectangle(startX, startY, width, height); } else { this.copyManualRectangle(startX, startY, width, height); } tileCols = width; tileRows = height; messySelection = true; if (currentTool == 'eraser') { this.restoreLastDrawingTool(); } this.refreshTilemap(); SceneManager._scene._mapEditorWindow._manualTileSelected = undefined; SceneManager._scene._mapEditorWindow.refresh(); SceneManager._scene._mapEditorWindow.ensureSelectionVisible(); } }, { key: "restoreLastDrawingTool", value: function restoreLastDrawingTool() { if (lastDrawingTool === 'rectangle') { this.rectangleButton(); } else { this.pencilButton(); } } }, { key: "isSameKindTileCurrentLayer", value: function isSameKindTileCurrentLayer(layers, index) { var size = $gameMap.width() * $gameMap.height(); if (currentLayer > 3) { for (var z = 0; z <= 3; z++) { var _tileId3 = $dataMap.data[index + z * size]; if (!Tilemap.isSameKindTile(_tileId3, layers[z])) { return false; } } return true; } var tileId = $dataMap.data[index]; return Tilemap.isSameKindTile(layers[currentLayer], tileId); } }, { key: "_maybeValidateTileIndexForCollectionList", value: function _maybeValidateTileIndexForCollectionList(list, index, area, initialTileIds) { if (area[index] !== undefined) { return; } var height = $gameMap.height(); var width = $gameMap.width(); area[index] = this.isSameKindTileCurrentLayer(initialTileIds, index); if (!area[index]) { return; } var workLayer = currentLayer <= 3 ? currentLayer : 0; var y = this.indexPositionY(index, workLayer); var x = index - this.tileIndex(0, y, workLayer); var leftIndex = x > 0 ? this.tileIndex(x - 1, y, workLayer) : -1; var rightIndex = x < width - 1 ? this.tileIndex(x + 1, y, workLayer) : -1; var upIndex = y > 0 ? this.tileIndex(x, y - 1, workLayer) : -1; var downIndex = y < height - 1 ? this.tileIndex(x, y + 1, workLayer) : -1; var maybeAddIndex = function maybeAddIndex(index) { if (index >= 0 && !list.includes(index)) { list.push(index); } }; maybeAddIndex(leftIndex); maybeAddIndex(rightIndex); maybeAddIndex(upIndex); maybeAddIndex(downIndex); } }, { key: "collectFillAreaFrom", value: function collectFillAreaFrom(mapX, mapY) { var list = []; var initialTileIds = []; var area = {}; if (currentLayer === Layers.auto || currentLayer < 4) { for (var z = 0; z <= 3; z++) { var tileIndex = this.tileIndex(mapX, mapY, z); initialTileIds[z] = $dataMap.data[tileIndex]; if (z === currentLayer || currentLayer === 7 && z === 0) { list.push(tileIndex); } } for (var i = 0; i < list.length; i++) { var index = list[i]; this._maybeValidateTileIndexForCollectionList(list, index, area, initialTileIds); } } return Object.keys(area).filter(function (key) { return area[key]; }); } }, { key: "applyFillArea", value: function applyFillArea(mapX, mapY) { if (currentTileId === undefined) { return; } this.ensureLayerVisibility(); var affectedArea = this.collectFillAreaFrom(mapX, mapY); var height = $gameMap.height(); var width = $gameMap.width(); var workLayer = currentLayer <= 3 ? currentLayer : 0; this.resetCurrentChange(); var _iterator16 = _createForOfIteratorHelper(affectedArea), _step16; try { for (_iterator16.s(); !(_step16 = _iterator16.n()).done;) { var tileIndex = _step16.value; var y = this.indexPositionY(tileIndex, workLayer); var _x10 = tileIndex - this.tileIndex(0, y, workLayer); var xDiff = (_x10 + width - mapX) % tileCols; var yDiff = (y + height - mapY) % tileRows; this.setSelectionTileMaybeMultiLayer(_x10, y, xDiff, yDiff, false); } } catch (err) { _iterator16.e(err); } finally { _iterator16.f(); } this.logChange(); this.refreshTilemap(); } }, { key: "ensureLayerVisibility", value: function ensureLayerVisibility() { if (!layerVisibility[currentLayer]) { layerVisibility[currentLayer] = true; if (this.isMapEditorScene()) { SceneManager._scene._mapEditorLayerListWindow.refresh(); } } } }, { key: "applySelectedTiles", value: function applySelectedTiles(mapX, mapY) { if (currentLayer !== Layers.blend) { if (currentTileId === undefined) { return; } if (selectedTileList.length < tileCols * tileRows) { return; } } this.ensureLayerVisibility(); var index = 0; var gridRatio = this.getGridRatio(); var increment = 1 / gridRatio; for (var y = mapY; y < mapY + tileRows; y += increment) { for (var _x11 = mapX; _x11 < mapX + tileCols; _x11 += increment) { if (!$gameMap.isValid(_x11, y)) { continue; } if (currentLayer === 7 && multiLayerSelection.length) { for (var z = 0; z <= 3; z++) { this.setMapTile(_x11, y, z, multiLayerSelection[z][index]); } } else { this.setMapTile(_x11, y, currentLayer, selectedTileList[index]); } index++; } } this.refreshTilemap(); } }, { key: "updateRightTouch", value: function updateRightTouch(x, y) { if (CycloneMapEditor$1.isRightButtonDown) { if (!CycloneMapEditor$1.wasRightButtonDown) { CycloneMapEditor$1.rectangleStartX = x; CycloneMapEditor$1.rectangleStartY = y; CycloneMapEditor$1.rectangleStartMouseX = TouchInput.x; CycloneMapEditor$1.rectangleStartMouseY = TouchInput.y; } var gridRatio = CycloneMapEditor$1.getGridRatio(); CycloneMapEditor$1.rectangleWidth = (x - CycloneMapEditor$1.rectangleStartX + 1 / gridRatio).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleHeight = (y - CycloneMapEditor$1.rectangleStartY + 1 / gridRatio).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleBackWidth = (CycloneMapEditor$1.rectangleStartX - x).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleBackHeight = (CycloneMapEditor$1.rectangleStartY - y).clamp(0, 30) * gridRatio; if (this.crossedHorizontalLoop()) { // moved right through the edge, limit the width to it if (CycloneMapEditor$1.rectangleStartX > x) { CycloneMapEditor$1.rectangleWidth = ($gameMap.width() - CycloneMapEditor$1.rectangleStartX) * gridRatio; CycloneMapEditor$1.rectangleBackWidth = 0; } else if (x > CycloneMapEditor$1.rectangleStartX) { CycloneMapEditor$1.rectangleBackWidth = CycloneMapEditor$1.rectangleStartX * gridRatio; CycloneMapEditor$1.rectangleWidth = 0; } } if (this.crossedVerticalLoop()) { if (CycloneMapEditor$1.rectangleStartY > y) { CycloneMapEditor$1.rectangleHeight = ($gameMap.height() - CycloneMapEditor$1.rectangleStartY) * gridRatio; CycloneMapEditor$1.rectangleBackHeight = 0; } else if (y > CycloneMapEditor$1.rectangleStartY) { CycloneMapEditor$1.rectangleBackHeight = CycloneMapEditor$1.rectangleStartY * gridRatio; CycloneMapEditor$1.rectangleHeight = 0; } } SceneManager._scene._spriteset._mapEditorCursor.updateDrawing(); return; } if (CycloneMapEditor$1.wasRightButtonDown) { this.updateRectangleReleased(); return; } } }, { key: "updateCurrentToolTouch", value: function updateCurrentToolTouch(x, y) { switch (CycloneMapEditor$1.currentTool) { case 'fill': this.updateFill(x, y); break; case 'pencil': this.updatePencil(x, y); break; case 'rectangle': this.updateRectangle(x, y); break; case 'eraser': this.updateEraser(x, y); break; } } }, { key: "changeRectangleArea", value: function changeRectangleArea() { var previewOnly = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; var startX = CycloneMapEditor$1.rectangleStartX; var startY = CycloneMapEditor$1.rectangleStartY; var applyWidth = 0; var applyHeight = 0; var gridRatio = CycloneMapEditor$1.getGridRatio(); if (CycloneMapEditor$1.rectangleWidth > 0) { applyWidth = CycloneMapEditor$1.rectangleWidth / gridRatio; } else if (CycloneMapEditor$1.rectangleBackWidth > 0) { startX -= CycloneMapEditor$1.rectangleBackWidth / gridRatio; applyWidth = (CycloneMapEditor$1.rectangleBackWidth + 1) / gridRatio; } if (CycloneMapEditor$1.rectangleHeight > 0) { applyHeight = CycloneMapEditor$1.rectangleHeight / gridRatio; } else if (CycloneMapEditor$1.rectangleBackHeight > 0) { startY -= CycloneMapEditor$1.rectangleBackHeight / gridRatio; applyHeight = (CycloneMapEditor$1.rectangleBackHeight + 1) / gridRatio; } if (applyWidth > 0 && applyHeight > 0) { if (CycloneMapEditor$1.wasRightButtonDown) { if (!previewOnly) { CycloneMapEditor$1.copyRectangle(startX, startY, applyWidth, applyHeight); } } else { CycloneMapEditor$1.applyRectangle(startX, startY, applyWidth, applyHeight, previewOnly); } } } }, { key: "updateRectangleReleased", value: function updateRectangleReleased() { this.changeRectangleArea(); CycloneMapEditor$1.rectangleWidth = 0; CycloneMapEditor$1.rectangleHeight = 0; CycloneMapEditor$1.rectangleBackWidth = 0; CycloneMapEditor$1.rectangleBackHeight = 0; SceneManager._scene._spriteset._mapEditorCursor.updateDrawing(); } }, { key: "crossedHorizontalLoop", value: function crossedHorizontalLoop() { if (!$gameMap.isLoopHorizontal()) { return false; } // if moved left but the end position is to the right if (CycloneMapEditor$1.rectangleStartMouseX > TouchInput.x && CycloneMapEditor$1.rectangleWidth > 0) { return true; } if (CycloneMapEditor$1.rectangleStartMouseX < TouchInput.x && CycloneMapEditor$1.rectangleBackWidth > 0) { return true; } return false; } }, { key: "crossedVerticalLoop", value: function crossedVerticalLoop() { if (!$gameMap.isLoopVertical()) { return false; } if (CycloneMapEditor$1.rectangleStartMouseY > TouchInput.y && CycloneMapEditor$1.rectangleHeight > 0) { return true; } if (CycloneMapEditor$1.rectangleStartMouseY < TouchInput.y && CycloneMapEditor$1.rectangleBackHeight > 0) { return true; } return false; } }, { key: "updateRectangle", value: function updateRectangle(x, y) { if (TouchInput.isPressed()) { if (!wasPressing) { CycloneMapEditor$1.rectangleStartX = x; CycloneMapEditor$1.rectangleStartY = y; CycloneMapEditor$1.rectangleStartMouseX = TouchInput.x; CycloneMapEditor$1.rectangleStartMouseY = TouchInput.y; } var gridRatio = CycloneMapEditor$1.getGridRatio(); CycloneMapEditor$1.rectangleWidth = (x - CycloneMapEditor$1.rectangleStartX + 1 / gridRatio).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleHeight = (y - CycloneMapEditor$1.rectangleStartY + 1 / gridRatio).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleBackWidth = (CycloneMapEditor$1.rectangleStartX - x).clamp(0, 30) * gridRatio; CycloneMapEditor$1.rectangleBackHeight = (CycloneMapEditor$1.rectangleStartY - y).clamp(0, 30) * gridRatio; if (this.crossedHorizontalLoop()) { // moved right through the edge, limit the width to it if (CycloneMapEditor$1.rectangleStartX > x) { CycloneMapEditor$1.rectangleWidth = ($gameMap.width() - CycloneMapEditor$1.rectangleStartX) * gridRatio; CycloneMapEditor$1.rectangleBackWidth = 0; } else if (x > CycloneMapEditor$1.rectangleStartX) { CycloneMapEditor$1.rectangleBackWidth = CycloneMapEditor$1.rectangleStartX * gridRatio; CycloneMapEditor$1.rectangleWidth = 0; } } if (this.crossedVerticalLoop()) { if (CycloneMapEditor$1.rectangleStartY > y) { CycloneMapEditor$1.rectangleHeight = ($gameMap.height() - CycloneMapEditor$1.rectangleStartY) * gridRatio; CycloneMapEditor$1.rectangleBackHeight = 0; } else if (y > CycloneMapEditor$1.rectangleStartY) { CycloneMapEditor$1.rectangleBackHeight = CycloneMapEditor$1.rectangleStartY * gridRatio; CycloneMapEditor$1.rectangleHeight = 0; } } this.changeRectangleArea(true); SceneManager._scene._spriteset._mapEditorCursor.updateDrawing(); return; } if (wasPressing) { this.updateRectangleReleased(); return; } } }, { key: "updateFill", value: function updateFill(x, y) { if (!TouchInput.isPressed() || wasPressing) { return; } CycloneMapEditor$1.applyFillArea(x, y); } }, { key: "updateEraser", value: function updateEraser(x, y) { if (this.isLayerVisible(Layers.blend)) { this.updatePencil(x, y); return; } this.updateRectangle(x, y); } }, { key: "updatePencil", value: function updatePencil(x, y) { if (TouchInput.isPressed()) { if (!currentChange) { this.resetCurrentChange(); } if (currentLayer === Layers.blend) { var offset = Input.isPressed('shift') ? 0.125 : 0.25; CycloneMapEditor$1._applyBlendBrush(x - offset, y - offset, false); return; } CycloneMapEditor$1.applySelectedTiles(x, y); return; } if (wasPressing) { CycloneMapEditor$1.logChange(); } } }, { key: "getGridRatio", value: function getGridRatio() { var drawRatio = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (!drawRatio) { if (currentLayer === Layers.blend) { return 16; } } if (puzzleMode) { return 2; } if (currentLayer === Layers.collisions) { if (window.CycloneMovement) { return window.CycloneMovement.collisionStepCount; } var count = this.params.collisionStepCount; if ([1, 2, 4].includes(count)) { return count; } return 1; } return 1; } }, { key: "canvasToMapX", value: function canvasToMapX(x) { var gridRatio = this.getGridRatio(); var originX = $gameMap._displayX * tileWidth; var mapX = (originX + x) / tileWidth; return Math.floor(mapX * gridRatio) / gridRatio; } }, { key: "canvasToMapY", value: function canvasToMapY(y) { var gridRatio = this.getGridRatio(); var originY = $gameMap._displayY * tileHeight; var mapY = (originY + y) / tileHeight; return Math.floor(mapY * gridRatio) / gridRatio; } }, { key: "requestCollisionRefresh", value: function requestCollisionRefresh() { if (!this.active) { return; } if (currentLayer !== Layers.collisions) { return; } if (this.isMapEditorScene()) { SceneManager._scene._mapEditorGrid.requestRefresh(); } } }, { key: "jumpToTile", value: function jumpToTile(tileId) { return SceneManager._scene._mapEditorWindow && SceneManager._scene._mapEditorWindow.jumpToTile(tileId); } }, { key: "jumpToLastTile", value: function jumpToLastTile() { if (!SceneManager._scene._mapEditorWindow) { return; } SceneManager._scene._mapEditorWindow.setTopRow(SceneManager._scene._mapEditorWindow.maxTopRow()); } }, { key: "jumpToOneTileOf", value: function jumpToOneTileOf(tileList) { var _iterator17 = _createForOfIteratorHelper(tileList), _step17; try { for (_iterator17.s(); !(_step17 = _iterator17.n()).done;) { var tileId = _step17.value; if (this.jumpToTile(tileId)) { return; } } } catch (err) { _iterator17.e(err); } finally { _iterator17.f(); } } }, { key: "currentTab", get: function get() { return currentTab; } }, { key: "active", get: function get() { return editorActive; }, set: function set(value) { editorActive = value; } }, { key: "tileWidth", get: function get() { return tileWidth; }, set: function set(value) { tileWidth = value; } }, { key: "tileDrawWidth", get: function get() { if (Graphics.width < 1280) { if (tileWidth > 32) { return Math.floor(tileWidth / 2); } if (tileWidth <= 16) { return tileWidth * 2; } } else { if (tileWidth < 32) { return tileWidth * 2; } } return tileWidth; } }, { key: "tileHeight", get: function get() { return tileHeight; }, set: function set(value) { tileHeight = value; } }, { key: "tileDrawHeight", get: function get() { if (Graphics.width < 1280) { if (tileHeight > 32) { return Math.floor(tileHeight / 2); } if (tileHeight <= 16) { return tileHeight * 2; } } else { if (tileHeight < 32) { return tileHeight * 2; } } return tileHeight; } }, { key: "windowWidth", get: function get() { return windowWidth; }, set: function set(value) { windowWidth = value; } }, { key: "isRightButtonDown", get: function get() { return isRightButtonDown; }, set: function set(value) { isRightButtonDown = value; } // the size of the rectangle tool when the user stretches it right }, { key: "rectangleWidth", get: function get() { return rectangleWidth; }, set: function set(value) { rectangleWidth = value; } // The size of the rectangle tool when the user stretches it down }, { key: "rectangleHeight", get: function get() { return rectangleHeight; }, set: function set(value) { rectangleHeight = value; } // the size of the rectangle tool when the user stretches it left }, { key: "rectangleBackWidth", get: function get() { return rectangleBackWidth; }, set: function set(value) { rectangleBackWidth = value; } // The size of the rectangle tool when the user stretches it up }, { key: "rectangleBackHeight", get: function get() { return rectangleBackHeight; }, set: function set(value) { rectangleBackHeight = value; } // The X tile where the rectangle started }, { key: "rectangleStartX", get: function get() { return rectangleStartX; }, set: function set(value) { rectangleStartX = value; } // The Y tile where the rectangle started }, { key: "rectangleStartY", get: function get() { return rectangleStartY; }, set: function set(value) { rectangleStartY = value; } }, { key: "tileCols", get: function get() { return tileCols; }, set: function set(value) { tileCols = value; } }, { key: "tileRows", get: function get() { return tileRows; }, set: function set(value) { tileRows = value; } // The Mouse X position where the rectangle started }, { key: "rectangleStartMouseX", get: function get() { return rectangleStartMouseX; }, set: function set(value) { rectangleStartMouseX = value; } // The Mouse Y position where the rectangle started }, { key: "rectangleStartMouseY", get: function get() { return rectangleStartMouseY; }, set: function set(value) { rectangleStartMouseY = value; } }, { key: "messySelection", get: function get() { return messySelection; }, set: function set(value) { messySelection = value; } }, { key: "changeHistory", get: function get() { return changeHistory; } }, { key: "undoHistory", get: function get() { return undoHistory; } }, { key: "layerVisibility", get: function get() { return layerVisibility; } }, { key: "wasRightButtonDown", get: function get() { return wasRightButtonDown; }, set: function set(value) { wasRightButtonDown = value; } }, { key: "wasPressing", get: function get() { return wasPressing; }, set: function set(value) { wasPressing = value; } }, { key: "currentTool", get: function get() { return currentTool; } }, { key: "currentLayer", get: function get() { return currentLayer; } }, { key: "showGrid", get: function get() { return showGrid; } }, { key: "previewChanges", get: function get() { return previewChanges; } }, { key: "puzzleMode", get: function get() { return puzzleMode; } }, { key: "currentTileId", get: function get() { return currentTileId; }, set: function set(value) { currentTileId = value; } }, { key: "selectedTileList", get: function get() { return selectedTileList; }, set: function set(value) { selectedTileList = value; } }, { key: "multiLayerSelection", get: function get() { return multiLayerSelection; }, set: function set(value) { multiLayerSelection = value; } }, { key: "statusTileId", get: function get() { return statusTileId; }, set: function set(value) { statusTileId = value; } }, { key: "statusMapX", get: function get() { return statusMapX; }, set: function set(value) { statusMapX = value; } }, { key: "statusMapY", get: function get() { return statusMapY; }, set: function set(value) { statusMapY = value; } }, { key: "statusTile1", get: function get() { return statusTile1; }, set: function set(value) { statusTile1 = value; } }, { key: "statusTile2", get: function get() { return statusTile2; }, set: function set(value) { statusTile2 = value; } }, { key: "statusTile3", get: function get() { return statusTile3; }, set: function set(value) { statusTile3 = value; } }, { key: "statusTile4", get: function get() { return statusTile4; }, set: function set(value) { statusTile4 = value; } }, { key: "statusRegion", get: function get() { return statusRegion; } }, { key: "statusTag", get: function get() { return statusTag; } }, { key: "statusCollision", get: function get() { return statusCollision; } }, { key: "statusBush", get: function get() { return statusBush; } }, { key: "statusCounter", get: function get() { return statusCounter; } }, { key: "statusDamage", get: function get() { return statusDamage; } }, { key: "statusLadder", get: function get() { return statusLadder; } }, { key: "customCollisionTable", get: function get() { return customCollisionTable; } }, { key: "tileBlendingTable", get: function get() { return tileBlendingTable; } }, { key: "mapCaches", get: function get() { return mapCaches; } }, { key: "currentZoom", get: function get() { return currentZoom; }, set: function set(value) { currentZoom = value; $gameScreen._zoomScale = value; if (this.isMapEditorScene()) { $gameMap.zoom = new Point(value, value); SceneManager._scene._mapEditorGrid.refresh(); SceneManager._scene._spriteset.updatePosition(); } // if (Utils.isNwjs()) { // this.zoom100Menu.checked = value === 1; // this.zoom150Menu.checked = value === 1.5; // this.zoom200Menu.checked = value === 2; // this.zoom400Menu.checked = value === 4; // } } }, { key: "changingTileProps", get: function get() { return tilePropTools.includes(currentTool); } }]); return CycloneMapEditor$1; }(CyclonePlugin); globalThis.CycloneMapEditor = CycloneMapEditor$1; CycloneMapEditor$1.register(); var regionColors = ['#e75858', '#c0986f', '#cbcf32', '#8ab24c', '#22aa47', '#1cbf97', '#7ec1df', '#4da4dc', '#4f36a9', '#725fb9', '#d48de4', '#fa5e84']; CycloneMapEditor.patchClass(Bitmap, function ($super) { return /*#__PURE__*/function () { function _class4() { _classCallCheck(this, _class4); } _createClass(_class4, [{ key: "drawNormalTile", value: function drawNormalTile(tileId, x, y, drawWidth, drawHeight) { if (tileId === undefined) { return; } var bitmap = CycloneMapEditor.loadTilesetBitmap(tileId); if (!bitmap) { return; } var sourceX = (Math.floor(tileId / 128) % 2 * 8 + tileId % 8) * CycloneMapEditor.tileWidth; var sourceY = Math.floor(tileId % 256 / 8) % 16 * CycloneMapEditor.tileHeight; this.blt(bitmap, sourceX, sourceY, CycloneMapEditor.tileWidth, CycloneMapEditor.tileHeight, x, y, drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth, drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight); return bitmap; } }, { key: "drawAutoTileTable", value: function drawAutoTileTable(bitmap, table, tileX, tileY, x, y, drawWidth, drawHeight) { var halfWidth = CycloneMapEditor.tileWidth / 2; var halfHeight = CycloneMapEditor.tileHeight / 2; var drawHalfWidth = (drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth) / 2; var drawHalfHeight = (drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight) / 2; for (var i = 0; i < 4; i++) { var tableX = table[i][0]; var tableY = table[i][1]; var sourceX = tileX * CycloneMapEditor.tileWidth + tableX * halfWidth; var sourceY = tileY * CycloneMapEditor.tileHeight + tableY * halfHeight; var targetX = x + i % 2 * drawHalfWidth; var targetY = y + Math.floor(i / 2) * drawHalfHeight; this.blt(bitmap, sourceX, sourceY, halfWidth, halfHeight, targetX, targetY, drawHalfWidth, drawHalfHeight); } return bitmap; } }, { key: "drawTileA1", value: function drawTileA1(bitmap, tileId, x, y, drawWidth, drawHeight) { var tileX = 0; var tileY = 0; var autotileTable = Tilemap.FLOOR_AUTOTILE_TABLE; var kind = Tilemap.getAutotileKind(tileId); var shape = Tilemap.getAutotileShape(tileId); switch (kind) { case 0: tileX = 0; tileY = 0; break; case 1: tileX = 0; tileY = 3; break; case 2: tileX = 6; tileY = 0; break; case 3: tileX = 6; tileY = 3; break; default: tileX = Math.floor(kind % 8 / 4) * 8; tileY = Math.floor(kind / 8) * 6 + Math.floor(kind % 8 / 2) % 2 * 3; if (kind % 2 === 1) { tileX += 6; autotileTable = Tilemap.WATERFALL_AUTOTILE_TABLE; } break; } return this.drawAutoTileTable(bitmap, autotileTable[shape], tileX, tileY, x, y, drawWidth, drawHeight); } }, { key: "drawTileA2", value: function drawTileA2(bitmap, tileId, x, y, drawWidth, drawHeight) { var kind = Tilemap.getAutotileKind(tileId); var tileX = kind % 8 * 2; var tileY = (Math.floor(kind / 8) - 2) * 3; var shape = Tilemap.getAutotileShape(tileId); return this.drawAutoTileTable(bitmap, Tilemap.FLOOR_AUTOTILE_TABLE[shape], tileX, tileY, x, y, drawWidth, drawHeight); } }, { key: "drawTileA3", value: function drawTileA3(bitmap, tileId, x, y, drawWidth, drawHeight) { var kind = Tilemap.getAutotileKind(tileId); var tileX = kind % 8 * 2; var tileY = (Math.floor(kind / 8) - 6) * 2; var shape = Tilemap.getAutotileShape(tileId); return this.drawAutoTileTable(bitmap, Tilemap.WALL_AUTOTILE_TABLE[shape], tileX, tileY, x, y, drawWidth, drawHeight); } }, { key: "drawTileA4", value: function drawTileA4(bitmap, tileId, x, y, drawWidth, drawHeight) { var kind = Tilemap.getAutotileKind(tileId); var tileX = kind % 8 * 2; var tileY = Math.floor((Math.floor(kind / 8) - 10) * 2.5 + (Math.floor(kind / 8) % 2 === 1 ? 0.5 : 0)); var shape = Tilemap.getAutotileShape(tileId); var autotileTable = Tilemap.FLOOR_AUTOTILE_TABLE; if (Math.floor(kind / 8) % 2 === 1) { autotileTable = Tilemap.WALL_AUTOTILE_TABLE; } return this.drawAutoTileTable(bitmap, autotileTable[shape], tileX, tileY, x, y, drawWidth, drawHeight); } }, { key: "drawAutoTile", value: function drawAutoTile(tileId, x, y, drawWidth, drawHeight) { var bitmap = CycloneMapEditor.loadTilesetBitmap(tileId); if (!bitmap) { return; } if (Tilemap.isTileA1(tileId)) { return this.drawTileA1(bitmap, tileId, x, y, drawWidth, drawHeight); } if (Tilemap.isTileA2(tileId)) { return this.drawTileA2(bitmap, tileId, x, y, drawWidth, drawHeight); } if (Tilemap.isTileA3(tileId)) { return this.drawTileA3(bitmap, tileId, x, y, drawWidth, drawHeight); } if (Tilemap.isTileA4(tileId)) { return this.drawTileA4(bitmap, tileId, x, y, drawWidth, drawHeight); } } }, { key: "drawTile", value: function drawTile(tileId, x, y, drawWidth, drawHeight) { if (tileId <= 0) { return; } if (Tilemap.isAutotile(tileId)) { return this.drawAutoTile(tileId, x, y, drawWidth, drawHeight); } return this.drawNormalTile(tileId, x, y, drawWidth, drawHeight); } }, { key: "drawAutoTilePieceTable", value: function drawAutoTilePieceTable(bitmap, tileX, tileY, x, y, drawWidth, drawHeight, pieceX, pieceY) { var halfWidth = CycloneMapEditor.tileWidth / 2; var halfHeight = CycloneMapEditor.tileHeight / 2; var realDrawWidth = drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth; var realDrawHeight = drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight; var sourceX = tileX * CycloneMapEditor.tileWidth + pieceX * halfWidth; var sourceY = tileY * CycloneMapEditor.tileHeight + pieceY * halfHeight; var targetX = x; var targetY = y; this.blt(bitmap, sourceX, sourceY, halfWidth, halfHeight, targetX, targetY, realDrawWidth, realDrawHeight); return bitmap; } }, { key: "drawTilePieceA1", value: function drawTilePieceA1(bitmap, tileId, x, y, drawWidth, drawHeight, pieceX, pieceY) { var tileX = 0; var tileY = 0; var kind = Tilemap.getAutotileKind(tileId); switch (kind) { case 0: tileX = 0; tileY = 0; break; case 1: tileX = 0; tileY = 3; break; case 2: tileX = 6; tileY = 0; break; case 3: tileX = 6; tileY = 3; break; default: tileX = Math.floor(kind % 8 / 4) * 8; tileY = Math.floor(kind / 8) * 6 + Math.floor(kind % 8 / 2) % 2 * 3; if (kind % 2 === 1) { tileX += 6; } break; } return this.drawAutoTilePieceTable(bitmap, tileX, tileY, x, y, drawWidth, drawHeight, pieceX, pieceY); } }, { key: "drawTilePieceA2", value: function drawTilePieceA2(bitmap, tileId, x, y, drawWidth, drawHeight, pieceX, pieceY) { var kind = Tilemap.getAutotileKind(tileId); var tileX = kind % 8 * 2; var tileY = (Math.floor(kind / 8) - 2) * 3; return this.drawAutoTilePieceTable(bitmap, tileX, tileY, x, y, drawWidth, drawHeight, pieceX, pieceY); } }, { key: "drawPuzzlePiece", value: function drawPuzzlePiece(pieceId, x, y, drawWidth, drawHeight) { if (pieceId <= 0) { return; } if (!Tilemap.isAutotile(pieceId)) { return; } var kind = Tilemap.getAutotileKind(pieceId); var tileId = Tilemap.makeAutotileId(kind, 0); var bitmap = CycloneMapEditor.loadTilesetBitmap(tileId); if (!bitmap) { return; } var pieceShape = pieceId - tileId; var pieceX = pieceShape % 4; var pieceY = Math.floor(pieceShape / 4); if (Tilemap.isTileA1(tileId)) { return this.drawTilePieceA1(bitmap, tileId, x, y, drawWidth, drawHeight, pieceX, pieceY); } if (Tilemap.isTileA2(tileId)) { return this.drawTilePieceA2(bitmap, tileId, x, y, drawWidth, drawHeight, pieceX, pieceY); } } }, { key: "drawIcon", value: function drawIcon(iconIndex, x, y, drawWidth, drawHeight) { var bitmap = ImageManager.loadSystem('IconSet'); var pw = ImageManager.iconWidth; var ph = ImageManager.iconHeight; var sx = iconIndex % 16 * pw; var sy = Math.floor(iconIndex / 16) * ph; var realDrawWidth = drawWidth !== null && drawWidth !== void 0 ? drawWidth : pw; var realDrawHeight = drawHeight !== null && drawHeight !== void 0 ? drawHeight : ph; this.blt(bitmap, sx, sy, pw, ph, x, y, realDrawWidth, realDrawHeight); } }, { key: "drawRegion", value: function drawRegion(regionId, x, y, drawWidth, drawHeight) { var _CycloneMapEditor$reg; var stretchIcon = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false; var realDrawWidth = drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth; var realDrawHeight = drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight; if (regionId > 0) { var color = regionColors[regionId % regionColors.length]; this.fillRect(x, y, realDrawWidth, realDrawHeight, "".concat(color, "66")); } var iconIndex = (_CycloneMapEditor$reg = CycloneMapEditor.regionIcons.get(regionId)) !== null && _CycloneMapEditor$reg !== void 0 ? _CycloneMapEditor$reg : 0; if (iconIndex) { var _ImageManager = ImageManager, iconWidth = _ImageManager.iconWidth, iconHeight = _ImageManager.iconHeight; var diffX = (realDrawWidth - iconWidth) / 2; var diffY = (realDrawHeight - iconHeight) / 2; var iconDrawWidth = stretchIcon ? realDrawWidth : iconWidth; var iconDrawHeight = stretchIcon ? realDrawHeight : iconHeight; var iconX = stretchIcon ? x : x + diffX; var iconY = stretchIcon ? y : y + diffY; this.drawIcon(iconIndex, iconX, iconY, iconDrawWidth, iconDrawHeight); } else { this.drawText(regionId, x, y, realDrawWidth, realDrawHeight, 'center'); } } }, { key: "drawShadow", value: function drawShadow(shadowId, x, y, drawWidth, drawHeight) { var halfWidth = (drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth) / 2; var halfHeight = (drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight) / 2; if (shadowId <= 0 || shadowId > 15) { return; } var table = shadowId.toString(2).padZero(4); for (var i = 0; i < 4; i++) { if (table[3 - i] !== '1') { continue; } var drawX = x + i % 2 * halfWidth; var drawY = y + Math.floor(i / 2) * halfHeight; this.fillRect(drawX, drawY, halfWidth, halfHeight, '#00000066'); } } }, { key: "drawCollisionType", value: function drawCollisionType(collision, x, y, drawWidth, drawHeight) { if (collision === 0) { return; } var realDrawWidth = drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth; var realDrawHeight = drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight; var colorIndex = collision <= 3 ? collision - 1 : 0; var context = this.context; context.save(); var color = ['#00FF00', '#FF0000', '#FF00FF'][colorIndex]; context.fillStyle = color; context.fillRect(x, y, realDrawWidth, realDrawHeight); var goesUp = false; var goesDown = false; var goesLeft = false; var goesRight = false; if (collision >= 20) { var unblockedDirection = collision - 20; goesUp = !DirectionHelper.goesUp(unblockedDirection); goesDown = !DirectionHelper.goesDown(unblockedDirection); goesLeft = !DirectionHelper.goesLeft(unblockedDirection); goesRight = !DirectionHelper.goesRight(unblockedDirection); } else if (collision > 10) { var blockedDirection = collision - 10; goesUp = DirectionHelper.goesUp(blockedDirection); goesDown = DirectionHelper.goesDown(blockedDirection); goesLeft = DirectionHelper.goesLeft(blockedDirection); goesRight = DirectionHelper.goesRight(blockedDirection); } else if (collision === 4) { goesDown = true; goesUp = true; } else if (collision === 5) { goesLeft = true; goesRight = true; } if (collision > 3) { var pieceWidth = Math.floor(realDrawWidth / 4); var pieceHeight = Math.floor(realDrawHeight / 4); context.fillStyle = '#FF00FF'; if (goesUp) { context.fillRect(x, y, realDrawWidth, pieceHeight); } if (goesDown) { context.fillRect(x, y + realDrawHeight - pieceHeight, realDrawWidth, pieceHeight); } if (goesLeft) { context.fillRect(x, y, pieceWidth, realDrawHeight); } if (goesRight) { context.fillRect(x + realDrawWidth - pieceWidth, y, pieceWidth, realDrawHeight); } } context.strokeStyle = '#000000'; context.beginPath(); context.moveTo(x, y); context.lineTo(x + realDrawWidth, y); context.stroke(); context.beginPath(); context.moveTo(x, y); context.lineTo(x, y + realDrawHeight); context.stroke(); } }]); return _class4; }(); }); CycloneMapEditor.patchClass(DataManager, function ($super) { return /*#__PURE__*/function () { function _class5() { _classCallCheck(this, _class5); } _createClass(_class5, null, [{ key: "loadMapData", value: function loadMapData(mapId) { if (mapId > 0 && CycloneMapEditor.mapCaches[mapId]) { globalThis.$dataMap = CycloneMapEditor.mapCaches[mapId]; this.onLoad('$dataMap'); return; } return $super.loadMapData.call(this, mapId); } }]); return _class5; }(); }); CycloneMapEditor.patchClass(Game_Map, function ($super) { return /*#__PURE__*/function () { function _class6() { _classCallCheck(this, _class6); } _createClass(_class6, [{ key: "screenTileX", value: function screenTileX() { if (!CycloneMapEditor.active) { return $super.screenTileX.call(this); } return (Graphics.width - CycloneMapEditor.windowWidth) / this.tileWidth(); } }, { key: "screenTileY", value: function screenTileY() { if (!CycloneMapEditor.active) { return $super.screenTileY.call(this); } return (Graphics.height - 40) / this.tileHeight(); } }, { key: "regionId", value: function regionId(x, y) { if (CycloneMapEditor.active) { return CycloneMapEditor.getCurrentTileAtPosition(x, y, 5, false); } return $super.regionId.call(this, x, y); } }, { key: "isLoopHorizontal", value: function isLoopHorizontal() { if (CycloneMapEditor.active) { return false; } return $super.isLoopHorizontal.call(this); } }, { key: "isLoopVertical", value: function isLoopVertical() { if (CycloneMapEditor.active) { return false; } return $super.isLoopVertical.call(this); } }, { key: "canvasToMapX", value: function canvasToMapX(x) { if (!CycloneMapEditor.active || CycloneMapEditor.currentZoom === 1) { return $super.canvasToMapX.call(this, x); } var tileWidth = this.tileWidth() * CycloneMapEditor.currentZoom; var originX = this._displayX * tileWidth; var mapX = Math.floor((originX + x) / tileWidth); return this.roundX(mapX); } }, { key: "canvasToMapY", value: function canvasToMapY(y) { if (!CycloneMapEditor.active || CycloneMapEditor.currentZoom === 1) { return $super.canvasToMapY.call(this, y); } var tileHeight = this.tileHeight() * CycloneMapEditor.currentZoom; var originY = this._displayY * tileHeight; var mapY = Math.floor((originY + y) / tileHeight); return this.roundY(mapY); } }, { key: "scrollDown", value: function scrollDown(distance) { if (!CycloneMapEditor.active) { return $super.scrollDown.call(this, distance); } var extraTiles = Math.ceil(Graphics.height / this.tileHeight()) - 3; var lastY = this._displayY; this._displayY = Math.min(this._displayY + distance, this.height() - this.screenTileY() + extraTiles); this._parallaxY += this._displayY - lastY; } }, { key: "scrollLeft", value: function scrollLeft(distance) { if (!CycloneMapEditor.active) { return $super.scrollLeft.call(this, distance); } var extraTiles = Math.ceil(Graphics.width / this.tileWidth()) - 3; var lastX = this._displayX; this._displayX = Math.max(this._displayX - distance, -extraTiles); this._parallaxX += this._displayX - lastX; } }, { key: "scrollRight", value: function scrollRight(distance) { if (!CycloneMapEditor.active) { return $super.scrollRight.call(this, distance); } var extraTiles = Math.ceil(Graphics.width / this.tileWidth()) - 5; var lastX = this._displayX; this._displayX = Math.min(this._displayX + distance, this.width() - this.screenTileX() + extraTiles); this._parallaxX += this._displayX - lastX; } }, { key: "scrollUp", value: function scrollUp(distance) { if (!CycloneMapEditor.active) { return $super.scrollUp.call(this, distance); } var extraTiles = Math.ceil(Graphics.height / this.tileHeight()) - 3; var lastY = this._displayY; this._displayY = Math.max(this._displayY - distance, -extraTiles); this._parallaxY += this._displayY - lastY; } }, { key: "checkTileIdPassage", value: function checkTileIdPassage(tileId, d) { var flags = this.tilesetFlags(); var flag = flags[tileId]; return this.getPassageBitType(flag, d); } }, { key: "getPassageBitType", value: function getPassageBitType(flag, d) { var bit = 1 << d / 2 - 1 & 0x0f; if ((flag & bit) === 0) { // [o] Passable return true; } if ((flag & bit) === bit) { // [x] Impassable return false; } } }, { key: "getTileFlag", value: function getTileFlag(tileId) { var flags = this.tilesetFlags(); return flags[tileId]; } }, { key: "checkTileIdPassageType", value: function checkTileIdPassageType(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; if ((flag & 0x10) !== 0) { if (tileId < Tilemap.TILE_ID_A1) { return TilePassageType.star; } return TilePassageType.free; } var top = this.getPassageBitType(flag, 8); var bottom = this.getPassageBitType(flag, 2); var left = this.getPassageBitType(flag, 4); var right = this.getPassageBitType(flag, 6); if (top === false && bottom === false && left === false && right === false) { return TilePassageType.blocked; } return TilePassageType.free; } }, { key: "tileIdIsBush", value: function tileIdIsBush(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; return (flag & 0x40) !== 0; } }, { key: "tileIdIsLadder", value: function tileIdIsLadder(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; return (flag & 0x20) !== 0; } }, { key: "tileIdIsCounter", value: function tileIdIsCounter(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; return (flag & 0x80) !== 0; } }, { key: "tileIdIsDamage", value: function tileIdIsDamage(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; return (flag & 0x100) !== 0; } }, { key: "tileIdTerrainTag", value: function tileIdTerrainTag(tileId) { var flags = this.tilesetFlags(); var flag = flags[tileId]; var tag = flag >> 12; if (tag > 0) { return tag; } return 0; } }]); return _class6; }(); }); CycloneMapEditor.patchClass(Game_Player, function ($super) { return /*#__PURE__*/function () { function _class7() { _classCallCheck(this, _class7); } _createClass(_class7, [{ key: "centerX", value: function centerX() { if (!CycloneMapEditor.active) { return $super.centerX.call(this); } return ((Graphics.width - CycloneMapEditor.windowWidth) / $gameMap.tileWidth() - 1) / 2.0; } }, { key: "centerY", value: function centerY() { if (!CycloneMapEditor.active) { return $super.centerY.call(this); } return ((Graphics.height - 40) / $gameMap.tileHeight() - 1) / 2.0; } }, { key: "reserveTransfer", value: function reserveTransfer(mapId) { var _$super$reserveTransf; if (CycloneMapEditor.changeHistory.length > 0) { if (confirm('Do you want to save your map before teleporting away?')) { CycloneMapEditor._doSave(); } } for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) { args[_key4 - 1] = arguments[_key4]; } (_$super$reserveTransf = $super.reserveTransfer).call.apply(_$super$reserveTransf, [this, mapId].concat(args)); } }, { key: "executeEncounter", value: function executeEncounter() { var result = $super.executeEncounter.call(this); if (result) { if (CycloneMapEditor.changeHistory.length > 0) { if (confirm('Do you want to save your map before the battle starts?')) { CycloneMapEditor._doSave(); } } } return result; } }, { key: "updateMove", value: function updateMove() { $super.updateMove.call(this); CycloneMapEditor.requestCollisionRefresh(); } }]); return _class7; }(); }); var WindowCycloneGrid = /*#__PURE__*/function (_Window_Base) { _inherits(WindowCycloneGrid, _Window_Base); var _super4 = _createSuper(WindowCycloneGrid); function WindowCycloneGrid() { _classCallCheck(this, WindowCycloneGrid); return _super4.apply(this, arguments); } _createClass(WindowCycloneGrid, [{ key: "initialize", value: function initialize() { var width = Graphics.width; var height = Graphics.height; var rect = new Rectangle(0, 0, width, height); _get(_getPrototypeOf(WindowCycloneGrid.prototype), "initialize", this).call(this, rect); this.padding = 0; this.refresh(); this.opacity = 0; this.backOpacity = 0; this.hide(); this.deactivate(); } }, { key: "createContents", value: function createContents() { this._padding = 0; _get(_getPrototypeOf(WindowCycloneGrid.prototype), "createContents", this).call(this); } }, { key: "drawCellGrid", value: function drawCellGrid(x, y) { if (!CycloneMapEditor.showGrid) { return; } var gridRatio = CycloneMapEditor.getGridRatio(true); var drawWidth = Math.floor(CycloneMapEditor.tileWidth * CycloneMapEditor.currentZoom) / gridRatio; var drawHeight = Math.floor(CycloneMapEditor.tileHeight * CycloneMapEditor.currentZoom) / gridRatio; var context = this.contents.context; context.strokeStyle = '#666666'; for (var cellX = 0; cellX < gridRatio; cellX++) { for (var cellY = 0; cellY < gridRatio; cellY++) { var drawX = x + cellX * drawWidth; var drawY = y + cellY * drawHeight; context.strokeRect(drawX, drawY, drawWidth, drawHeight); } } context.stroke(); } }, { key: "maybeDrawRegions", value: function maybeDrawRegions(x, y) { if (!CycloneMapEditor.isLayerVisible(Layers.regions)) { return; } if (CycloneMapEditor.isLayerVisible(Layers.tags)) { return; } var mapX = $gameMap.canvasToMapX(x); var mapY = $gameMap.canvasToMapY(y); var regionId = $gameMap.regionId(mapX, mapY); if (regionId > 0) { this.contents.drawRegion(regionId, x, y); } } }, { key: "checkTilePassability", value: function checkTilePassability(x, y, d) { return $gameMap.isPassable(x, y, d); } }, { key: "drawTilesetCollision", value: function drawTilesetCollision(x, y) { var mapX = $gameMap.canvasToMapX(x); var mapY = $gameMap.canvasToMapY(y); var drawWidth = CycloneMapEditor.tileWidth; var drawHeight = CycloneMapEditor.tileHeight; var downBlocked = !this.checkTilePassability(mapX, mapY, 2); var upBlocked = !this.checkTilePassability(mapX, mapY, 8); var leftBlocked = !this.checkTilePassability(mapX, mapY, 4); var rightBlocked = !this.checkTilePassability(mapX, mapY, 6); var same = downBlocked === upBlocked && downBlocked === leftBlocked && downBlocked === rightBlocked; if (downBlocked && same) { this.contents.fillRect(x, y, drawWidth, drawHeight, '#FF000033'); return; } var sideHeight = 2; var sideWidth = 2; this.contents.fillRect(x, y, drawWidth, drawHeight, '#00FF0033'); if (downBlocked) { this.contents.fillRect(x, y + drawHeight - sideHeight, drawWidth, sideHeight, '#FF00FFAA'); } if (upBlocked) { this.contents.fillRect(x, y, drawWidth, sideHeight, '#FF00FFAA'); } if (leftBlocked) { this.contents.fillRect(x, y, sideWidth, drawHeight, '#FF00FFAA'); } if (rightBlocked) { this.contents.fillRect(x + drawWidth - sideWidth, y, sideWidth, drawHeight, '#FF00FFAA'); } } }, { key: "drawCustomCollision", value: function drawCustomCollision(x, y) { var mapX = CycloneMapEditor.canvasToMapX(x); var mapY = CycloneMapEditor.canvasToMapY(y); var customCollisionTable = CycloneMapEditor.customCollisionTable; var height = $gameMap.height() * 4; var width = $gameMap.width() * 4; var tileWidth = CycloneMapEditor.tileWidth; var tileHeight = CycloneMapEditor.tileHeight; var drawWidth = tileWidth / 4; var drawHeight = tileHeight / 4; var colors = ['#00FF00AA', '#FF0000AA', '#FF00FFFF']; var context = this.contents.context; context.save(); var drawCustomSideCollisions = function drawCustomSideCollisions(goesUp, goesDown, goesLeft, goesRight, drawX, drawY) { context.fillStyle = colors[2]; var pieceWidth = Math.floor(drawWidth / 4); var pieceHeight = Math.floor(drawHeight / 4); if (goesUp) { context.fillRect(drawX, drawY, drawWidth, pieceHeight); } if (goesDown) { context.fillRect(drawX, drawY + drawHeight - pieceHeight, drawWidth, pieceHeight); } if (goesLeft) { context.fillRect(drawX, drawY, pieceWidth, drawHeight); } if (goesRight) { context.fillRect(drawX + drawWidth - pieceWidth, drawY, pieceWidth, drawHeight); } }; for (var cellX = 0; cellX < 4; cellX++) { for (var cellY = 0; cellY < 4; cellY++) { var intX = Math.floor(mapX * 4) + cellX; var intY = Math.floor(mapY * 4) + cellY; var index = intY % height * width + intX % width; if (customCollisionTable[index]) { var drawX = x + cellX * drawWidth; var drawY = y + cellY * drawHeight; context.clearRect(drawX, drawY, drawWidth, drawHeight); var collision = customCollisionTable[index]; var colorIndex = collision <= 3 ? collision - 1 : 0; var color = colors[colorIndex]; context.fillStyle = color; context.fillRect(drawX, drawY, drawWidth, drawHeight); var goesUp = false; var goesDown = false; var goesLeft = false; var goesRight = false; if (collision >= 20) { var d = collision - 20; goesUp = !DirectionHelper.goesUp(d); goesDown = !DirectionHelper.goesDown(d); goesLeft = !DirectionHelper.goesLeft(d); goesRight = !DirectionHelper.goesRight(d); } else if (collision > 10) { var _d2 = collision - 10; goesUp = DirectionHelper.goesUp(_d2); goesDown = DirectionHelper.goesDown(_d2); goesLeft = DirectionHelper.goesLeft(_d2); goesRight = DirectionHelper.goesRight(_d2); } else if (collision === 4) { goesUp = true; goesDown = true; } else if (collision === 5) { goesLeft = true; goesRight = true; } if (collision > 3) { drawCustomSideCollisions(goesUp, goesDown, goesLeft, goesRight, drawX, drawY); } } } } context.restore(); this.contents._baseTexture.update(); } }, { key: "maybeDrawCollisions", value: function maybeDrawCollisions(x, y) { if (!CycloneMapEditor.isLayerVisible(Layers.collisions)) { return; } this.drawTilesetCollision(x, y); this.drawCustomCollision(x, y); } }, { key: "maybeDrawTags", value: function maybeDrawTags(x, y) { if (!CycloneMapEditor.isLayerVisible(Layers.tags)) { return; } var mapX = $gameMap.canvasToMapX(x); var mapY = $gameMap.canvasToMapY(y); var terrainTag = $gameMap.terrainTag(mapX, mapY); if (terrainTag === 0) { return; } var drawWidth = CycloneMapEditor.tileWidth; var drawHeight = CycloneMapEditor.tileHeight; this.contents.drawText(terrainTag, x, y, drawWidth, drawHeight, 'center'); } }, { key: "drawCell", value: function drawCell(x, y) { var mapX = $gameMap.canvasToMapX(x); var mapY = $gameMap.canvasToMapY(y); if (!$gameMap.isValid(mapX, mapY)) { return false; } this.maybeDrawCollisions(x, y); this.maybeDrawRegions(x, y); this.maybeDrawTags(x, y); this.drawCellGrid(x, y); } }, { key: "refresh", value: function refresh() { this.contents.clear(); this._lastDisplayX = $gameMap._displayX; this._lastDisplayY = $gameMap._displayY; var drawWidth = Math.floor(CycloneMapEditor.tileWidth * CycloneMapEditor.currentZoom); var drawHeight = Math.floor(CycloneMapEditor.tileHeight * CycloneMapEditor.currentZoom); var paddingX; var paddingY; if ($gameMap._displayX < 0) { paddingX = Math.floor($gameMap._displayX * CycloneMapEditor.tileWidth); } else { paddingX = Math.floor(($gameMap._displayX - Math.floor($gameMap._displayX)) * drawWidth); } if ($gameMap._displayY < 0) { paddingY = Math.floor($gameMap._displayY * CycloneMapEditor.tileHeight); } else { paddingY = Math.floor(($gameMap._displayY - Math.floor($gameMap._displayY)) * drawHeight); } var mapStartX = 0 - paddingX; var mapStartY = 0 - paddingY; var mapEndX = mapStartX + $gameMap.width() * drawWidth; var mapEndY = mapStartY + $gameMap.height() * drawHeight; var rightPos = Math.min(Graphics.width, mapEndX); var bottomPos = Math.min(Graphics.height, mapEndY); for (var _x12 = mapStartX; _x12 < rightPos; _x12 += drawWidth) { if (_x12 + drawWidth < 0) { continue; } for (var y = mapStartY; y < bottomPos; y += drawHeight) { if (y + drawHeight < 0) { continue; } this.drawCell(_x12, y); } } if (CycloneMapEditor.isLayerVisible(Layers.collisions)) { this.drawEventsCollision(); this.drawPlayerCollision(); } } }, { key: "drawEventsCollision", value: function drawEventsCollision() { var drawWidth = $gameMap.tileWidth(); var drawHeight = $gameMap.tileHeight(); var cycloneMovement = window.CycloneMovement && window.CycloneMovement.params.applyToEvents; var _iterator18 = _createForOfIteratorHelper($gameMap._events), _step18; try { for (_iterator18.s(); !(_step18 = _iterator18.n()).done;) { var event = _step18.value; if (!event) { continue; } if (event._priorityType !== 1 || event._through || event._erased) { continue; } if (cycloneMovement) { this.drawCycloneMovementCollision(event, '#FF00FF66'); continue; } var _x13 = event.x * $gameMap.tileWidth(); var y = event.y * $gameMap.tileHeight(); var drawX = _x13 - $gameMap._displayX * $gameMap.tileWidth(); var drawY = y - $gameMap._displayY * $gameMap.tileHeight(); if (drawX + drawWidth < 0 || drawY + drawHeight < 0) { continue; } this.contents.fillRect(drawX, drawY, drawWidth, drawHeight, '#FF00FF66'); } } catch (err) { _iterator18.e(err); } finally { _iterator18.f(); } } }, { key: "drawPlayerCollision", value: function drawPlayerCollision() { if (window.CycloneMovement) { return this.drawCycloneMovementPlayerCollision(); } var x = $gamePlayer.x * $gameMap.tileWidth(); var y = $gamePlayer.y * $gameMap.tileHeight(); var drawWidth = $gameMap.tileWidth(); var drawHeight = $gameMap.tileHeight(); var drawX = x - $gameMap._displayX * $gameMap.tileWidth(); var drawY = y - $gameMap._displayY * $gameMap.tileHeight(); if (drawX + drawWidth < 0 || drawY + drawHeight < 0) { return; } this.contents.fillRect(drawX, drawY, drawWidth, drawHeight, '#0000FF66'); } }, { key: "drawCycloneMovementPlayerCollision", value: function drawCycloneMovementPlayerCollision() { this.drawCycloneMovementCollision($gamePlayer, '#0000FF66'); } }, { key: "drawCycloneMovementCollision", value: function drawCycloneMovementCollision(object, color) { var top = object.top, left = object.left, width = object.width, height = object.height; var x = left * $gameMap.tileWidth(); var y = top * $gameMap.tileHeight(); var drawWidth = width * $gameMap.tileWidth(); var drawHeight = height * $gameMap.tileHeight(); var drawX = x - $gameMap._displayX * $gameMap.tileWidth(); var drawY = y - $gameMap._displayY * $gameMap.tileHeight(); if (drawX + drawWidth < 0 || drawY + drawHeight < 0) { return; } this.contents.fillRect(drawX, drawY, drawWidth, drawHeight, color); } }, { key: "update", value: function update() { if (!CycloneMapEditor.active) { return; } if (this._lastDisplayX !== $gameMap._displayX || this._lastDisplayY !== $gameMap._displayY) { this.refresh(); } } }, { key: "requestRefresh", value: function requestRefresh() { this._lastDisplayX = -999; } }]); return WindowCycloneGrid; }(Window_Base); var pencilIcon = new Image(); pencilIcon.src = ''; var lineIcon = new Image(); lineIcon.src = ''; var rectangleIcon = new Image(); rectangleIcon.src = ''; var fillIcon = new Image(); fillIcon.src = ''; var eraseIcon = new Image(); eraseIcon.src = ''; var saveIcon = new Image(); saveIcon.src = ''; var reloadIcon = new Image(); reloadIcon.src = ''; var undoIcon = new Image(); undoIcon.src = ''; var redoIcon = new Image(); redoIcon.src = ''; var WindowCycloneMapEditorCommands = /*#__PURE__*/function (_Window_Command) { _inherits(WindowCycloneMapEditorCommands, _Window_Command); var _super5 = _createSuper(WindowCycloneMapEditorCommands); function WindowCycloneMapEditorCommands() { _classCallCheck(this, WindowCycloneMapEditorCommands); return _super5.apply(this, arguments); } _createClass(WindowCycloneMapEditorCommands, [{ key: "initialize", value: function initialize() { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = 0; var w = CycloneMapEditor.windowWidth; var h = CycloneMapEditor.tileDrawWidth >= 48 && Graphics.width >= 1280 ? 74 : 50; _get(_getPrototypeOf(WindowCycloneMapEditorCommands.prototype), "initialize", this).call(this, new Rectangle(x, y, w, h)); this.showBackgroundDimmer(); this.configureHandlers(); } }, { key: "configureHandlers", value: function configureHandlers() { var _this20 = this; this.setHandler('undo', function () { CycloneMapEditor.undoButton(); _this20.activate(); }); this.setHandler('redo', function () { CycloneMapEditor.redoButton(); _this20.activate(); }); this.setHandler('pencil', function () { CycloneMapEditor.pencilButton(); _this20.activate(); }); this.setHandler('rectangle', function () { CycloneMapEditor.rectangleButton(); _this20.activate(); }); this.setHandler('fill', function () { CycloneMapEditor.fillButton(); _this20.activate(); }); this.setHandler('eraser', function () { CycloneMapEditor.eraserButton(); _this20.activate(); }); this.setHandler('save', function () { CycloneMapEditor.saveButton(); _this20.activate(); }); this.setHandler('reload', function () { CycloneMapEditor.reloadButton(); _this20.activate(); }); } }, { key: "maxScrollY", value: function maxScrollY() { return 0; } }, { key: "maxScrollX", value: function maxScrollX() { return 0; } }, { key: "processCursorMove", value: function processCursorMove() {} }, { key: "processHandling", value: function processHandling() {} }, { key: "updateBackOpacity", value: function updateBackOpacity() { this.backOpacity = 255; } }, { key: "_updateCursor", value: function _updateCursor() { this._cursorSprite.visible = false; } }, { key: "makeCommandList", value: function makeCommandList() { this.addCommand('Undo', 'undo'); this.addCommand('Redo', 'redo'); this.addCommand('', ''); this.addCommand('Pen', 'pencil'); this.addCommand('Rect', 'rectangle'); this.addCommand('Fill', 'fill'); this.addCommand('Erase', 'eraser'); } }, { key: "colSpacing", value: function colSpacing() { return 6; } }, { key: "rowSpacing", value: function rowSpacing() { return 0; } }, { key: "maxCols", value: function maxCols() { return 7; } }, { key: "redraw", value: function redraw() { Window_Selectable.prototype.refresh.call(this); } }, { key: "getSymbolIcon", value: function getSymbolIcon(symbol) { switch (symbol) { case 'undo': return undoIcon; case 'redo': return redoIcon; case Tools.pencil: return pencilIcon; case Tools.rectangle: return rectangleIcon; case Tools.fill: return fillIcon; case Tools.eraser: return eraseIcon; case 'save': return saveIcon; case 'reload': return reloadIcon; } } }, { key: "itemRect", value: function itemRect(index) { var rect = _get(_getPrototypeOf(WindowCycloneMapEditorCommands.prototype), "itemRect", this).call(this, index); if (Graphics.width < 1280) { rect.width += 3; } return rect; } }, { key: "lineHeight", value: function lineHeight() { if (Graphics.width >= 1280) { if (CycloneMapEditor.tileDrawWidth < 48) { return 14; } return 36; } return 14; } }, { key: "drawItem", value: function drawItem(index) { var symbol = this.commandSymbol(index); var rect = this.itemRect(index); if (CycloneMapEditor.changingTileProps && ['undo', 'redo'].includes(symbol)) { return; } if (CycloneMapEditor.currentLayer === Layers.blend) { if (symbol === Tools.fill) { return; } } else if (CycloneMapEditor.puzzleMode) { if ([Tools.rectangle, Tools.fill].includes(symbol)) { return; } } if (symbol === CycloneMapEditor.currentTool) { this.contents.fillRect(rect.x, rect.y + 2, rect.width, rect.height, '#00FF0066'); this.contents.fillRect(rect.x - 2, rect.y, rect.width + 4, 4, '#000000'); this.contents.fillRect(rect.x - 2, rect.y + 2 + rect.height, rect.width + 6, 4, '#000000'); this.contents.fillRect(rect.x - 2, rect.y, 4, rect.height + 4, '#000000'); this.contents.fillRect(rect.x + rect.width, rect.y, 4, rect.height + 4, '#000000'); this.contents.fillRect(rect.x, rect.y + 2, rect.width, 2, '#FFFFFF'); this.contents.fillRect(rect.x, rect.y + 2 + rect.height, rect.width + 2, 2, '#FFFFFF'); this.contents.fillRect(rect.x, rect.y + 2, 2, rect.height, '#FFFFFF'); this.contents.fillRect(rect.x + rect.width, rect.y + 2, 2, rect.height, '#FFFFFF'); } var icon = this.getSymbolIcon(symbol); if (!icon) { return _get(_getPrototypeOf(WindowCycloneMapEditorCommands.prototype), "drawItem", this).call(this, index); } this.resetTextColor(); if (symbol === 'undo') { this.changePaintOpacity(CycloneMapEditor.changeHistory.length > 0); } else if (symbol === 'redo') { this.changePaintOpacity(CycloneMapEditor.undoHistory.length > 0); } else { this.changePaintOpacity(true); } var ctx = this.contents._canvas.getContext('2d'); ctx.imageSmoothingEnabled = false; var iconWidth = CycloneMapEditor.tileDrawWidth >= 48 && Graphics.width >= 1280 ? 48 : 24; ctx.drawImage(icon, rect.x + 1, rect.y, iconWidth, iconWidth); } }, { key: "drawAllItems", value: function drawAllItems() { _get(_getPrototypeOf(WindowCycloneMapEditorCommands.prototype), "drawAllItems", this).call(this); } }, { key: "playCursorSound", value: function playCursorSound() {} }, { key: "playOkSound", value: function playOkSound() {} }, { key: "playBuzzerSound", value: function playBuzzerSound() {} }]); return WindowCycloneMapEditorCommands; }(Window_Command); var hiddenIcon = new Image(); hiddenIcon.src = ''; var visibleIcon = new Image(); visibleIcon.src = ''; var WindowCycloneMapEditorLayerList = /*#__PURE__*/function (_Window_Base2) { _inherits(WindowCycloneMapEditorLayerList, _Window_Base2); var _super6 = _createSuper(WindowCycloneMapEditorLayerList); function WindowCycloneMapEditorLayerList() { _classCallCheck(this, WindowCycloneMapEditorLayerList); return _super6.apply(this, arguments); } _createClass(WindowCycloneMapEditorLayerList, [{ key: "initialize", value: function initialize() { var x = 0; var w = 180; var y = 0; var h = Graphics.height - 40; _get(_getPrototypeOf(WindowCycloneMapEditorLayerList.prototype), "initialize", this).call(this, new Rectangle(x, y, w, h)); this.showBackgroundDimmer(); } }, { key: "update", value: function update() { _get(_getPrototypeOf(WindowCycloneMapEditorLayerList.prototype), "update", this).call(this); } }, { key: "updateBackOpacity", value: function updateBackOpacity() { this.backOpacity = 255; } }, { key: "refresh", value: function refresh() { this.drawContents(); SceneManager._scene.redrawMap(); } }, { key: "drawContents", value: function drawContents() { this.contents.clear(); var ctx = this.contents._canvas.getContext('2d'); var names = ['Auto Layer', 'Layer 1', 'Layer 2', 'Layer 3', 'Layer 4', 'Shadows', 'Regions', 'Events']; this.contents.fontSize = 22; ctx.imageSmoothingEnabled = false; for (var i = 0; i < 8; i++) { var layerIndex = i === 0 ? Layers.auto : i - 1; this.contents.fontBold = CycloneMapEditor.currentLayer === layerIndex; this.changeTextColor(CycloneMapEditor.currentLayer === layerIndex ? ColorManager.powerUpColor() : ColorManager.normalColor()); if (layerIndex !== Layers.auto) { ctx.drawImage(CycloneMapEditor.layerVisibility[layerIndex] ? visibleIcon : hiddenIcon, -4, 30 * i - 4, 48, 48); this.drawText(names[i], 40, i * 30, this.contents.width - 40, 'left'); } else { this.drawText(names[i], 10, i * 30, this.contents.width - 10, 'left'); } } } }, { key: "toggleLayerVisibility", value: function toggleLayerVisibility(layerIndex) { CycloneMapEditor.layerVisibility[layerIndex] = !CycloneMapEditor.layerVisibility[layerIndex]; this.refresh(); SceneManager._scene._mapEditorGrid.refresh(); } }, { key: "getLayerIndex", value: function getLayerIndex(y) { var padding = this.padding + 10; if (y < padding || y > this.height - padding + 6) { return -1; } var layerIndex = Math.floor((y - padding) / 30); if (y > padding + layerIndex * 30 + 22) { return -1; } if (layerIndex > CycloneMapEditor.layerVisibility.length) { return -1; } if (layerIndex === 0) { return Layers.auto; } return layerIndex - 1; } }, { key: "onMapTouch", value: function onMapTouch(x, y) { var layerIndex = this.getLayerIndex(y); if (layerIndex < 0) { return; } if (x >= CycloneMapEditor.windowWidth / 2) { x -= CycloneMapEditor.windowWidth / 2; layerIndex += 4; } if (x < 50 && layerIndex < 7) { this.toggleLayerVisibility(layerIndex); return; } CycloneMapEditor.changeCurrentLayer(layerIndex); this.refresh(); } }]); return WindowCycloneMapEditorLayerList; }(Window_Base); var WindowCycloneMapEditorStatus = /*#__PURE__*/function (_Window_Base3) { _inherits(WindowCycloneMapEditorStatus, _Window_Base3); var _super7 = _createSuper(WindowCycloneMapEditorStatus); function WindowCycloneMapEditorStatus() { _classCallCheck(this, WindowCycloneMapEditorStatus); return _super7.apply(this, arguments); } _createClass(WindowCycloneMapEditorStatus, [{ key: "initialize", value: function initialize() { var h = 40; _get(_getPrototypeOf(WindowCycloneMapEditorStatus.prototype), "initialize", this).call(this, new Rectangle(0, Graphics.height - h, Graphics.width, h)); this.showBackgroundDimmer(); } }, { key: "createContents", value: function createContents() { this._padding = 0; _get(_getPrototypeOf(WindowCycloneMapEditorStatus.prototype), "createContents", this).call(this); } }, { key: "updateBackOpacity", value: function updateBackOpacity() { this.backOpacity = 255; } }, { key: "refresh", value: function refresh() { this.drawContents(); } }, { key: "lineHeight", value: function lineHeight() { return 16; } }, { key: "makeLine", value: function makeLine() { var line = ''; var addConditional = function addConditional(paramName, newPart) { if (CycloneMapEditor.params[paramName]) { if (line && newPart) { return ", ".concat(newPart); } return newPart; } return ''; }; line += addConditional('showMapId', "Map: ".concat($gameMap._mapId)); line += addConditional('showTilesetId', "Tileset: ".concat($gameMap._tilesetId)); line += addConditional('showPosition', "Pos: ".concat(CycloneMapEditor.statusMapX, ", ").concat(CycloneMapEditor.statusMapY)); if (CycloneMapEditor.params.showCellTiles) { var _CycloneMapEditor = CycloneMapEditor, _statusTile = _CycloneMapEditor.statusTile1, _statusTile2 = _CycloneMapEditor.statusTile2, _statusTile3 = _CycloneMapEditor.statusTile3, _statusTile4 = _CycloneMapEditor.statusTile4; if (line) { line += ' - '; } line += "Tiles: (".concat(_statusTile, ", ").concat(_statusTile2, ", ").concat(_statusTile3, ", ").concat(_statusTile4, ")"); } line += addConditional('showRegionId', "Region: ".concat(CycloneMapEditor.statusRegion)); line += addConditional('showTag', "Tag: ".concat(CycloneMapEditor.statusTag)); line += addConditional('showCollision', "Collision: ".concat(CycloneMapEditor.statusCollision)); line += addConditional('showLadder', CycloneMapEditor.statusLadder ? ' Ladder' : ''); line += addConditional('showBush', CycloneMapEditor.statusBush ? ' Bush' : ''); line += addConditional('showCounter', CycloneMapEditor.statusCounter ? ' Counter' : ''); line += addConditional('showDamageFloor', CycloneMapEditor.statusDamage ? ' Damage' : ''); return line; } }, { key: "textY", value: function textY() { return 12; } }, { key: "drawMainLine", value: function drawMainLine() { var line = this.makeLine(); this.drawText(line, 8, this.textY(), this.width - 8, 'left'); } }, { key: "drawRightLine", value: function drawRightLine() { this.drawText("TileId: ".concat(CycloneMapEditor.statusTileId), 0, this.textY(), this.width - 8, 'right'); } }, { key: "drawContents", value: function drawContents() { this.contents.clear(); this.contents.fontSize = 16; this.drawMainLine(); this.drawRightLine(); } }]); return WindowCycloneMapEditorStatus; }(Window_Base); // import { Layers, Tools } from './constants'; var WindowCycloneMapEditorTabs = /*#__PURE__*/function (_Window_Command2) { _inherits(WindowCycloneMapEditorTabs, _Window_Command2); var _super8 = _createSuper(WindowCycloneMapEditorTabs); function WindowCycloneMapEditorTabs() { _classCallCheck(this, WindowCycloneMapEditorTabs); return _super8.apply(this, arguments); } _createClass(WindowCycloneMapEditorTabs, [{ key: "initialize", value: function initialize() { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = SceneManager._scene._mapEditorCommands.y + SceneManager._scene._mapEditorCommands.height; var w = CycloneMapEditor.windowWidth; var h = 74; _get(_getPrototypeOf(WindowCycloneMapEditorTabs.prototype), "initialize", this).call(this, new Rectangle(x, y, w, h)); this.showBackgroundDimmer(); this.configureHandlers(); } }, { key: "configureHandlers", value: function configureHandlers() { var _this21 = this; this.setHandler('a', function () { CycloneMapEditor.jumpToOneTileOf([Tilemap.TILE_ID_A1, Tilemap.TILE_ID_A2, Tilemap.TILE_ID_A3, Tilemap.TILE_ID_A4, Tilemap.TILE_ID_A5]); _this21.activate(); }); this.setHandler('b', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_B); _this21.activate(); }); this.setHandler('c', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_C); _this21.activate(); }); this.setHandler('d', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_D); _this21.activate(); }); this.setHandler('e', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_E); _this21.activate(); }); this.setHandler('f', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_E + 256); _this21.activate(); }); this.setHandler('g', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_E + 512); _this21.activate(); }); this.setHandler('h', function () { CycloneMapEditor.jumpToTile(Tilemap.TILE_ID_A5 + 256); _this21.activate(); }); } }, { key: "maxScrollY", value: function maxScrollY() { return 0; } }, { key: "maxScrollX", value: function maxScrollX() { return 0; } }, { key: "processCursorMove", value: function processCursorMove() {} }, { key: "processHandling", value: function processHandling() {} }, { key: "updateBackOpacity", value: function updateBackOpacity() { this.backOpacity = 255; } }, { key: "_updateCursor", value: function _updateCursor() { this._cursorSprite.visible = false; } }, { key: "makeCommandList", value: function makeCommandList() { this.addCommand('A', 'a'); this.addCommand('B', 'b'); this.addCommand('C', 'c'); this.addCommand('D', 'd'); this.addCommand('E', 'e'); this.addCommand('F', 'f', Boolean(window.CycloneExtraTilesets)); this.addCommand('G', 'g', Boolean(window.CycloneExtraTilesets)); this.addCommand('H', 'h', Boolean(window.CycloneExtraTilesets)); } }, { key: "colSpacing", value: function colSpacing() { return 6; } }, { key: "rowSpacing", value: function rowSpacing() { return 0; } }, { key: "maxCols", value: function maxCols() { return 8; } }, { key: "redraw", value: function redraw() { Window_Selectable.prototype.refresh.call(this); } // itemRect(index) { // const rect = super.itemRect(index); // if (Graphics.width < 1280) { // rect.width += 3; // } // return rect; // } // lineHeight() { // if (Graphics.width >= 1280) { // if (CycloneMapEditor.tileDrawWidth < 48) { // return 14; // } // return 36; // } // return 14; // } }, { key: "playCursorSound", value: function playCursorSound() {} }, { key: "playOkSound", value: function playOkSound() {} }, { key: "playBuzzerSound", value: function playBuzzerSound() {} }]); return WindowCycloneMapEditorTabs; }(Window_Command); var WindowCycloneMapEditor = /*#__PURE__*/function (_Window_Command3) { _inherits(WindowCycloneMapEditor, _Window_Command3); var _super9 = _createSuper(WindowCycloneMapEditor); function WindowCycloneMapEditor() { _classCallCheck(this, WindowCycloneMapEditor); return _super9.apply(this, arguments); } _createClass(WindowCycloneMapEditor, [{ key: "initialize", value: function initialize() { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = SceneManager._scene._mapEditorTabsWindow.y + SceneManager._scene._mapEditorTabsWindow.height; var w = CycloneMapEditor.windowWidth; var h = Graphics.height - y - SceneManager._scene._mapEditorStatus.height; _get(_getPrototypeOf(WindowCycloneMapEditor.prototype), "initialize", this).call(this, new Rectangle(x, y, w, h)); this.showBackgroundDimmer(); } }, { key: "onMapTouch", value: function onMapTouch(x, y) {} }, { key: "updateBackOpacity", value: function updateBackOpacity() { this.backOpacity = 255; } }, { key: "_updateCursor", value: function _updateCursor() { this._cursorSprite.visible = false; } }, { key: "processCursorMove", value: function processCursorMove() {} }, { key: "processHandling", value: function processHandling() {} }, { key: "addTile", value: function addTile(tileId) { if (!CycloneMapEditor.getTilesetName(tileId)) { return; } if (Tilemap.isAutotile(tileId)) { if (Tilemap.isWallSideTile(tileId) || Tilemap.isRoofTile(tileId)) { this.addCommand(tileId, 'tile', true, tileId); } else if (Tilemap.isWaterfallTile(tileId)) { this.addCommand(tileId, 'tile', true, tileId); } else { this.addCommand(tileId, 'tile', true, tileId + 46); } return; } this.addCommand(tileId, 'tile', true, tileId); } }, { key: "makeManualTilesList", value: function makeManualTilesList() { var tileId = this._manualTileSelected; var maxShape = 46; if (Tilemap.isWallSideTile(tileId) || Tilemap.isRoofTile(tileId)) { maxShape = 15; } else if (Tilemap.isWaterfallTile(tileId)) { maxShape = 3; } for (var i = 0; i <= maxShape; i++) { this.addCommand(tileId + i, 'tile', true, tileId + i); } } }, { key: "makeShadowList", value: function makeShadowList() { for (var i = 0; i <= 15; i++) { this.addCommand(i, 'shadow', true, i); } } }, { key: "makeRegionList", value: function makeRegionList() { for (var i = 0; i <= 255; i++) { this.addCommand(i, 'region', true, i); } } }, { key: "isTileLayer", value: function isTileLayer() { return CycloneMapEditor.currentLayer === 7 || CycloneMapEditor.currentLayer < 4; } }, { key: "makeTileList", value: function makeTileList() { if (CycloneMapEditor.puzzleMode) { this.makePuzzleList(); return; } for (var tileId = Tilemap.TILE_ID_A1; tileId < Tilemap.TILE_ID_MAX; tileId += 48) { this.addTile(tileId); } for (var _tileId4 = Tilemap.TILE_ID_A5; _tileId4 < Tilemap.TILE_ID_A5 + 128; _tileId4++) { this.addTile(_tileId4); } for (var _tileId5 = Tilemap.TILE_ID_B; _tileId5 < Tilemap.TILE_ID_A5; _tileId5++) { this.addTile(_tileId5); } for (var _tileId6 = Tilemap.TILE_ID_A5 + 256; _tileId6 < Tilemap.TILE_ID_A5 + 512; _tileId6++) { this.addTile(_tileId6); } } }, { key: "makePuzzleList", value: function makePuzzleList() { var min = CycloneMapEditor.getTilesetName(Tilemap.TILE_ID_A1) ? Tilemap.TILE_ID_A1 : Tilemap.TILE_ID_A2; var max = CycloneMapEditor.getTilesetName(Tilemap.TILE_ID_A2) ? Tilemap.TILE_ID_A3 : Tilemap.TILE_ID_A2; var tileList = []; for (var tileId = min; tileId < max; tileId += 48) { if (Tilemap.isWaterfallTile(tileId)) { continue; } if (tileId === 2144 || tileId === 2192) { continue; } tileList.push(tileId); } for (var i = 0; i < tileList.length; i += 4) { for (var pieceY = 0; pieceY < 6; pieceY++) { for (var idx = 0; idx <= 3; idx++) { var _tileId7 = tileList[i + idx]; if (!_tileId7) { continue; } for (var pieceX = 0; pieceX < 4; pieceX++) { var pieceId = _tileId7 + pieceX + pieceY * 4; this.addCommand(pieceId, 'puzzle', true, pieceId); } } } } } }, { key: "makeCommandList", value: function makeCommandList() { if (CycloneMapEditor.changingTileProps) { this.makeTileList(); return; } if (this._manualTileSelected) { this.makeManualTilesList(); return; } if (CycloneMapEditor.currentLayer === 4) { this.makeShadowList(); return; } if (CycloneMapEditor.currentLayer === 5) { this.makeRegionList(); return; } if (this.isTileLayer()) { this.makeTileList(); return; } if (CycloneMapEditor.currentLayer === 8) { this.makeCollisionList(); return; } } }, { key: "makeCollisionList", value: function makeCollisionList() { this.addCommand(0, 'collision', true, 0); this.addCommand(1, 'collision', true, 1); this.addCommand(2, 'collision', true, 2); this.addCommand(17, 'collision', true, 17); this.addCommand(18, 'collision', true, 18); this.addCommand(19, 'collision', true, 19); this.addCommand(14, 'collision', true, 14); this.addCommand(20, 'collision', true, 20); this.addCommand(16, 'collision', true, 16); this.addCommand(11, 'collision', true, 11); this.addCommand(12, 'collision', true, 12); this.addCommand(13, 'collision', true, 13); this.addCommand(22, 'collision', true, 22); this.addCommand(26, 'collision', true, 26); this.addCommand(24, 'collision', true, 24); this.addCommand(28, 'collision', true, 28); this.addCommand(4, 'collision', true, 4); this.addCommand(5, 'collision', true, 5); } }, { key: "getTileRow", value: function getTileRow(tileId) { var index = this._list.findIndex(function (item) { return (item === null || item === void 0 ? void 0 : item.name) === tileId; }); if (index >= 0) { return Math.floor(index / this.maxCols()); } return -1; } }, { key: "jumpToTile", value: function jumpToTile(tileId) { var row = this.getTileRow(tileId); if (row < 0) { return false; } this.setTopRow(row || 0); return true; } }, { key: "ensureSelectionVisible", value: function ensureSelectionVisible() { if (this._selectionIndex < 0 || CycloneMapEditor.currentTileId === undefined) { return; } var row = Math.floor(this._selectionIndex / this.maxCols()); if (row < this.topRow()) { this.setTopRow(Math.min(row, this.maxTopRow())); } else if (row > this.topRow() + this.maxPageRows()) { this.setTopRow(Math.min(row, this.maxTopRow())); } } }, { key: "redraw", value: function redraw() { Window_Selectable.prototype.refresh.call(this); if (!CycloneMapEditor.changingTileProps) { // Force the tilemap cursor to redraw too SceneManager._scene._spriteset._mapEditorCursor.updateDrawing(); } } }, { key: "colSpacing", value: function colSpacing() { if (CycloneMapEditor.currentLayer === Layers.collisions) { return 0; } return Math.floor((this.width - this.maxCols() * this.itemWidth()) / this.maxCols()); } }, { key: "rowSpacing", value: function rowSpacing() { return 0; } }, { key: "maxCols", value: function maxCols() { if (CycloneMapEditor.currentLayer === Layers.collisions) { return 3; } if (CycloneMapEditor.puzzleMode) { return 16; } return 8; } }, { key: "itemWidth", value: function itemWidth() { var w = CycloneMapEditor.tileDrawWidth; if (CycloneMapEditor.puzzleMode) { return w / 2; } return w; } }, { key: "itemHeight", value: function itemHeight() { var h = CycloneMapEditor.tileDrawHeight; if (CycloneMapEditor.puzzleMode) { return h / 2; } return h; } }, { key: "drawRegion", value: function drawRegion(index) { var rect = this.itemRect(index); this.contents.fontSize = Graphics.width < 1280 ? 14 : 18; this.contents.drawRegion(index, rect.x, rect.y, rect.width, rect.height, true); } }, { key: "drawCollision", value: function drawCollision(index) { var _this$_list$index$ext; if (index === 0) { return; } var collision = (_this$_list$index$ext = this._list[index].ext) !== null && _this$_list$index$ext !== void 0 ? _this$_list$index$ext : index; if (collision === 0) { return; } var rect = this.itemRect(index); this.contents.drawCollisionType(collision, rect.x, rect.y, rect.width, rect.height); } }, { key: "drawPuzzle", value: function drawPuzzle(index) { var pieceId = this._list[index].ext; if (!pieceId) { return; } var rect = this.itemRect(index); this.contents.drawPuzzlePiece(pieceId, rect.x, rect.y, rect.width, rect.height); } }, { key: "drawShadow", value: function drawShadow(index) { var rect = this.itemRect(index); var shadowId = index; var x = rect.x; var y = rect.y; var drawWidth = rect.width; var drawHeight = rect.height; var halfWidth = (drawWidth !== null && drawWidth !== void 0 ? drawWidth : CycloneMapEditor.tileWidth) / 2; var halfHeight = (drawHeight !== null && drawHeight !== void 0 ? drawHeight : CycloneMapEditor.tileHeight) / 2; if (shadowId < 0 || shadowId > 15) { return; } var table = shadowId.toString(2).padZero(4); for (var i = 0; i < 4; i++) { var color = '#000000'; if (table[3 - i] !== '1') { color = '#FFFFFF99'; } var drawX = x + i % 2 * halfWidth; var drawY = y + Math.floor(i / 2) * halfHeight; this.contents.fillRect(drawX, drawY, halfWidth, halfHeight, color); } var context = this.contents.context; context.save(); context.strokeStyle = '#FF0000'; context.beginPath(); context.moveTo(x, y); context.lineTo(x + drawWidth, y); context.stroke(); context.beginPath(); context.moveTo(x, y); context.lineTo(x, y + drawHeight); context.stroke(); } }, { key: "updateOpacityForTile", value: function updateOpacityForTile(tileId) { if (!CycloneMapEditor.changingTileProps || Input.isPressed('shift')) { return this.changePaintOpacity(true); } return this.changePaintOpacity(false); } }, { key: "drawItem", value: function drawItem(index) { var _this22 = this; this.resetTextColor(); this.changePaintOpacity(this.isCommandEnabled(index)); var symbol = this.commandSymbol(index); if (symbol === 'region') { this.drawRegion(index); return; } if (symbol === 'shadow') { this.drawShadow(index); return; } if (symbol === 'collision') { this.drawCollision(index); return; } if (symbol === 'puzzle') { this.drawPuzzle(index); return; } var rect = this.itemRect(index); var tileId = this._list[index].ext; this.updateOpacityForTile(tileId); var bitmap = this.contents.drawTile(tileId, rect.x, rect.y, this.itemWidth(), this.itemHeight()); if (!bitmap) { return; } if (!bitmap.isReady() && bitmap._loadListeners.length < 2) { bitmap.addLoadListener(function () { _this22._needsRedraw = true; }); } this.changePaintOpacity(true); if (!this._needsRedraw && CycloneMapEditor.changingTileProps) { this.drawTileProp(this.commandName(index), rect); } } }, { key: "translucentOpacity", value: function translucentOpacity() { return 90; } }, { key: "drawTileProp", value: function drawTileProp(tileId, rect) { if (Input.isPressed('shift')) { return; } switch (CycloneMapEditor.currentTool) { case Tools.passage: return this.drawTilePassage(tileId, rect); case Tools.passage4: return this.drawTilePassage4(tileId, rect); case Tools.ladder: return this.drawTileLadder(tileId, rect); case Tools.bush: return this.drawTileBush(tileId, rect); case Tools.counter: return this.drawTileCounter(tileId, rect); case Tools.damage: return this.drawTileDamage(tileId, rect); case Tools.terrain: return this.drawTileTerrain(tileId, rect); } } }, { key: "drawTilePassage", value: function drawTilePassage(tileId, rect) { var passageType = $gameMap.checkTileIdPassageType(tileId); var context = this.contents.context; if (passageType === TilePassageType.blocked) { context.strokeStyle = '#000000'; context.lineWidth = 6; context.beginPath(); context.moveTo(rect.x + 8, rect.y + 8); context.lineTo(rect.x + rect.width - 8, rect.y + rect.height - 8); context.stroke(); context.beginPath(); context.moveTo(rect.x + rect.width - 8, rect.y + 8); context.lineTo(rect.x + 8, rect.y + rect.height - 8); context.stroke(); context.strokeStyle = '#FFFFFF'; context.lineWidth = 4; context.beginPath(); context.moveTo(rect.x + 8, rect.y + 8); context.lineTo(rect.x + rect.width - 8, rect.y + rect.height - 8); context.stroke(); context.beginPath(); context.moveTo(rect.x + rect.width - 8, rect.y + 8); context.lineTo(rect.x + 8, rect.y + rect.height - 8); context.stroke(); return; } if (passageType === TilePassageType.star) { var rot = Math.PI / 5; var step = Math.PI / 5; var outerRadius = Math.floor(Math.min(rect.width, rect.height) / 3); var innerRadius = Math.floor(Math.min(rect.width, rect.height) / 6); var baseX = Math.floor(rect.x + rect.width / 2); var baseY = Math.floor(rect.y + rect.height / 2); context.beginPath(); context.moveTo(baseX, baseY - outerRadius); for (var i = 0; i < 5; i++) { var _x14 = baseX + Math.cos(rot) * outerRadius; var y = baseY + Math.sin(rot) * outerRadius; context.lineTo(_x14, y); rot += step; var inX = baseX + Math.cos(rot) * innerRadius; var inY = baseY + Math.sin(rot) * innerRadius; context.lineTo(inX, inY); rot += step; } context.lineTo(baseX, baseY - outerRadius); context.closePath(); context.lineWidth = 5; context.strokeStyle = '#000000'; context.stroke(); context.fillStyle = '#FFFFFF'; context.fill(); return; } context.strokeStyle = '#000000'; context.lineWidth = 8; context.beginPath(); context.arc(Math.floor(rect.x + rect.width / 2), Math.floor(rect.y + rect.height / 2), Math.floor(Math.min(rect.width - 10, rect.height - 10) / 2), 0, Math.PI * 2, false); context.stroke(); context.strokeStyle = '#FFFFFF'; context.lineWidth = 4; context.beginPath(); context.arc(Math.floor(rect.x + rect.width / 2), Math.floor(rect.y + rect.height / 2), Math.floor(Math.min(rect.width - 10, rect.height - 10) / 2), 0, Math.PI * 2, false); context.stroke(); } }, { key: "drawTilePassage4", value: function drawTilePassage4(tileId, rect) { var flag = $gameMap.getTileFlag(tileId); var top = $gameMap.getPassageBitType(flag, 8); var bottom = $gameMap.getPassageBitType(flag, 2); var left = $gameMap.getPassageBitType(flag, 4); var right = $gameMap.getPassageBitType(flag, 6); var margin = 3; var middleX = rect.x + Math.floor(rect.width / 2); var middleY = rect.y + Math.floor(rect.height / 2); var context = this.contents.context; context.lineWidth = 6; context.strokeStyle = '#000000'; var drawArrow = function drawArrow(x, y, x2, y2) { var headLen = Math.floor(rect.width / 5); var angle1 = Math.PI / 13; var angle2 = Math.atan2(y2 - y, x2 - x); var diff1 = angle2 - angle1; var diff2 = angle2 + angle1; context.beginPath(); context.moveTo(x, y); context.lineTo(x2, y2); context.moveTo(x2, y2); context.lineTo(x2 - headLen * Math.cos(diff1), y2 - headLen * Math.sin(diff1)); context.moveTo(x2, y2); context.lineTo(x2 - headLen * Math.cos(diff2), y2 - headLen * Math.sin(diff2)); context.closePath(); context.stroke(); }; var drawArrows = function drawArrows() { if (top) { drawArrow(middleX, middleY, middleX, rect.y + margin); } if (bottom) { drawArrow(middleX, middleY, middleX, rect.y + rect.height - margin); } if (left) { drawArrow(middleX, middleY, rect.x + margin, middleY); } if (right) { drawArrow(middleX, middleY, rect.x + rect.width - margin, middleY); } }; drawArrows(); context.lineWidth = 2; context.strokeStyle = '#FFFFFF'; drawArrows(); } }, { key: "drawTileLadder", value: function drawTileLadder(tileId, rect) { if (!$gameMap.tileIdIsLadder(tileId)) { return; } var context = this.contents.context; var w = Math.floor(rect.width / 4); var h = Math.floor(rect.height / 3); var x = Math.floor(rect.x + rect.width / 2 - w / 2); var y = Math.floor(rect.y + rect.height / 2 - w / 2); var drawLadder = function drawLadder() { context.beginPath(); context.moveTo(x, y); context.lineTo(x, y + h); context.moveTo(x + w, y); context.lineTo(x + w, y + h); context.moveTo(x, y + Math.floor(h / 3)); context.lineTo(x + w, y + Math.floor(h / 3)); context.moveTo(x, y + Math.floor(h / 3) * 2); context.lineTo(x + w, y + Math.floor(h / 3) * 2); context.closePath(); context.stroke(); }; context.strokeStyle = '#000000'; context.lineWidth = 6; drawLadder(); context.strokeStyle = '#FFFFFF'; context.lineWidth = 2; drawLadder(); } }, { key: "drawTileBush", value: function drawTileBush(tileId, rect) { if (!$gameMap.tileIdIsBush(tileId)) { return; } this.contents.drawText('~', rect.x, rect.y, rect.width, rect.height - 8, 'center'); this.contents.drawText('~', rect.x, rect.y + 8, rect.width, rect.height - 8, 'center'); } }, { key: "drawTileCounter", value: function drawTileCounter(tileId, rect) { if (!$gameMap.tileIdIsCounter(tileId)) { return; } var context = this.contents.context; var w = Math.floor(rect.width / 2); var h = Math.floor(rect.height / 2); var x = rect.x + w; var y = rect.y + h / 2; context.beginPath(); context.moveTo(x, y); context.lineTo(x - w / 2, y + h / 2); context.lineTo(x, y + h); context.lineTo(x + w / 2, y + h / 2); context.closePath(); context.strokeStyle = '#000000'; context.lineWidth = 4; context.stroke(); context.fillStyle = '#FFFFFF'; context.fill(); } }, { key: "drawTileDamage", value: function drawTileDamage(tileId, rect) { if (!$gameMap.tileIdIsDamage(tileId)) { return; } this.contents.drawText('DMG', rect.x, rect.y, rect.width, rect.height, 'center'); } }, { key: "drawTileTerrain", value: function drawTileTerrain(tileId, rect) { var tag = $gameMap.tileIdTerrainTag(tileId); if (!tag) { return; } this.contents.drawText(tag, rect.x, rect.y, rect.width, rect.height, 'center'); } }, { key: "drawAllItems", value: function drawAllItems() { _get(_getPrototypeOf(WindowCycloneMapEditor.prototype), "drawAllItems", this).call(this); this.drawSelection(); } }, { key: "drawMessySelection", value: function drawMessySelection() { this._selectionIndex = -1; for (var index = 0; index < this._list.length; index++) { var item = this._list[index]; var isSelected = Tilemap.isSameKindTile(item.name, CycloneMapEditor.currentTileId); if (isSelected) { this._selectionIndex = index; } else { var _iterator19 = _createForOfIteratorHelper(CycloneMapEditor.selectedTileList), _step19; try { for (_iterator19.s(); !(_step19 = _iterator19.n()).done;) { var tileId = _step19.value; if (Tilemap.isSameKindTile(tileId, item.name)) { isSelected = true; } } } catch (err) { _iterator19.e(err); } finally { _iterator19.f(); } } if (!isSelected) { continue; } this._drawSelection(index, 1, 1); } } }, { key: "_drawSelection", value: function _drawSelection(topIndex, rowDrawCount, colDrawCount) { var rect = this.itemRect(topIndex); var x = rect.x, y = rect.y; if (CycloneMapEditor.puzzleMode) { rowDrawCount = 0.5; colDrawCount = 0.5; } else if (!this._manualTileSelected && CycloneMapEditor.selectedTileList.length >= 2 && Tilemap.isSameKindTile(CycloneMapEditor.selectedTileList[0], CycloneMapEditor.selectedTileList[1])) { rowDrawCount = 1; colDrawCount = 1; } var selectionWidth = CycloneMapEditor.tileDrawWidth * colDrawCount; var selectionHeight = CycloneMapEditor.tileDrawHeight * rowDrawCount; var context = this.contents.context; context.fillStyle = '#000000'; context.fillRect(x - 1, y - 1, selectionWidth + 2, 4); context.fillRect(x - 1, y + selectionHeight - 2, selectionWidth + 2, 4); context.fillRect(x - 1, y, 4, selectionHeight); context.fillRect(x + selectionWidth - 1, y, 4, selectionHeight); context.fillStyle = '#FFFFFF'; context.fillRect(x + 2, y + 2, selectionWidth - 3, 2); context.fillRect(x + 2, y + selectionHeight - 4, selectionWidth - 3, 2); context.fillRect(x + 2, y + 2, 2, selectionHeight - 4); context.fillRect(x + selectionWidth - 3, y + 2, 2, selectionHeight - 4); } }, { key: "isSelectedTile", value: function isSelectedTile(tileId) { if (!Tilemap.isSameKindTile(tileId, CycloneMapEditor.currentTileId)) { return false; } if (tileId !== CycloneMapEditor.currentTileId) { if (this._manualTileSelected !== undefined) { return false; } if (CycloneMapEditor.puzzleMode) { return false; } } return true; } }, { key: "drawSelection", value: function drawSelection() { if (CycloneMapEditor.changingTileProps) { return; } if (CycloneMapEditor.messySelection) { this.drawMessySelection(); return; } var cols = this.maxCols(); this._selectionIndex = -1; for (var index = 0; index < this._list.length; index++) { var item = this._list[index]; if (!this.isSelectedTile(item.name)) { continue; } this._selectionIndex = index; var col = index % cols; var row = Math.floor(index / cols); var rowCount = CycloneMapEditor.tileRows; var colCount = CycloneMapEditor.tileCols; var rowDrawCount = CycloneMapEditor.tileRows <= 0 ? Math.abs(CycloneMapEditor.tileRows) + 2 : CycloneMapEditor.tileRows; var colDrawCount = CycloneMapEditor.tileCols <= 0 ? Math.abs(CycloneMapEditor.tileCols) + 2 : CycloneMapEditor.tileCols; while (rowCount <= 0) { rowCount++; row--; } while (colCount <= 0) { colCount++; col--; } var topIndex = row * cols + col; this._drawSelection(topIndex, rowDrawCount, colDrawCount); break; } } }, { key: "playCursorSound", value: function playCursorSound() {} }, { key: "playOkSound", value: function playOkSound() {} }, { key: "playBuzzerSound", value: function playBuzzerSound() {} }, { key: "selectTileId", value: function selectTileId(tileId) { var cols = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; var rows = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1; if (CycloneMapEditor.currentTool === 'eraser') { CycloneMapEditor.restoreLastDrawingTool(); } CycloneMapEditor.currentTileId = tileId; CycloneMapEditor.tileCols = cols !== null && cols !== void 0 ? cols : 1; CycloneMapEditor.tileRows = rows !== null && rows !== void 0 ? rows : 1; CycloneMapEditor.messySelection = false; CycloneMapEditor.multiLayerSelection = []; var topIndex = this._list.findIndex(function (item) { return item.name === tileId; }); if (topIndex < 0) { CycloneMapEditor.currentTileId = undefined; CycloneMapEditor.selectedTileList = []; this.redraw(); return; } CycloneMapEditor.selectedTileList = Array(cols * rows); CycloneMapEditor.selectedTileList[0] = CycloneMapEditor.currentTileId; var maxCols = this.maxCols(); var topRow = Math.floor(topIndex / maxCols); var leftCol = topIndex % maxCols; var selectionIndex = 0; for (var y = topRow; y < topRow + CycloneMapEditor.tileRows; y++) { for (var _x15 = leftCol; _x15 < leftCol + CycloneMapEditor.tileCols; _x15++) { var newIndex = y * maxCols + _x15; var newTileId = this.commandName(newIndex); CycloneMapEditor.selectedTileList[selectionIndex] = newTileId; selectionIndex++; } } this.redraw(); } }, { key: "startSelectingTile", value: function startSelectingTile() { if (!this._mouseDown) { var index = this.hitIndex(); if (index < 0) { return; } var tileId = this.commandName(index); this.selectTileId(tileId); this._mouseDown = true; } } }, { key: "findName", value: function findName(name) { return this._list.findIndex(function (item) { return item.name === name; }); } }, { key: "continueSelectingTile", value: function continueSelectingTile() { var index = this.hitIndex(); var prevCols = CycloneMapEditor.tileCols; var prevRows = CycloneMapEditor.tileRows; if (index >= 0) { var initialIndex = this.findName(CycloneMapEditor.currentTileId); if (initialIndex < 0) { initialIndex = this._index; } var initialCol = initialIndex % this.maxCols(); var initialRow = Math.floor(initialIndex / this.maxCols()); var newCol = index % this.maxCols(); var newRow = Math.floor(index / this.maxCols()); CycloneMapEditor.tileCols = newCol - initialCol + 1; CycloneMapEditor.tileRows = newRow - initialRow + 1; } if (this._mouseDown) { if (!TouchInput.isPressed() || CycloneMapEditor.changingTileProps || CycloneMapEditor.puzzleMode) { this.finalizeTileSelection(); } else if (TouchInput.isMoved()) { if (prevCols !== CycloneMapEditor.tileCols || prevRows !== CycloneMapEditor.tileRows) { this.redraw(); } } } } }, { key: "finalizeTileSelection", value: function finalizeTileSelection() { this._mouseDown = false; var cols = this.maxCols(); for (var index = 0; index < this._list.length; index++) { var item = this._list[index]; if (item.name !== CycloneMapEditor.currentTileId) { continue; } var col = index % cols; var row = Math.floor(index / cols); var rowCount = CycloneMapEditor.tileRows; var colCount = CycloneMapEditor.tileCols; var newTileRows = CycloneMapEditor.tileRows <= 0 ? Math.abs(CycloneMapEditor.tileRows) + 2 : CycloneMapEditor.tileRows; var newTileCols = CycloneMapEditor.tileCols <= 0 ? Math.abs(CycloneMapEditor.tileCols) + 2 : CycloneMapEditor.tileCols; while (rowCount <= 0) { rowCount++; row--; } while (colCount <= 0) { colCount++; col--; } var topIndex = row * cols + col; if (topIndex >= 0) { var newTileId = this.commandName(topIndex); if (newTileId || newTileId === 0) { this.selectTileId(newTileId, newTileCols, newTileRows); } else { this.selectTileId(CycloneMapEditor.currentTileId); } } else { this.selectTileId(0); } break; } this.redraw(); } }, { key: "activateManualTile", value: function activateManualTile() { var index = this.hitIndex(); if (index < 0) { return; } var tileId = this.commandName(index); if (Tilemap.isAutotile(tileId)) { this._manualTileSelected = tileId; this._selectionIndex = -1; } } }, { key: "toggleManualTiles", value: function toggleManualTiles() { if (this._manualTileSelected === undefined) { this.activateManualTile(); } else { this._manualTileSelected = undefined; } this.refresh(); this._mouseDown = false; CycloneMapEditor.wasRightButtonDown = CycloneMapEditor.isRightButtonDown; } }, { key: "processTouchScroll", value: function processTouchScroll() { if (TouchInput.isTriggered() && this.isTouchedInsideFrame()) { this.startSelectingTile(); } else if (CycloneMapEditor.isRightButtonDown && !CycloneMapEditor.wasRightButtonDown && !this._mouseDown && !CycloneMapEditor.changingTileProps) { this.toggleManualTiles(); return; } if (this._mouseDown) { this._mouseMoved = true; this.continueSelectingTile(); } } }, { key: "update", value: function update() { var shift = Input.isPressed('shift'); if (shift !== this._oldShift) { this._needsRedraw = true; this._oldShift = shift; } if (this._needsRedraw) { this._needsRedraw = false; this.redraw(); } _get(_getPrototypeOf(WindowCycloneMapEditor.prototype), "update", this).call(this); } }]); return WindowCycloneMapEditor; }(Window_Command); var lastDisplayX = 0; var lastDisplayY = 0; CycloneMapEditor.patchClass(Scene_Map, function ($super) { return /*#__PURE__*/function () { function _class8() { _classCallCheck(this, _class8); } _createClass(_class8, [{ key: "createAllWindows", value: function createAllWindows() { $super.createAllWindows.call(this); this.createMapEditorWindows(); CycloneMapEditor.clearAllData(); this.refreshMapEditorWindows(); CycloneMapEditor.addMenuBar(); CycloneMapEditor.loadExtraData(); } }, { key: "toggleMapEditor", value: function toggleMapEditor() { if (CycloneMapEditor.active && CycloneMapEditor.changeHistory.length > 0) { if (confirm('Do you want to save your map before hiding the map editor?')) { CycloneMapEditor._doSave(); } } CycloneMapEditor.tileWidth = $gameMap.tileWidth(); CycloneMapEditor.tileHeight = $gameMap.tileHeight(); CycloneMapEditor.active = !CycloneMapEditor.active; this.refreshMapEditorWindows(); this._spriteset._mapEditorCursor.updateDrawing(); this._spriteset.updatePosition(); } }, { key: "createMapEditorWindows", value: function createMapEditorWindows() { CycloneMapEditor.tileWidth = $gameMap.tileWidth(); CycloneMapEditor.tileHeight = $gameMap.tileHeight(); var neededWidth = CycloneMapEditor.tileDrawWidth * 8 + 24; if (neededWidth > CycloneMapEditor.windowWidth) { CycloneMapEditor.windowWidth = neededWidth; } this._mapEditorGrid = new WindowCycloneGrid(); this.addChild(this._mapEditorGrid); this._mapEditorGrid.hide(); this._mapEditorGrid.deactivate(); this._mapEditorCommands = new WindowCycloneMapEditorCommands(); this.addChild(this._mapEditorCommands); this._mapEditorCommands.hide(); this._mapEditorCommands.deactivate(); this._mapEditorLayerListWindow = new WindowCycloneMapEditorLayerList(); this.addChild(this._mapEditorLayerListWindow); this._mapEditorLayerListWindow.hide(); this._mapEditorLayerListWindow.deactivate(); this._mapEditorTabsWindow = new WindowCycloneMapEditorTabs(); this.addChild(this._mapEditorTabsWindow); this._mapEditorTabsWindow.hide(); this._mapEditorTabsWindow.deactivate(); this._mapEditorStatus = new WindowCycloneMapEditorStatus(); this.addChild(this._mapEditorStatus); this._mapEditorStatus.hide(); this._mapEditorStatus.deactivate(); this._mapEditorWindow = new WindowCycloneMapEditor(); this.addChild(this._mapEditorWindow); this._mapEditorWindow.hide(); this._mapEditorWindow.deactivate(); } }, { key: "refreshMapEditorWindows", value: function refreshMapEditorWindows() { var _CycloneMapEditor2 = CycloneMapEditor, active = _CycloneMapEditor2.active; this._mapEditorGrid.visible = active; this._mapEditorCommands.visible = active; this._mapEditorLayerListWindow.visible = active; this._mapEditorWindow.visible = active; this._mapEditorStatus.visible = active; this._mapEditorTabsWindow.visible = active; this._mapEditorCommands.active = active; this._mapEditorLayerListWindow.active = active; this._mapEditorWindow.active = active; this._mapEditorTabsWindow.active = active; this._mapEditorCommands.refresh(); this._mapEditorLayerListWindow.refresh(); this._mapEditorTabsWindow.refresh(); this._mapEditorWindow.refresh(); this._mapEditorGrid.refresh(); this._mapEditorStatus.refresh(); if (active) { this._spriteset._mapEditorCursor.updateDrawing(); } CycloneMapEditor.refreshMenuVisibility(); } }, { key: "redrawMap", value: function redrawMap() { this._spriteset._tilemap.refresh(); } }, { key: "processMapTouch", value: function processMapTouch() { if (!CycloneMapEditor.active) { $super.processMapTouch.call(this); return; } this._touchCount = 0; if (TouchInput.isPressed() && !this.isAnyButtonPressed()) { this.onMapTouch(); } } }, { key: "onMapTouch", value: function onMapTouch() { if (!CycloneMapEditor.active) { $super.onMapTouch.call(this); return; } } }, { key: "editorX", value: function editorX() { return Graphics.width - CycloneMapEditor.windowWidth; } }, { key: "canUpdateMouse", value: function canUpdateMouse() { return CycloneMapEditor.active && this._mapEditorWindow && this._mapEditorLayerListWindow; } }, { key: "updateMenuTouch", value: function updateMenuTouch(x, y, pressed) { if (!pressed) { return; } if (x > this._mapEditorLayerListWindow.x && x < this._mapEditorLayerListWindow.x + this._mapEditorLayerListWindow.width) { if (y < this._mapEditorLayerListWindow.height + this._mapEditorLayerListWindow.y) { if (!CycloneMapEditor.wasPressing) { this._mapEditorLayerListWindow.onMapTouch(x - this._mapEditorLayerListWindow.x, y - this._mapEditorLayerListWindow.y); CycloneMapEditor.wasPressing = true; } return true; } } if (x > this._mapEditorWindow.x && x < this._mapEditorWindow.x + this._mapEditorWindow.width) { this._mapEditorWindow.onMapTouch(x - this._mapEditorWindow.x, y - this._mapEditorWindow.y); return true; } } }, { key: "updateRightMouse", value: function updateRightMouse() { if (!this.canUpdateMouse()) { CycloneMapEditor.isRightButtonDown = false; CycloneMapEditor.wasRightButtonDown = false; return; } if (!CycloneMapEditor.isRightButtonDown && !CycloneMapEditor.wasRightButtonDown) { return; } var _TouchInput = TouchInput, x = _TouchInput.x, y = _TouchInput.y; if (this.updateMenuTouch(x, y, CycloneMapEditor.isRightButtonDown)) { return; } var mapX = CycloneMapEditor.canvasToMapX(x); var mapY = CycloneMapEditor.canvasToMapY(y); if (mapX >= 0 && mapY >= 0) { CycloneMapEditor.updateRightTouch(mapX, mapY); } CycloneMapEditor.wasRightButtonDown = CycloneMapEditor.isRightButtonDown; } }, { key: "updateDisplayPositionData", value: function updateDisplayPositionData() { if (lastDisplayX === $gameMap._displayX && lastDisplayY === $gameMap._displayY) { return; } var xDiff = $gameMap._displayX - lastDisplayX; var yDiff = $gameMap._displayY - lastDisplayY; if (xDiff > 10 || yDiff > 10) { // If the difference is too big, then we don't update return; } if ((CycloneMapEditor.rectangleWidth > 0 || CycloneMapEditor.rectangleBackWidth > 0) && (CycloneMapEditor.rectangleHeight > 0 || CycloneMapEditor.rectangleBackHeight > 0)) { CycloneMapEditor.rectangleStartMouseX += xDiff * CycloneMapEditor.tileWidth; CycloneMapEditor.rectangleStartMouseY += yDiff * CycloneMapEditor.tileHeight; } } }, { key: "getSelectionTileAt", value: function getSelectionTileAt(x, y) { if (x <= this._mapEditorWindow.x || x >= this._mapEditorWindow.x + this._mapEditorWindow.width) { return CycloneMapEditor.currentTileId; } if (y >= this._mapEditorWindow.height + this._mapEditorWindow.y) { return CycloneMapEditor.currentTileId; } var index = this._mapEditorWindow.hitIndex(); if (index >= 0) { return this._mapEditorWindow.commandName(index); } } }, { key: "updateMouse", value: function updateMouse() { var _this$getSelectionTil; if (!this.canUpdateMouse()) { CycloneMapEditor.wasPressing = false; return; } this.updateDisplayPositionData(); lastDisplayX = $gameMap._displayX; lastDisplayY = $gameMap._displayY; var pressed = TouchInput.isPressed(); var _TouchInput2 = TouchInput, x = _TouchInput2.x, y = _TouchInput2.y; var mapX = CycloneMapEditor.canvasToMapX(x); var mapY = CycloneMapEditor.canvasToMapY(y); var fx = Math.floor(mapX); var fy = Math.floor(mapY); var tile1 = CycloneMapEditor.getCurrentTileAtPosition(fx, fy, 0, true); var tile2 = CycloneMapEditor.getCurrentTileAtPosition(fx, fy, 1, true); var tile3 = CycloneMapEditor.getCurrentTileAtPosition(fx, fy, 2, true); var tile4 = CycloneMapEditor.getCurrentTileAtPosition(fx, fy, 3, true); var tileId = (_this$getSelectionTil = this.getSelectionTileAt(x, y)) !== null && _this$getSelectionTil !== void 0 ? _this$getSelectionTil : ''; CycloneMapEditor.updateStatus({ mapX: mapX, mapY: mapY, tile1: tile1, tile2: tile2, tile3: tile3, tile4: tile4, tileId: tileId }); if (!pressed && !CycloneMapEditor.wasPressing) { return; } if (this.updateMenuTouch(x, y, pressed)) { return; } var minX = 0; var minY = 0; if (CycloneMapEditor.isLayerVisible(Layers.blend) && [Tools.pencil, Tools.eraser].includes(CycloneMapEditor.currentTool)) { minX--; minY--; } if (mapX >= minX && mapY >= minY) { if (Input.isPressed('control') && !CycloneMapEditor.wasPressing) { CycloneMapEditor.selectHigherLayer(mapX, mapY); } else { CycloneMapEditor.updateCurrentToolTouch(mapX, mapY); } } CycloneMapEditor.wasPressing = pressed; } }, { key: "isMenuEnabled", value: function isMenuEnabled() { if (CycloneMapEditor.active) { return false; } return $super.isMenuEnabled.call(this); } }, { key: "update", value: function update() { $super.update.call(this); if (!CycloneMapEditor.active) { return; } if (CycloneMapEditor.wasPressing || CycloneMapEditor.wasRightButtonDown) { if (this._isControlPressed !== Input.isPressed('control') || this._isShiftPressed !== Input.isPressed('shift')) { this.updateMouse(); } } this._isControlPressed = Input.isPressed('control'); this._isShiftPressed = Input.isPressed('shift'); } }]); return _class8; }(); }); CycloneMapEditor.patchClass(SceneManager, function ($super) { return /*#__PURE__*/function () { function _class9() { _classCallCheck(this, _class9); } _createClass(_class9, null, [{ key: "onSceneTerminate", value: function onSceneTerminate() { CycloneMapEditor.refreshMenuVisibility(); } }]); return _class9; }(); }); var SpriteMapEditorCursor = /*#__PURE__*/function (_Sprite) { _inherits(SpriteMapEditorCursor, _Sprite); var _super10 = _createSuper(SpriteMapEditorCursor); function SpriteMapEditorCursor() { _classCallCheck(this, SpriteMapEditorCursor); return _super10.apply(this, arguments); } _createClass(SpriteMapEditorCursor, [{ key: "initialize", value: function initialize() { _get(_getPrototypeOf(SpriteMapEditorCursor.prototype), "initialize", this).call(this, new Bitmap(CycloneMapEditor.tileWidth, CycloneMapEditor.tileHeight)); } }, { key: "update", value: function update() { _get(_getPrototypeOf(SpriteMapEditorCursor.prototype), "update", this).call(this); if (this.visible !== CycloneMapEditor.active) { this.visible = CycloneMapEditor.active; } if (CycloneMapEditor.active) { this.updatePosition(); } } }, { key: "updateDrawing", value: function updateDrawing() { if (CycloneMapEditor.isRightButtonDown) { return this.updateRectangle(); } switch (CycloneMapEditor.currentTool) { case Tools.fill: return this.updateTiles(); case Tools.pencil: if (CycloneMapEditor.isLayerVisible(Layers.blend)) { return this.updateBrush(); } return this.updateTiles(); case Tools.eraser: if (CycloneMapEditor.isLayerVisible(Layers.blend)) { return this.updateBrush(); } return this.updateEraser(); case Tools.rectangle: if (!CycloneMapEditor.rectangleWidth && !CycloneMapEditor.rectangleBackWidth || !CycloneMapEditor.rectangleHeight && !CycloneMapEditor.rectangleBackHeight) { this.updateTiles(); return; } return this.updateRectangle(); default: return this.updateOther(); } } }, { key: "getNewBitmapWidth", value: function getNewBitmapWidth() { return (CycloneMapEditor.tileWidth * (CycloneMapEditor.rectangleWidth || CycloneMapEditor.rectangleBackWidth + 1) || 1) / CycloneMapEditor.getGridRatio(); } }, { key: "getNewBitmapHeight", value: function getNewBitmapHeight() { return (CycloneMapEditor.tileHeight * (CycloneMapEditor.rectangleHeight || CycloneMapEditor.rectangleBackHeight + 1) || 1) / CycloneMapEditor.getGridRatio(); } }, { key: "updateRectangle", value: function updateRectangle() { var width = this.getNewBitmapWidth(); var height = this.getNewBitmapHeight(); if (width !== this.bitmap.width || height !== this.bitmap.height) { this.bitmap = new Bitmap(width, height); } else { this.bitmap.clear(); } var fillColor = CycloneMapEditor.isRightButtonDown ? '#00000033' : '#00FF0033'; if (CycloneMapEditor.currentLayer === 5) { this.drawTiles(); } if (width > 8 && height > 8) { this.bitmap.fillRect(0, 0, width, 4, '#000000'); this.bitmap.fillRect(0, height - 4, width, 4, '#000000'); this.bitmap.fillRect(0, 0, 4, height, '#000000'); this.bitmap.fillRect(width - 4, 0, 4, height, '#000000'); this.bitmap.fillRect(2, 2, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, height - 4, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, 2, 2, height - 4, '#FFFFFF'); this.bitmap.fillRect(width - 4, 2, 2, height - 4, '#FFFFFF'); this.bitmap.fillRect(4, 4, width - 8, height - 8, fillColor); } else if (width > 0 && height > 0) { this.bitmap.fillRect(0, 0, width, height, fillColor); } } }, { key: "updateBrush", value: function updateBrush() { var size = Input.isPressed('shift') ? 4 : 2; var width = $gameMap.tileWidth() / size; var height = $gameMap.tileHeight() / size; if (width !== this.bitmap.width || height !== this.bitmap.height) { this.bitmap = new Bitmap(width, height); } else { this.bitmap.clear(); } var fillColor = CycloneMapEditor.currentTool === Tools.eraser ? '#99000099' : '#00999999'; this.bitmap.drawCircle(width / 2, height / 2, Math.min(width, height) / 2, fillColor); } }, { key: "updateEraser", value: function updateEraser() { var width = this.getNewBitmapWidth(); var height = this.getNewBitmapHeight(); if (width !== this.bitmap.width || height !== this.bitmap.height) { this.bitmap = new Bitmap(width, height); } else { this.bitmap.clear(); } if (width > 8 && height > 8) { this.bitmap.fillRect(0, 0, width, 4, '#000000'); this.bitmap.fillRect(0, height - 4, width, 4, '#000000'); this.bitmap.fillRect(0, 0, 4, height, '#000000'); this.bitmap.fillRect(width - 4, 0, 4, height, '#000000'); this.bitmap.fillRect(2, 2, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, height - 4, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, 2, 2, height - 4, '#FFFFFF'); this.bitmap.fillRect(width - 4, 2, 2, height - 4, '#FFFFFF'); this.bitmap.fillRect(4, 4, width - 8, height - 8, '#FF000033'); } else if (width > 0 && height > 0) { this.bitmap.fillRect(0, 0, width, height, '#FF000033'); } } }, { key: "drawMultiLayerTiles", value: function drawMultiLayerTiles() { for (var z = 0; z < CycloneMapEditor.multiLayerSelection.length; z++) { var column = 0; var row = 0; var _iterator20 = _createForOfIteratorHelper(CycloneMapEditor.multiLayerSelection[z]), _step20; try { for (_iterator20.s(); !(_step20 = _iterator20.n()).done;) { var tileId = _step20.value; if (column >= CycloneMapEditor.tileCols) { column = 0; row++; } var _x16 = column * CycloneMapEditor.tileWidth; var y = row * CycloneMapEditor.tileHeight; this.bitmap.drawTile(tileId, _x16, y); column++; } } catch (err) { _iterator20.e(err); } finally { _iterator20.f(); } } } }, { key: "drawTiles", value: function drawTiles() { if (CycloneMapEditor.currentLayer === Layers.auto && CycloneMapEditor.multiLayerSelection.length) { this.drawMultiLayerTiles(); return; } var column = 0; var row = 0; var _iterator21 = _createForOfIteratorHelper(CycloneMapEditor.selectedTileList), _step21; try { for (_iterator21.s(); !(_step21 = _iterator21.n()).done;) { var tileId = _step21.value; if (column >= CycloneMapEditor.tileCols) { column = 0; row++; } var _x17 = column * CycloneMapEditor.tileWidth; var y = row * CycloneMapEditor.tileHeight; if (CycloneMapEditor.currentLayer === 5) { this.bitmap.drawRegion(tileId, _x17, y); } else if (CycloneMapEditor.currentLayer === 4) { this.bitmap.drawShadow(tileId, _x17, y); } else if (CycloneMapEditor.currentLayer === 8) { this.drawCollision(tileId, _x17, y); } else if (CycloneMapEditor.puzzleMode) { this.bitmap.drawPuzzlePiece(tileId, _x17, y, CycloneMapEditor.tileWidth / 2, CycloneMapEditor.tileHeight / 2); } else { this.bitmap.drawTile(tileId, _x17, y); } column++; } } catch (err) { _iterator21.e(err); } finally { _iterator21.f(); } } }, { key: "drawCollision", value: function drawCollision(tileId, x, y) { var drawWidth = CycloneMapEditor.tileWidth; var drawHeight = CycloneMapEditor.tileHeight; if (tileId === 0) { return; } this.bitmap.drawCollisionType(tileId, x, y, drawWidth, drawHeight); } }, { key: "updateOther", value: function updateOther() { this.bitmap.clear(); } }, { key: "updateTiles", value: function updateTiles() { var gridRatio = CycloneMapEditor.getGridRatio(); var width = CycloneMapEditor.tileWidth * CycloneMapEditor.tileCols / gridRatio; var height = CycloneMapEditor.tileHeight * CycloneMapEditor.tileRows / gridRatio; if (width !== this.bitmap.width || height !== this.bitmap.height) { this.bitmap = new Bitmap(width, height); } else { this.bitmap.clear(); } this.drawTiles(); if (width > 8 && height > 8) { this.bitmap.fillRect(0, 0, width, 4, '#000000'); this.bitmap.fillRect(0, height - 4, width, 4, '#000000'); this.bitmap.fillRect(0, 0, 4, height, '#000000'); this.bitmap.fillRect(width - 4, 0, 4, height, '#000000'); this.bitmap.fillRect(2, 2, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, height - 4, width - 4, 2, '#FFFFFF'); this.bitmap.fillRect(2, 2, 2, height - 4, '#FFFFFF'); this.bitmap.fillRect(width - 4, 2, 2, height - 4, '#FFFFFF'); } } }, { key: "getCursorTileX", value: function getCursorTileX() { if (CycloneMapEditor.currentTool === 'rectangle' || CycloneMapEditor.currentTool === 'eraser' || CycloneMapEditor.isRightButtonDown) { if (CycloneMapEditor.rectangleWidth > 0) { return CycloneMapEditor.rectangleStartX; } if (CycloneMapEditor.rectangleBackWidth > 0) { return CycloneMapEditor.rectangleStartX - CycloneMapEditor.rectangleBackWidth / CycloneMapEditor.getGridRatio(); } } if (SceneManager._scene._mapEditorWindow) { if (TouchInput.x >= SceneManager._scene._mapEditorWindow.x) { return CycloneMapEditor.canvasToMapX(SceneManager._scene._mapEditorWindow.x); } } return CycloneMapEditor.canvasToMapX(TouchInput.x); } }, { key: "getCursorTileY", value: function getCursorTileY() { if (CycloneMapEditor.currentTool === 'rectangle' || CycloneMapEditor.currentTool === 'eraser' || CycloneMapEditor.isRightButtonDown) { if (CycloneMapEditor.rectangleHeight > 0) { return CycloneMapEditor.rectangleStartY; } if (CycloneMapEditor.rectangleBackHeight > 0) { return CycloneMapEditor.rectangleStartY - CycloneMapEditor.rectangleBackHeight / CycloneMapEditor.getGridRatio(); } } return CycloneMapEditor.canvasToMapY(TouchInput.y); } }, { key: "updatePosition", value: function updatePosition() { if (!CycloneMapEditor.active) { return; } var tileX = this.getCursorTileX(); var tileY = this.getCursorTileY(); var offsetX = 0; var offsetY = 0; if (CycloneMapEditor.isLayerVisible(Layers.blend) && [Tools.eraser, Tools.pencil].includes(CycloneMapEditor.currentTool)) { offsetX -= Math.floor(this.bitmap.width / 2); offsetY -= Math.floor(this.bitmap.height / 2); } this.x = Math.floor($gameMap.adjustX(tileX) * CycloneMapEditor.tileWidth) + offsetX; this.y = Math.floor($gameMap.adjustY(tileY) * CycloneMapEditor.tileHeight) + offsetY; } }]); return SpriteMapEditorCursor; }(Sprite); CycloneMapEditor.patchClass(Spriteset_Map, function ($super) { return /*#__PURE__*/function () { function _class10() { _classCallCheck(this, _class10); } _createClass(_class10, [{ key: "initialize", value: function initialize() { $super.initialize.call(this); this.createMapEditorCursor(); } }, { key: "createMapEditorCursor", value: function createMapEditorCursor() { this._mapEditorCursor = new SpriteMapEditorCursor(); this.addChild(this._mapEditorCursor); } }, { key: "forceBlenderRefresh", value: function forceBlenderRefresh() { var hardRefresh = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; if (!window.CycloneMagic) { return; } if (hardRefresh) { var _iterator22 = _createForOfIteratorHelper(this._blenderTileSprites), _step22; try { for (_iterator22.s(); !(_step22 = _iterator22.n()).done;) { var sprite = _step22.value; sprite.parent.removeChild(sprite); sprite.destroy(); } } catch (err) { _iterator22.e(err); } finally { _iterator22.f(); } this._blenderTileSprites = []; this.createBlenderTiles(); return; } var magicTiles = $gameMap.magicTiles(); var _iterator23 = _createForOfIteratorHelper(magicTiles), _step23; try { for (_iterator23.s(); !(_step23 = _iterator23.n()).done;) { var tile = _step23.value; var found = false; var _iterator24 = _createForOfIteratorHelper(this._blenderTileSprites), _step24; try { for (_iterator24.s(); !(_step24 = _iterator24.n()).done;) { var _sprite = _step24.value; if (_sprite._mapX !== tile.x || _sprite._mapY !== tile.y) { continue; } found = true; if (!window.CycloneMagic.isSpriteCached(_sprite.spriteId)) { _sprite._bitmap = null; } break; } } catch (err) { _iterator24.e(err); } finally { _iterator24.f(); } if (!found) { var newSprite = new window.CycloneMagic.SpriteBlenderTile(tile.tiles, tile.x, tile.y, 1, 1); this._blenderTileSprites.push(newSprite); this._tilemap.addChild(newSprite); } } } catch (err) { _iterator23.e(err); } finally { _iterator23.f(); } this._tilemap.refresh(); } // updatePosition() { // if (!CycloneMapEditor.active) { // return $super.updatePosition.call(this); // } // const scale = $gameMap.zoom ?? { x : 1, y : 1}; // const screen = $gameScreen; // this.x = -($gameMap.zoom?.x ?? 1) * (scale.x - 1); // this.y = -($gameMap.zoom?.y ?? 1) * (scale.y - 1); // this.x = this.x + screen.shake(); // if (this.scale.x !== scale.x || this.scale.y !== scale.y) { // const sw = Graphics.width / scale.x + this._tilemap._margin * 2; // const sh = Graphics.height / scale.y + this._tilemap._margin * 2; // if (sw !== this._tilemap.width || sh !== this._tilemap.height) { // this._tilemap.width = sw; // this._tilemap.height = sh; // this._tilemap.refresh(); // } // this.scale = new PIXI.Point(scale.x, scale.y); // this._weather.scale = new PIXI.Point(1.0 / scale.x, 1.0 / scale.y); // this._parallax.move(this._parallax.x, this._parallax.y, Graphics.width / scale.x, Graphics.height / scale.y); // } // } }]); return _class10; }(); }); CycloneMapEditor.patchClass(Tilemap, function ($super) { return /*#__PURE__*/function () { function _class11() { _classCallCheck(this, _class11); } _createClass(_class11, [{ key: "_readMapData", value: function _readMapData(x, y, z) { var _CycloneMapEditor$pre; if (!$gameMap.isValid(x, y)) { return 0; } if (z <= 4 && !CycloneMapEditor.layerVisibility[z]) { return 0; } var tileIndex = CycloneMapEditor.tileIndex(x, y, z); if (((_CycloneMapEditor$pre = CycloneMapEditor.previewChanges) === null || _CycloneMapEditor$pre === void 0 ? void 0 : _CycloneMapEditor$pre[tileIndex]) !== undefined) { return CycloneMapEditor.previewChanges[tileIndex]; } return $super._readMapData.call(this, x, y, z); } }, { key: "canUpdateAnimationCount", value: function canUpdateAnimationCount() { if (CycloneMapEditor.active && CycloneMapEditor.isLayerVisible(Layers.blend) && TouchInput.isPressed()) { return false; } return true; } }, { key: "update", value: function update() { // Prevent the water animation while modifying blending if (!this.canUpdateAnimationCount()) { this.animationCount--; } $super.update.call(this); } }]); return _class11; }(); }); CycloneMapEditor.patchClass(TouchInput, function ($super) { return /*#__PURE__*/function () { function _class12() { _classCallCheck(this, _class12); } _createClass(_class12, null, [{ key: "_onLeftButtonDown", value: function _onLeftButtonDown(event) { $super._onLeftButtonDown.call(this, event); if (SceneManager._scene instanceof Scene_Map) { SceneManager._scene.updateMouse(); } } }, { key: "_onMouseMove", value: function _onMouseMove(event) { $super._onMouseMove.call(this, event); if (SceneManager._scene instanceof Scene_Map) { SceneManager._scene.updateMouse(); SceneManager._scene.updateRightMouse(); } } }, { key: "_onMouseUp", value: function _onMouseUp(event) { $super._onMouseUp.call(this, event); if (SceneManager._scene instanceof Scene_Map) { if (event.button === 0) { SceneManager._scene.updateMouse(); } else if (event.button === 2) { CycloneMapEditor.isRightButtonDown = false; SceneManager._scene.updateRightMouse(); } } } }, { key: "_onRightButtonDown", value: function _onRightButtonDown(event) { $super._onRightButtonDown.call(this, event); if (SceneManager._scene instanceof Scene_Map) { CycloneMapEditor.isRightButtonDown = true; SceneManager._scene.updateRightMouse(); } } }]); return _class12; }(); }); CycloneMapEditor.patchClass(Sprite_Character, function ($super) { return /*#__PURE__*/function () { function _class13() { _classCallCheck(this, _class13); } _createClass(_class13, [{ key: "update", value: function update() { var _$super$update; if (CycloneMapEditor.active) { this.visible = CycloneMapEditor.isLayerVisible(Layers.events); if (!this.visible) { return; } } for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) { args[_key5] = arguments[_key5]; } (_$super$update = $super.update).call.apply(_$super$update, [this].concat(args)); } }]); return _class13; }(); }); WindowCycloneGrid.prototype.initialize = function () { var width = Graphics.width; var height = Graphics.height; Window_Base.prototype.initialize.call(this, 0, 0, width, height); this.refresh(); this.opacity = 0; this.backOpacity = 0; this.hide(); this.deactivate(); }; WindowCycloneGrid.prototype.standardPadding = function () { return 0; }; WindowCycloneMapEditor.prototype.initialize = function () { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = SceneManager._scene._mapEditorTabsWindow.y + SceneManager._scene._mapEditorTabsWindow.height; Window_Command.prototype.initialize.call(this, x, y); this.showBackgroundDimmer(); }; WindowCycloneMapEditor.prototype.windowWidth = function () { return CycloneMapEditor.windowWidth; }; WindowCycloneMapEditor.prototype.windowHeight = function () { var y = SceneManager._scene._mapEditorTabsWindow.y + SceneManager._scene._mapEditorTabsWindow.height; return Graphics.height - y - SceneManager._scene._mapEditorStatus.height; }; WindowCycloneMapEditor.prototype.spacing = function () { return 0; }; WindowCycloneMapEditor.prototype.standardPadding = function () { return 8; }; WindowCycloneMapEditor.prototype.processTouch = function () { return this.processTouchScroll(); }; WindowCycloneMapEditor.prototype._updateCursor = function () { this._windowCursorSprite.visible = false; }; WindowCycloneMapEditorCommands.prototype.initialize = function () { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = 0; Window_Command.prototype.initialize.call(this, x, y); this.showBackgroundDimmer(); this.configureHandlers(); }; WindowCycloneMapEditorCommands.prototype.windowWidth = function () { return CycloneMapEditor.windowWidth; }; WindowCycloneMapEditorCommands.prototype.windowHeight = function () { return 74; }; WindowCycloneMapEditorCommands.prototype.standardPadding = function () { return 8; }; WindowCycloneMapEditorCommands.prototype.spacing = function () { return 6; }; WindowCycloneMapEditorCommands.prototype._updateCursor = function () { this._windowCursorSprite.visible = false; }; WindowCycloneMapEditorCommands.prototype.itemHeight = function () { return this.lineHeight() + 8; }; WindowCycloneMapEditorCommands.prototype.onTouch = function (triggered) { var x = this.canvasToLocalX(TouchInput.x); var y = this.canvasToLocalY(TouchInput.y); var hitIndex = this.hitTest(x, y); if (hitIndex >= 0) { this.select(hitIndex); if (triggered) { this.processOk(); } } }; WindowCycloneMapEditorLayerList.prototype.initialize = function () { var x = 0; var y = 0; var h = Graphics.height - 40; var w = 180; Window_Base.prototype.initialize.call(this, x, y, w, h); this.showBackgroundDimmer(); }; WindowCycloneMapEditorLayerList.prototype.standardPadding = function () { return 8; }; WindowCycloneMapEditorStatus.prototype.initialize = function () { var h = 40; Window_Base.prototype.initialize.call(this, 0, Graphics.height - h, Graphics.width, h); this.showBackgroundDimmer(); }; WindowCycloneMapEditorStatus.prototype.textY = function () { return 2; }; WindowCycloneMapEditorStatus.prototype.standardPadding = function () { return 8; }; WindowCycloneMapEditorStatus.prototype.drawRightLine = function () { this.drawText("TileId: ".concat(CycloneMapEditor.statusTileId), 0, this.textY(), this.width - 16, 'right'); }; WindowCycloneMapEditorTabs.prototype.initialize = function () { var x = Graphics.width - CycloneMapEditor.windowWidth; var y = SceneManager._scene._mapEditorCommands.y + SceneManager._scene._mapEditorCommands.height; Window_Command.prototype.initialize.call(this, x, y); this.showBackgroundDimmer(); this.configureHandlers(); }; WindowCycloneMapEditorTabs.prototype.windowWidth = function () { return CycloneMapEditor.windowWidth; }; WindowCycloneMapEditorTabs.prototype.windowHeight = function () { return 65; }; WindowCycloneMapEditorTabs.prototype.standardPadding = function () { return 8; }; WindowCycloneMapEditorTabs.prototype.spacing = function () { return 6; }; WindowCycloneMapEditorTabs.prototype._updateCursor = function () { this._windowCursorSprite.visible = false; }; WindowCycloneMapEditorTabs.prototype.itemHeight = function () { return this.lineHeight() + 8; }; WindowCycloneMapEditorTabs.prototype.onTouch = function (triggered) { var x = this.canvasToLocalX(TouchInput.x); var y = this.canvasToLocalY(TouchInput.y); var hitIndex = this.hitTest(x, y); if (hitIndex >= 0) { this.select(hitIndex); if (triggered) { this.processOk(); } } }; CycloneMapEditor.patchClass(Scene_Boot, function ($super) { return /*#__PURE__*/function () { function _class14() { _classCallCheck(this, _class14); } _createClass(_class14, [{ key: "resizeScreen", value: function resizeScreen() { if (Utils.isNwjs() && Graphics.width < 1280) { var minWidth = Math.min(1920, screen.availWidth - (window.outerWidth - window.innerWidth)); var minHeight = Math.min(1080, screen.availHeight - (window.outerHeight - window.innerHeight)); if (Graphics.width < minWidth) { Graphics.width = minWidth; } if (Graphics.boxWidth < minWidth) { Graphics.boxWidth = minWidth; } if (Graphics.height < minHeight) { Graphics.height = minHeight; } if (Graphics.boxHeight < minHeight) { Graphics.boxHeight = minHeight; } var xDelta = Graphics.width - window.innerWidth; var yDelta = Graphics.height - window.innerHeight; window.moveBy(-xDelta / 2, -yDelta / 2); window.resizeBy(xDelta, yDelta); } } }, { key: "start", value: function start() { $super.start.call(this); this.resizeScreen(); } }]); return _class14; }(); }); CycloneMapEditor.isFullScreen = function () { // MV's _isFullScreen was broken, it would return the opposite value return !Graphics._isFullScreen(); }; })();