A rip of https://pkmnmap.com updated to Generation 4 of the Pokémon series. Uses Leaflet to generate an interactive map. Map assembled from resources from Bulbapedia. Item locations sourced from Techno Trainer's video series. Without these resources and the original code from Jaxson Keenes this project would not exist.
The site is available at https://pkmnmap4.web.app/.
-
Procure a high-resolution map of whatever you want to make a tileset out of. make sure the dimensions of the map image are easily halved, don't worry if you have to add a lot of whitespace
-
I've included my personal script for converting a large png into a tileset with multiple zoom levels in this respository as
ImageToTileset
inHelperTools.py
. It will resize your map to the various zoom levels, and for each resize it will split the image into 256x256 pixel tiles which then get arranged into the proper directory structure for Leaflet to be able to render your map. -
Install ImageMagick as a prerequisite for Wand
-
Install Wand as a prerequisite for HelperTools.py
-
Use the script
HelperTools.py
to generate the tilesets:To generate tilesets for every map in maps/
# note that you may need to adjust you ImageMagick policy.xml file to allow for larger images python HelperTools.py # or python HelperTools.py 5 # to specify the number or multiprocess
Or to generate a single tileset using as a python lib
from HelperTools import ImageToTileset ImageToTileset(r"[path to your png map]", r"[directory you want the tileset to be placed]")
-
To see your new map, you can update the
shortname
of the Overworld map in maps.js to point to the tileset directory, just make sure to changebounds
to be representative of your map's aspect ratio. Your smaller dimension should always be 128, and the larger dimension should be scaled to fit that ratio.
- Create a new tileset for your map using the above steps
- Add your map's information to
maps.js
- Add region data to the variable you defined in the map's information
- Add marker data for your interior using
markerSet(y, x, name, icon, mapname, [return location])
- return location is optional and intended for entrances, but should be a two element array that looks like
[[y, x], zoom]
. - return location determines where the camera should be centered when you enter the map. if no return location is specified, the camera is perfectly centered on the whole map.
- return location is optional and intended for entrances, but should be a two element array that looks like
- Finally, add an entrance marker to the overworld with the name matching the new map's name.
-
Open your final map png in an image editor like Paint.NET
-
Select the area you wish to turn into a clickable region
-
Make note of the following values: Selection top left coordinate, selection width and height.
-
Insert those values into my helper function:
from HelperTools import TranslateScale TranslateScale(s, x, y, w, h)
Note: Scale parameter
s
depends on the size of your map. A good way to find it is to divide the smallest dimension of your map by 512. In general, if your regions come out at half size, then halve the scale parameter. -
Copy and paste the output into the "coordinates" property of a feature in one of the vector js files.
Map files published under this repository are subject to a CC BY-NC-SA 2.5 license via Bulbapedia. You are free to share or adapt this material under the terms that you provide appropriate attribution, do not use the material for commercial purposes, and distribute your work under the same license.