diff options
author | Vincent Petithory <vincent.petithory@gmail.com> | 2013-02-18 23:11:40 +0100 |
---|---|---|
committer | Vincent Petithory <vincent.petithory@gmail.com> | 2013-02-18 23:32:23 +0100 |
commit | 2daee52eec6ace68bf49779acba61056aeba11be (patch) | |
tree | d03e3d310ffa724eb1c7b912304b18fe08b1bfd2 /client/minimap-render.py | |
parent | 40623c146ac1e5210d20bcb47d313c2659c665f2 (diff) | |
download | tools-2daee52eec6ace68bf49779acba61056aeba11be.tar.gz tools-2daee52eec6ace68bf49779acba61056aeba11be.tar.bz2 tools-2daee52eec6ace68bf49779acba61056aeba11be.tar.xz tools-2daee52eec6ace68bf49779acba61056aeba11be.zip |
Map tools: use new --tilesize option of tmwrasterizer and update some things
Diffstat (limited to 'client/minimap-render.py')
-rwxr-xr-x | client/minimap-render.py | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/client/minimap-render.py b/client/minimap-render.py index 402630b..6b6b009 100755 --- a/client/minimap-render.py +++ b/client/minimap-render.py @@ -22,9 +22,10 @@ class MinimapRenderer(object): }, } - def __init__(self, map_name, scale): + def __init__(self, map_name, tilesize, useAntiAliasing): self.map_name = map_name - self.scale = scale + self.tilesize = tilesize + self.useAntiAliasing = useAntiAliasing def render(self): """ @@ -58,11 +59,16 @@ class MinimapRenderer(object): platform_programs = MinimapRenderer.PROGRAMS.get(sys.platform, MinimapRenderer.PROGRAMS.get('default')) # tmx rasterize mrf, map_raster = tempfile.mkstemp(suffix='.png') - subprocess.check_call([platform_programs.get('tmxrasterizer'), '--scale', str(self.scale), tmx_file, map_raster]) + tmxrasterizer_cmd = [ + platform_programs.get('tmxrasterizer'), + '--tilesize', str(self.tilesize), + ] + if self.useAntiAliasing: + tmxrasterizer_cmd.append('--anti-aliasing') + tmxrasterizer_cmd += [tmx_file, map_raster] + subprocess.check_call(tmxrasterizer_cmd) if os.stat(map_raster).st_size == 0: - # the image couldnt be rendered. The most probable reason is - # that the map was too big (e.g 024-4, 500x500 tiles) - raise Exception('Map too large to be rendered.') + raise Exception('A problem was encountered when rendering a map') # add cell-shading to the minimap to improve readability ebf, edges_bitmap = tempfile.mkstemp(suffix='.png') subprocess.check_call([ @@ -140,9 +146,10 @@ def main(): status = 0 for map_name in sys.argv[1:]: - map_renderer = MinimapRenderer(map_name, 0.03125) # this scale renders 1px for a tile of 32px + # Render tiles at 1 pixel size + map_renderer = MinimapRenderer(map_name, 1, True) status += map_renderer.render() return status if __name__ == '__main__': - sys.exit(main())
\ No newline at end of file + sys.exit(main()) |