diff --git a/CHANGELOG.md b/CHANGELOG.md index a210459f..4589e78b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,22 +11,22 @@ The **"Breaking Changes"** listed below are changes that have been made in the d - 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. - Arguments for the API function `createImage` have changed: `xflip` and `yflip` have been replaced with `hScale` and `vScale`, and `offset` has been replaced with `xOffset` and `yOffset`. +- The API function `addFilledRect` has been removed; it's been replaced by new arguments in `addRect`: `color` has been replaced with `borderColor` and `fillColor`, and a new `rounding` argument allows ellipses to be drawn. ### Added - Add prefab support - Add Cut/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 ability to export an image of the primary or secondary tileset's metatiles. - 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. +- Add new features to the scripting API, including the ability to display messages and user input windows, set the overlay's opacity, rotation, scale, and clipping, interact with map header properties and the map border, read tile pixel data, and more. ### 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. +- Unused metatile attribute bits 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. @@ -34,6 +34,7 @@ The **"Breaking Changes"** listed below are changes that have been made in the d - 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. - The metatile behavior is now displayed in the bottom bar mouseover text. +- Removed some unnecessary error logs from the scripting API and added new useful ones. ### Fixed - Fix cursor tile outline not updating at the end of a dragged selection. @@ -43,8 +44,9 @@ The **"Breaking Changes"** listed below are changes that have been made in the d - 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 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. +- Fix drawing large amounts of text with the scripting API causing a significant drop in performance. - Silence unnecessary error logging when parsing C defines Porymap doesn't use. - Fix some windows like the Tileset Editor not raising to the front when reactivated. diff --git a/docsrc/manual/scripting-capabilities.rst b/docsrc/manual/scripting-capabilities.rst index fda7de02..f5acd7f3 100644 --- a/docsrc/manual/scripting-capabilities.rst +++ b/docsrc/manual/scripting-capabilities.rst @@ -936,7 +936,7 @@ All tileset functions are callable via the global ``map`` object. Overlay Functions ^^^^^^^^^^^^^^^^^ -The following functions are related to an overlay that is drawn on top of the map area. Text, images, and shapes can be drawn using these functions. Items can be drawn and manipulated on separate layers by specifiying a layer id. Items on higher layer ids will be drawn above those on lower layers. The visibility, position, and opacity of each layer can be changed; by default all layers are visible, at position ``0,0``, and have an opacity of ``100``. +The following functions are related to an overlay that is drawn on top of the map area. Text, images, and shapes can be drawn using these functions. Items can be drawn and manipulated on separate layers by specifiying a layer id. Items on higher layer ids will be drawn above those on lower layers. The visibility, opacity, position, rotation, and scale of each layer can be changed; by default all layers are visible, have an opacity of ``100``, are at position ``0,0``, an angle of ``0``, and a horizontal and vertical scale of ``1.0``. All overlay functions are callable via the global ``overlay`` object. @@ -1010,6 +1010,79 @@ All overlay functions are callable via the global ``overlay`` object. :param number opacity: the opacity +.. js:function:: overlay.getHorizontalScale(layer = 0) + + Gets the horizontal scale of the specified overlay layer. ``1.0`` is normal size. + + :param number layer: the layer id. Defaults to ``0`` + :returns number: the scale + +.. js:function:: overlay.getVerticalScale(layer = 0) + + Gets the vertical scale of the specified overlay layer. ``1.0`` is normal size. + + :param number layer: the layer id. Defaults to ``0`` + :returns number: the scale + +.. js:function:: overlay.setHorizontalScale(scale, layer) + + Sets the horizontal scale of the specified overlay layer. ``1.0`` is normal size. + + :param number scale: the scale to set + :param number layer: the layer id + +.. js:function:: overlay.setHorizontalScale(scale) + + This is an overloaded function. Sets the horizontal scale of all active overlay layers. Layers that have not been used yet will not have their scale changed. ``1.0`` is normal size. + + :param number scale: the scale to set + +.. js:function:: overlay.setVerticalScale(scale, layer) + + Sets the vertical scale of the specified overlay layer. ``1.0`` is normal size. + + :param number scale: the scale to set + :param number layer: the layer id + +.. js:function:: overlay.setVerticalScale(scale) + + This is an overloaded function. Sets the vertical scale of all active overlay layers. Layers that have not been used yet will not have their scale changed. ``1.0`` is normal size. + + :param number scale: the scale to set + +.. js:function:: overlay.getAngle(layer = 0) + + Gets the angle the specified overlay layer is rotated to. + + :param number layer: the layer id. Defaults to ``0`` + :returns number: the angle + +.. js:function:: overlay.setAngle(angle, layer) + + Sets the angle the specified overlay layer is rotated to. + + :param number angle: the angle to set + :param number layer: the layer id + +.. js:function:: overlay.setAngle(angle) + + This is an overloaded function. Sets the angle that all active overlay layers are rotated to. Layers that have not been used yet will not have their angle changed. + + :param number angle: the angle to set + +.. js:function:: overlay.rotate(degrees, layer) + + Rotates the specified overlay layer. A positive number of degrees is clockwise rotation, a negative number of degrees is counterclockwise rotation. + + :param number degrees: the number of degrees to rotate + :param number layer: the layer id + +.. js:function:: overlay.rotate(degrees) + + This is an overloaded function. Rotates the all active overlay layers. Layers that have not been used yet will not be rotated. A positive number of degrees is clockwise rotation, a negative number of degrees is counterclockwise rotation. + + :param number degrees: the number of degrees to rotate + .. js:function:: overlay.getX(layer = 0) Gets the x position of the specified overlay layer. @@ -1123,11 +1196,11 @@ All overlay functions are callable via the global ``overlay`` object. :param string text: the text to display :param number x: the x pixel coordinate of the text (relative to the layer's position) :param number y: the y pixel coordinate of the text (relative to the layer's position) - :param string color: the color of the text. Can be specified as "#RRGGBB" or "#AARRGGBB". Defaults to black. + :param string color: the color of the text. Can be specified as ``"#RRGGBB"`` or ``"#AARRGGBB"``. Defaults to black. :param number size: the font size of the text. Defaults to 12. :param number layer: the layer id. Defaults to ``0`` -.. js:function:: overlay.addRect(x, y, width, height, color = "#000000", layer = 0) +.. js:function:: overlay.addRect(x, y, width, height, borderColor = "#000000", fillColor = "", rounding = 0, layer = 0) Adds a rectangle outline item to the specified overlay layer. @@ -1135,18 +1208,19 @@ All overlay functions are callable via the global ``overlay`` object. :param number y: the y pixel coordinate of the rectangle's top-left corner (relative to the layer's position) :param number width: the pixel width of the rectangle :param number height: the pixel height of the rectangle - :param string color: the color of the rectangle. Can be specified as "#RRGGBB" or "#AARRGGBB". Defaults to black. + :param string borderColor: the color of the rectangle's border. Can be specified as ``"#RRGGBB"`` or ``"#AARRGGBB"``. Defaults to black. + :param string fillColor: the color of the area enclosed by the rectangle. Can be specified as ``"#RRGGBB"`` or ``"#AARRGGBB"``. Defaults to transparent. + :param number rounding: the percent degree the corners will be rounded. ``0`` is rectangular, ``100`` is elliptical. Defaults to ``0`` :param number layer: the layer id. Defaults to ``0`` -.. js:function:: overlay.addFilledRect(x, y, width, height, color = "#000000", layer = 0) +.. js:function:: overlay.addPath(xCoords, yCoords, borderColor = "#000000", fillColor = "", layer = 0) - Adds a filled rectangle item to the specified overlay layer. + Draws a straight path on the specified layer by connecting the coordinates at (``xCoords``, ``yCoords``). The area enclosed by the path can be colored in, and will follow the `"odd-even" fill rule `_. - :param number x: the x pixel coordinate of the rectangle's top-left corner (relative to the layer's position) - :param number y: the y pixel coordinate of the rectangle's top-left corner (relative to the layer's position) - :param number width: the pixel width of the rectangle - :param number height: the pixel height of the rectangle - :param string color: the color of the rectangle. Can be specified as "#RRGGBB" or "#AARRGGBB". Defaults to black. + :param array xCoords: array of x pixel coordinates to connect to create the path + :param array yCoords: array of y pixel coordinates to connect to create the path + :param string borderColor: the color of the path. Can be specified as ``"#RRGGBB"`` or ``"#AARRGGBB"``. Defaults to black. + :param string fillColor: the color of the area enclosed by the path. Can be specified as ``"#RRGGBB"`` or ``"#AARRGGBB"``. Defaults to transparent. :param number layer: the layer id. Defaults to ``0`` .. js:function:: overlay.addImage(x, y, filepath, layer = 0, useCache = true)