summaryrefslogtreecommitdiff
path: root/client/minimap-render.py
diff options
context:
space:
mode:
authorVincent Petithory <vincent.petithory@gmail.com>2013-02-18 23:11:40 +0100
committerVincent Petithory <vincent.petithory@gmail.com>2013-02-18 23:32:23 +0100
commit2daee52eec6ace68bf49779acba61056aeba11be (patch)
treed03e3d310ffa724eb1c7b912304b18fe08b1bfd2 /client/minimap-render.py
parent40623c146ac1e5210d20bcb47d313c2659c665f2 (diff)
downloadtools-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-xclient/minimap-render.py23
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())