# Changelog All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project somewhat adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). The MAJOR version number is bumped when there are breaking changes in the pret projects. The **"Breaking Changes"** listed below are changes that have been made in the decompilation projects (e.g. pokeemerald), which porymap requires in order to work properly. It also includes changes to the scripting API that may change the behavior of existing porymap scripts. If porymap is used with a project or API script that is not up-to-date with the breaking changes, then porymap will likely break or behave improperly. ## [Unreleased] ### Breaking Changes - Proper support for pokefirered's clone objects was added, which requires the changes made in [pokefirered/#484](https://github.com/pret/pokefirered/pull/484). - Many API functions which were previously accessible via the `map` object are now accessible via one of the new objects `overlay`, `utility`, or `constants`. Some functions were renamed accordingly. See [porymap/#460](https://github.com/huderlem/porymap/pull/460) for a full list of API function name changes. - The boolean arguments `xflip` and `yflip` in the API function `createImage` have been replaced with arguments for horizontal and vertical scale. ### Added - Add prefab support - Add Copy/Paste for metatiles in the Tileset Editor. - Add new features to the scripting API, including the ability to display message boxes and user input windows, set overlay opacity, get/set map header properties, read/write the map border, read tile pixel data, and set blocks or metatile attributes using a raw value. - Add button to copy the full metatile label to the clipboard in the Tileset Editor. - Add option to not open the most recent project on launch. - Add options for customizing how new maps are filled - Add color picker to palette editor for taking colors from the screen. ### Changed - Overhauled the region map editor, adding support for tilemaps, and significant customization. Also now supports pokefirered. - If an object event is inanimate, it will always render using its first frame. - Only log "Unknown custom script function" when a registered script function is not present in any script. - Unused metatile attribute bits that are set are preserved instead of being cleared. - The wild encounter editor is automatically disabled if the encounter JSON data cannot be read - Metatiles are always rendered accurately with 3 layers, and the unused layer is not assumed to be transparent. - `object_event_graphics_info.h` can now be parsed correctly if it uses structs with attributes. - The selection is no longer reset when pasting events. The newly pasted events are selected instead. - Palette editor ui is updated a bit to allow hex and rgb value input. ### Fixed - Fix cursor tile outline not updating at the end of a dragged selection. - Fix cursor tile and player view outlines exiting map bounds while painting. - Fix cursor tile and player view outlines not updating immediately when toggled in Collision view. - Fix selected space not updating while painting in Collision view. - Fix collision values of 2 or 3 not rendering properly. - Fix the map music dropdown being empty when importing a map from Advance Map. - Fix object events added by pasting ignoring the map event limit. - Fixed a bug where saving the tileset editor would reselect the main editor's first selected metatile. - Fix crashes / unexpected behavior if certain scripting API functions are given invalid palette or tile numbers. - Silence unnecessary errors about `SECRET_BASE_GROUP` when parsing `secret_bases.h`. ## [4.5.0] - 2021-12-26 ### Added - WSL project paths are now supported. (For example, \wsl$\Ubuntu-20.04\home\huderlem\pokeemerald) - Add ability to export map timelapse animated GIFs with `File -> Export Map Timelapse Image...`. - Add tool to count the times each metatile or tile is used in the tileset editor. - Events, current metatile selections, and map images can now be copied and pasted, including between windows. - The grid and map border visibility are now saved as config options. - Add ~60 new scripting API functions, including new features like reading/writing metatile data, layering, moving, and hiding items in the overlay, creating modified images and tile/metatile images, reading tileset sizes, logging warnings and errors, and more. - Add 7 new scripting API callbacks. - Porymap is now compatible with Qt6. ### Changed - New events will be placed in the center of the current view of the map. - Scripting API errors are more detailed and logged in more situations. - Add new optional arguments to 5 existing API functions. - Top-level UI elements now render above the scripting overlay. - The onBlockChanged script callback is now called for blocks changed by Undo/Redo. ### Fixed - Fix % operator in C defines not being evaluated - Fix tileset palette editor crash that could occur when switching maps or tilesets with it open. - The metatile selection is no longer reset if it becomes invalid by changing the tileset. Invalid metatiles in the selection will be temporarily replaced with metatile 0. - Loading wild encounters will now properly preserve the original order, so saving the file will not give huge diffs. - Fix bug where the tile selection cursor could be toggld on in the Events tab. ## [4.4.0] - 2020-12-20 ### Added - Add undoable edit history for Events tab. - Add keyboard shortcut for `DEL` key to delete the currently selected event(s). - Disable ui while there is no open project to prevent crashing. - Add "Straight Paths" feature for drawing straight lines while holding `Ctrl`. - The New Map dialog now gives an option to specify the "Show Location Name" field. - Some new shortcuts were added in [porymap/#290](https://github.com/huderlem/porymap/pull/290). - All plain text boxes now have a clear button to delete the text. - The window sizes and positions of the tileset editor, palette editor, and region map editor are now stored in `porymap.cfg`. - Add ruler tool for measuring metatile distance in events tab (Right-click to turn on/off, left-click to lock in place). - Add delete button to wild pokemon encounters tab. - Add shortcut customization via `Options -> Edit Shortcuts`. - Add custom text editor commands in `Options -> Edit Preferences`, a tool-button next to the `Script` combo-box, and `Tools -> Open Project in Text Editor`. The tool-button will open the containing file to the cooresponding script. ### Changed - Holding `shift` now toggles "Smart Path" drawing; when the "Smart Paths" checkbox is checked, holding `shift` will temporarily disable it. ### Fixed - Fix a bug with the current metatile selection zoom. - Fix bug preventing the status bar from updating the current position while dragging events. - Fix porymap icon not showing on window or panel on Linux. - The main window can now be resized to fit on lower resolution displays. - Zooming the map in/out will now focus on the cursor. - Fix bug where object event sprites whose name contained a 0 character would display the placeholder "N" picture. ## [4.3.1] - 2020-07-17 ### Added - Add keyboard shortcut `Ctrl + D` for duplicating map events. - Add keyboard shortcut `Ctrl + Shift + Z` for "redo" in the tileset editor. - Add scripting api to reorder metatile layers and draw them with opacity. ### Changed - The tileset editor now syncs its metatile selection with the map's metatile selector. - The number of object events per map is now limited to OBJECT_EVENT_TEMPLATES_COUNT - The tileset editor can now flip selections that were taken from an existing metatile. ### Fixed - Fix bug where editing a metatile layer would have no effect. - Fix a crash that occured when creating a new tileset using triple layer mode. - Fix crash when reducing number of metatiles past current selection. - Fix various methods of selecting invalid metatiles. - Fix sprite transparency not updating when changing object event graphics. - Fix dropdown menu item selection when using the arrow keys. ## [4.3.0] - 2020-06-27 ### Added - Add triple-layer metatiles support. ### Changed - The "Open Scripts" button will fall back to `scripts.inc` if `scripts.pory` doesn't exist. ### Fixed - Fix bug where exported tileset images could be horizontally or vertically flipped. - Fix bug where the map list wasn't filtered properly after switching filter types. - Don't zoom in map when mouse middle button is pressed. ## [4.2.0] - 2020-06-06 ### Added - Add more project-specific configs to better support porting features from different projects. - Add metatile label names to the status bar when hovering over metatiles in the map editor tab. - Add mouse coordinates to the status bar when hovering in the events tab. ### Changed - `metatile_labels.h` is now watched for changes. ### Fixed - Reduce time it takes to load maps and save in the tileset editor. - Fix crash that could occur when parsing unknown symbols when evaluating `define` expressions. ## [4.1.0] - 2020-05-18 ### Added - Add scripting capabilities, which allows the user to add custom behavior to Porymap using JavaScript scripts. - Add ability to import FRLG tileset .bvd files from Advance Map 1.92. ### Changed - Edit modes are no longer shared between the Map and Events tabs. Pencil is default for Map tab, and Pointer is default for Events tab. ### Fixed - Disallow drawing new heal locations in the events tab. - Fix issue where the metatile selection window was not resizable. - Show warning when closing project with unsaved wild Pokémon changes. - Fix bug where negative object event coordinates were saved as "0". - Fix maximum map dimension limits. - Fix crash when using the Pencil tool to create an event on a map with no existing events. ## [4.0.0] - 2020-04-28 ### Breaking Changes - If you are using pokeemerald or pokeruby, there were changes made in [pokeemerald/#1010](https://github.com/pret/pokeemerald/pull/1010) and [pokeruby/#776](https://github.com/pret/pokeruby/pull/776) that you will need to integrate in order to use this version of porymap. ### Added - Support for [pokefirered](https://github.com/pret/pokefirered). Kanto fans rejoice! At long last porymap supports the FRLG decompilation project. - Add ability to export map stitches with `File -> Export Map Stitch Image...`. - Add new project config option `use_custom_border_size`. - Add ability to toggle project settings in `Options` menu. - Add file monitoring, so Porymap will prompt the user to reload the project if certain project files are modified outside of Porymap. - Add ability to reload project. - Add `Pencil`, `Move`, and `Map Shift` tools to the Events tab. ### Changed - Porymap now saves map and encounter json data in an order consistent with the upstream repos. This will provide more comprehensible diffs when files are saved. - Update Porymap icon. - The "Map" and "Events" tabs now render using the same view, so jumping between them is smooth. - Extend connection min and max offsets to player's view boundary, rather than the map's boundary. ### Fixed - Fix bug where pressing TAB key did not navigate through widgets in the wild encounter tables. - Fix bug that allowed selecting an invalid metatile in the metatile selector. - Don't allow `.` or `-` characters in new tileset names. - Fix regression that prevented selecting empty region map squares ## [3.0.1] - 2020-03-04 ### Fixed - Fix bug on Mac where tileset images were corrupted when saving. ## [3.0.0] - 2020-03-04 ### Breaking Changes - pokeemerald and pokeruby both underwent a naming consistency update with respect to "object events". As such, these naming changes break old versions of Porymap. - pokeemerald object event PR: https://github.com/pret/pokeemerald/pull/910 - pokeruby object event PR: https://github.com/pret/pokeruby/pull/768 ### Added - Add optional support for Poryscript script files via the `use_poryscript` config option. - Selecting a group of metatiles from the map area now also copies the collision properties, too. - Add keyboard shortcut `Ctrl + G` for toggling the map grid. ### Changed - Draw map connections with the current map's tilesets to more accurately mimic their appearance in-game. ### Fixed - Fix index-out-of-bounds crash when deleting the last event in an event type group. - Fix bug where exporting tileset images could add an extra row of junk at the end. - Fix crashes when encountering an error opening a project or map. - Fix bug where comboboxes and wild pokemon data could grow large when opening projects multiple times during the same porymap session. - Fix bug where dragging the metatile selector would visually extend beyond map boundary. ## [2.0.0] - 2019-10-16 ### Breaking Changes - Accomodate event object graphics pointer table being explicitly indexed. From changes introduced in commits [cdae0c1444bed98e652c87dc3e3edcecacfef8be](https://github.com/pret/pokeemerald/commit/cdae0c1444bed98e652c87dc3e3edcecacfef8be) and [0e8ccfc4fd3544001f4c25fafd401f7558bdefba](https://github.com/pret/pokeruby/commit/0e8ccfc4fd3544001f4c25fafd401f7558bdefba). - New "field" key in wild encounter JSON data from pokeemerald and pokeruby commits [adb0a444577b59eb02788c782a3d04bc285be0ba](https://github.com/pret/pokeemerald/commit/adb0a444577b59eb02788c782a3d04bc285be0ba) and [https://github.com/pret/pokeruby/commit/c73de8bed752ca538d90cfc93c4a9e8c7965f8c9](c73de8bed752ca538d90cfc93c4a9e8c7965f8c9). ### Added - Add wild encounter table editor. - Add dark themes. - Support metatile labels file introduced in pokeruby and pokeemerald commits [ad365a35c1536740cbcbc10bee66e5dd908c39e7](https://github.com/pret/pokeruby/commit/ad365a35c1536740cbcbc10bee66e5dd908c39e7) and [c68ba9f4e8e260f2e3389eccd15f6ee5f4bdcd3e](https://github.com/pret/pokeemerald/commit/c68ba9f4e8e260f2e3389eccd15f6ee5f4bdcd3e). - Add warning when closing porymap with unsaved changes. ### Changed - Exporting map images is now more configurable. Events, connections, collision, etc. can be toggled on and off before exporting the image. - The entire Tileset Editor selection is now conveniently flipped when selecting x-flip or y-flip. - Autocomplete for porymap's comboboxes no longer require typing the full string prefix. ### Fixed - Fix bug where map group names were hardcoded when creating a new map. - Fix bug in Tileset Editor where multi-tile selections weren't properly painted when clicking on the bottom row of the metatile layers. - Fix bug where line breaks in C headers were not parsed properly. - Fix bug when exporting tileset images using palettes with duplicate colors. - Fix bug where creating new maps from existing layouts created an empty layout folder. - Fix bug where exported tile images did not contain the last row of tiles. ## [1.2.2] - 2019-05-16 ### Added - Add region map editor - Add ability to add new tilesets - Add official Porymap documentation website: https://huderlem.github.io/porymap/ ### Changed - Event sprites now display as facing the direction of their movement type. - Default values for newly-created events now use valid values from the project, rather than hardcoded values. - Deleting events will stay in the same events tab for easier bulk deletions. - Double-clicking on a secret base event will open the corresponding secret base map. - Selected events are now rendered above other events. - Default values for new events are now more sensible and guaranteed to be valid. ### Fixed - Fix bug in zoomed metatile selector where a large selection rectangle was being rendered. - Fix bug where edited map icons were not rendered properly. - Fix bug where right-click copying a tile from the tileset editor's metatile layers wouldn't copy the x/y flip status. - Parsing project data is now more resilient to crashing, and it reports more informative errors. ## [1.2.1] - 2019-02-16 ### Added - Add ability to zoom in and out the map metatile selector via a slider at the bottom of the metatile selector window. ### Fixed - Fix crash when creating a new map from a layout that has no pre-existing maps that use it. - Fix bug where `var_value`, `trainer_type` and `trainer_sight_or_berry_tree_id` JSON fields were being interpreted as integers. ## [1.2.0] - 2019-02-04 ### Breaking Changes - New JSON map data format in pokeemerald and pokeruby from commits [82abc164dc9f6a74fdf0c535cc1621b7ed05318b](https://github.com/pret/pokeemerald/commit/82abc164dc9f6a74fdf0c535cc1621b7ed05318b) and [a0ba1b7c6353f7e4f3066025514c05b323a0123d](https://github.com/pret/pokeruby/commit/a0ba1b7c6353f7e4f3066025514c05b323a0123d). ### Added - Add "magic fill" mode to fill tool (hold down CTRL key). This fills all matching metatiles on the map, rather than only the contiguous region. - Add ability to import tileset palettes (JASC, .pal, .tpl, .gpl, .act). - Add ability to export tileset tiles as indexed .png images. The currently-selected palette is used. - Restore window sizes the next time the application is opened. - Add ability to import metatiles from Advance Map 1.92 (.bvd files). - Add About window that contains porymap information and changelog. (Found in file menu `Help > About Porymap`) - Add option to show player's in-game view when hovering the mouse on the map. - Add option to show an outline around the currently-hovered map tile. Its size depends on the size of the current metatile selection. - Add ability to define custom fields for map header and all events. ### Changed - Collapse the map list by default. - Collision view now has a transparency slider to help make it easier to view the underlying metatiles. - When importing tileset tiles from an image that is not indexed, the user can also provide a palette for the image. This is for the scenario where the user exports tiles and a palette from Advance Map. - When creating a new map, the user specifies all of the map properties in a new window prompt. - New maps can be created using existing layouts by right-clicking on an existing layout folder in the map list panel when sorted by "Layout". - The map list panel now has "expand-all" and "collapse-all" buttons. - Events without sprites are now partially transparent so the underlying metatile can be seen. (Warps, signs, etc.) - Changed the Trainer checkbox to a combobox, since there are actually 3 valid values for the trainer type. - Multiline comments are now respected when parsing C defines. - The tiles image in the tileset editor will no longer flip according to the x/y flip checkboxes. The individual tile selection still flips, though. ### Fixed - Fix bug where smart paths could be auto-enabled, despite the checkbox being disabled. - Fix crash that could occur when changing the palette id in the tileset palette editor. - Fix crash that could occur when shrinking the number of metatiles in a tileset. - Fix bug where exported tile images from Advance Map were not handled correctly due to Advance Map using incorrect file extensions. ## [1.1.0] - 2018-12-27 ### Breaking Changes - New map header format in pokeemerald from commit [a1ea3b5e394bc115ba9b86348c161094a00dcca7](https://github.com/pret/pokeemerald/commit/a1ea3b5e394bc115ba9b86348c161094a00dcca7). ### Added - Add `porymap.project.cfg` config file to project repos, in order to house project-specific settings, such as `base_game_version=pokeemerald`. - Write all logs to `porymap.log` file, so users can view any errors that porymap hits. - Changelog ### Changed - Add `porymap.cfg` base config file, rather than using built-in system settings (e.g. registry on Windows). - Properly read/write map headers for `pokeemerald`. - Overhauled event editing pane, which now contains tabs for each different event. Events of the same type can be iterated through using the spinner at the top of the tab. This makes it possible to edit events that are outside the viewing window. ### Fixed - Creating new hidden-item events now uses a valid default flag value. - Fix bug where tilesets were sometimes not displaying their bottom row of metatiles. - Fix bug where porymap crashes on startup due to missing map headers. - Fix tileset editor crash that only happened on macOS. - Fix minor bug when parsing C defines. - Write `MAP_GROUPS_COUNT` define to `maps.h`. - Fix bug where opening multiple projects and saving would cause junk to be written to `layouts_table.inc`. - Fix porymap icon on macOS. ## [1.0.0] - 2018-10-26 This was the initial release. [Unreleased]: https://github.com/huderlem/porymap/compare/4.5.0...HEAD [4.5.0]: https://github.com/huderlem/porymap/compare/4.4.0...4.5.0 [4.4.0]: https://github.com/huderlem/porymap/compare/4.3.1...4.4.0 [4.3.1]: https://github.com/huderlem/porymap/compare/4.3.0...4.3.1 [4.3.0]: https://github.com/huderlem/porymap/compare/4.2.0...4.3.0 [4.2.0]: https://github.com/huderlem/porymap/compare/4.1.0...4.2.0 [4.1.0]: https://github.com/huderlem/porymap/compare/4.0.0...4.1.0 [4.0.0]: https://github.com/huderlem/porymap/compare/3.0.1...4.0.0 [3.0.1]: https://github.com/huderlem/porymap/compare/3.0.0...3.0.1 [3.0.0]: https://github.com/huderlem/porymap/compare/2.0.0...3.0.0 [2.0.0]: https://github.com/huderlem/porymap/compare/1.2.2...2.0.0 [1.2.2]: https://github.com/huderlem/porymap/compare/1.2.1...1.2.2 [1.2.1]: https://github.com/huderlem/porymap/compare/1.2.0...1.2.1 [1.2.0]: https://github.com/huderlem/porymap/compare/1.1.0...1.2.0 [1.1.0]: https://github.com/huderlem/porymap/compare/1.0.0...1.1.0 [1.0.0]: https://github.com/huderlem/porymap/tree/1.0.0