Haxe map importer for Pyxel Edit (free version 0.2.22c)
- Export your map File > Export tilemap as XML...
- Export your tileset File > Export tileset...
Make use of the PyxelEdit-Map-Importer tools with import pmi.PyxelMapImporter
Assuming you're not necessarily using any graphical framework (server for example) :
var pyxelMap = new PyxelMapImporter(sys.io.File.getContent("map.xml"));
will load the xml pyxel map. The argument is the xml content as String
.
var background = pyxelMap.getDatasFromLayer("background");
"background"
is the name of the layer in PyxelEdit.background
(the variable) is an array ofMap<String, String>
.
Each item of the array contain the keys : x
, y
, index
,rot
& flipX
as it is in the XML, those datas are exposed in an cleaner way than the XML file and let you use some of the parameters i'm not using in the other methods.
var backgroundArray = pyxelMap.getLayerArray(background)
will return an map array of type Array<Array<Int>>
allowing you to check the tile ID with backgroundArray[x][y]
.
You can also use it to get a collision map. If, for example, you name a PyxelEdit layer "collision" and dedicate a red tile for collisions, you can then extract that layer and check if there is a collision with a simple collisionArray[x][y]
.
IDs are assigned in order of appearance in your Pyxel Edit tileset window :
So let's say your collision red tile is at the rank 5, to check a collision you'll have to check if collisionArray[x][y] == 5
: This is not a 0/1 collision map.
No tiles is defaulted to -1
.
import pmi.PyxelMapImporter;
import pmi.OpenflHelper;
class Main extends Sprite
{
public function new()
{
super();
var pyxelMap = new PyxelMapImporter(sys.io.File.getContent("map.xml"));
var background = pyxelMap.getDatasFromLayer("background");
var backgroundArray = pyxelMap.getLayerArray(background);
}
}
You can make use of pmi.OpenflHelper
to get a tilesheet object and a tile array easily.
var tilemapBackground = OpenflHelper.getTilesheetArray(background);
will return anArray<Float>
.var tilesheet = OpenflHelper.getTilesheet("assets/map.png");
will return a tilesheet object.
and that's all you need.
It will load three different layers and will draw them on screen.
import flash.display.Sprite;
import openfl.Assets;
import pmi.PyxelMapImporter;
import pmi.OpenflHelper;
class Main extends Sprite
{
public function new()
{
super();
var pyxelMap = new PyxelMapImporter(Assets.getText("assets/map.xml"));
var background = pyxelMap.getDatasFromLayer("background");
var walls = pyxelMap.getDatasFromLayer("walls");
var objects = pyxelMap.getDatasFromLayer("objects");
var tilemapBackground = OpenflHelper.getTilesheetArray(background);
var tilemapWalls = OpenflHelper.getTilesheetArray(walls);
var tilemapObjects = OpenflHelper.getTilesheetArray(objects);
var tilesheet = OpenflHelper.getTilesheet("assets/map.png");
tilesheet.drawTiles(flash.Lib.current.graphics, tilemapBackground);
tilesheet.drawTiles(flash.Lib.current.graphics, tilemapWalls);
tilesheet.drawTiles(flash.Lib.current.graphics, tilemapObjects);
}
}