2012-01-08 15:01:54 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import mapnik
|
2012-09-28 03:58:50 +02:00
|
|
|
mapnik.logger.set_severity(mapnik.severity_type.None)
|
|
|
|
|
2012-01-08 15:01:54 +01:00
|
|
|
import sys
|
|
|
|
import os.path
|
2012-09-28 03:58:50 +02:00
|
|
|
from compare import compare, summary, fail
|
2012-01-08 15:01:54 +01:00
|
|
|
|
2012-10-03 06:18:45 +02:00
|
|
|
visual_output_dir = "/tmp/mapnik-visual-images"
|
|
|
|
|
2012-03-20 22:06:22 +01:00
|
|
|
defaults = {
|
2012-09-26 20:28:23 +02:00
|
|
|
'sizes': [(500, 100)]
|
2012-03-20 22:06:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
sizes_many_in_big_range = [(800, 100), (600, 100), (400, 100),
|
|
|
|
(300, 100), (250, 100), (150, 100), (100, 100)]
|
|
|
|
|
|
|
|
sizes_few_square = [(800, 800), (600, 600), (400, 400), (200, 200)]
|
|
|
|
sizes_many_in_small_range = [(490, 100), (495, 100), (497, 100), (498, 100),
|
|
|
|
(499, 100), (500, 100), (501, 100), (502, 100), (505, 100), (510, 100)]
|
|
|
|
|
2012-09-26 20:28:23 +02:00
|
|
|
default_text_box = mapnik.Box2d(-0.05, -0.01, 0.95, 0.01)
|
|
|
|
|
2012-03-09 02:01:51 +01:00
|
|
|
dirname = os.path.dirname(__file__)
|
2012-03-23 20:42:11 +01:00
|
|
|
|
2012-02-20 17:42:12 +01:00
|
|
|
files = [
|
2012-09-26 20:28:23 +02:00
|
|
|
{'name': "list", 'sizes': sizes_many_in_big_range,'bbox':default_text_box},
|
|
|
|
{'name': "simple", 'sizes': sizes_many_in_big_range,'bbox':default_text_box},
|
|
|
|
{'name': "lines-1", 'sizes': sizes_few_square,'bbox':default_text_box},
|
|
|
|
{'name': "lines-2", 'sizes': sizes_few_square,'bbox':default_text_box},
|
|
|
|
{'name': "lines-3", 'sizes': sizes_few_square,'bbox':default_text_box},
|
2012-08-17 01:56:43 +02:00
|
|
|
{'name': "lines-4", 'sizes': sizes_few_square},
|
|
|
|
{'name': "lines-5", 'sizes': sizes_few_square},
|
|
|
|
{'name': "lines-6", 'sizes': sizes_few_square},
|
2012-09-26 20:28:23 +02:00
|
|
|
{'name': "lines-shield", 'sizes': sizes_few_square,'bbox':default_text_box},
|
|
|
|
{'name': "simple-E", 'bbox':mapnik.Box2d(-0.05, -0.01, 0.95, 0.01)},
|
|
|
|
{'name': "simple-NE",'bbox':default_text_box},
|
|
|
|
{'name': "simple-NW",'bbox':default_text_box},
|
|
|
|
{'name': "simple-N",'bbox':default_text_box},
|
|
|
|
{'name': "simple-SE",'bbox':default_text_box},
|
|
|
|
{'name': "simple-SW",'bbox':default_text_box},
|
|
|
|
{'name': "simple-S",'bbox':default_text_box},
|
|
|
|
{'name': "simple-W",'bbox':default_text_box},
|
|
|
|
{'name': "formatting-1",'bbox':default_text_box},
|
|
|
|
{'name': "formatting-2",'bbox':default_text_box},
|
|
|
|
{'name': "formatting-3",'bbox':default_text_box},
|
|
|
|
{'name': "formatting-4",'bbox':default_text_box},
|
2013-03-16 12:21:31 +01:00
|
|
|
{'name': "formatting", 'bbox':default_text_box},
|
2012-09-26 20:28:23 +02:00
|
|
|
{'name': "expressionformat",'bbox':default_text_box},
|
|
|
|
{'name': "shieldsymbolizer-1", 'sizes': sizes_many_in_small_range,'bbox':default_text_box},
|
|
|
|
{'name': "rtl-point", 'sizes': [(200, 200)],'bbox':default_text_box},
|
|
|
|
{'name': "jalign-auto", 'sizes': [(200, 200)],'bbox':default_text_box},
|
|
|
|
{'name': "line-offset", 'sizes':[(900, 250)],'bbox': mapnik.Box2d(-5.192, 50.189, -5.174, 50.195)},
|
|
|
|
{'name': "tiff-alpha-gdal", 'sizes':[(600,400)]},
|
|
|
|
{'name': "tiff-alpha-raster", 'sizes':[(600,400)]},
|
2012-09-29 00:07:33 +02:00
|
|
|
{'name': "tiff-alpha-broken-assoc-alpha-gdal", 'sizes':[(600,400)]},
|
|
|
|
{'name': "tiff-alpha-broken-assoc-alpha-raster", 'sizes':[(600,400)]},
|
2012-09-26 21:01:28 +02:00
|
|
|
{'name': "tiff-alpha-gradient-gdal", 'sizes':[(600,400)]},
|
|
|
|
{'name': "tiff-nodata-edge-gdal", 'sizes':[(600,400)]},
|
|
|
|
{'name': "tiff-nodata-edge-raster", 'sizes':[(600,400)]},
|
2012-09-28 20:19:20 +02:00
|
|
|
{'name': "tiff-opaque-edge-gdal", 'sizes':[(256,256)]},
|
2012-09-28 04:11:11 +02:00
|
|
|
{'name': "tiff-opaque-edge-raster", 'sizes':[(256,256)]},
|
2012-10-02 00:05:07 +02:00
|
|
|
{'name': "tiff-opaque-edge-gdal2", 'sizes':[(600,400)]},
|
|
|
|
{'name': "tiff-opaque-edge-raster2", 'sizes':[(600,400)]},
|
2012-08-17 01:56:43 +02:00
|
|
|
{'name': "shieldsymbolizer-2"},
|
|
|
|
{'name': "shieldsymbolizer-3"},
|
2013-03-16 12:34:59 +01:00
|
|
|
{'name': "shieldsymbolizer-4"},
|
2012-08-02 01:12:52 +02:00
|
|
|
{'name': "orientation", 'sizes': [(800, 200)]},
|
2012-09-13 23:35:42 +02:00
|
|
|
{'name': "hb-fontsets", 'sizes': [(800, 200)]},
|
|
|
|
{'name': "charspacing", 'sizes': [(200, 400)]},
|
2012-09-14 18:05:52 +02:00
|
|
|
{'name': "line_break", 'sizes': [(800, 800)]},
|
2012-03-16 00:38:03 +01:00
|
|
|
]
|
2012-02-17 23:19:07 +01:00
|
|
|
|
2012-04-04 23:54:07 +02:00
|
|
|
def render(filename, width, height, bbox, quiet=False):
|
2012-03-02 01:45:44 +01:00
|
|
|
m = mapnik.Map(width, height)
|
2012-04-17 07:07:14 +02:00
|
|
|
expected = os.path.join(dirname, "images", '%s-%d-reference.png' % (filename, width))
|
2012-10-03 06:18:45 +02:00
|
|
|
actual = '%s-%d' % (filename, width)
|
2012-09-28 03:58:50 +02:00
|
|
|
try:
|
2012-09-29 00:07:33 +02:00
|
|
|
mapnik.load_map(m, os.path.join(dirname, "styles", "%s.xml" % filename), False)
|
|
|
|
if bbox is not None:
|
|
|
|
m.zoom_to_box(bbox)
|
|
|
|
else:
|
|
|
|
m.zoom_all()
|
2012-10-03 06:18:45 +02:00
|
|
|
except Exception, e:
|
|
|
|
sys.stderr.write(e.message + '\n')
|
|
|
|
fail(actual,expected,str(e.message))
|
|
|
|
return
|
|
|
|
actual_agg = os.path.join(visual_output_dir, '%s-agg.png' % actual)
|
|
|
|
if not quiet:
|
|
|
|
print "\"%s\" with size %dx%d with agg..." % (filename, width, height),
|
|
|
|
try:
|
|
|
|
mapnik.render_to_file(m, actual_agg)
|
|
|
|
diff = compare(actual_agg, expected)
|
2012-09-28 04:24:02 +02:00
|
|
|
if not quiet:
|
|
|
|
if diff > 0:
|
|
|
|
print '\x1b[31m✘\x1b[0m (\x1b[34m%u different pixels\x1b[0m)' % diff
|
|
|
|
else:
|
|
|
|
print '\x1b[32m✓\x1b[0m'
|
2012-09-28 03:58:50 +02:00
|
|
|
except Exception, e:
|
|
|
|
sys.stderr.write(e.message + '\n')
|
2012-10-03 06:18:45 +02:00
|
|
|
fail(actual_agg,expected,str(e.message))
|
|
|
|
if 'tiff' in actual:
|
|
|
|
actual_cairo = os.path.join(visual_output_dir, '%s-cairo.png' % actual)
|
|
|
|
if not quiet:
|
|
|
|
print "\"%s\" with size %dx%d with cairo..." % (filename, width, height),
|
|
|
|
try:
|
|
|
|
mapnik.render_to_file(m, actual_cairo,'ARGB32')
|
|
|
|
diff = compare(actual_cairo, expected)
|
|
|
|
if not quiet:
|
|
|
|
if diff > 0:
|
|
|
|
print '\x1b[31m✘\x1b[0m (\x1b[34m%u different pixels\x1b[0m)' % diff
|
|
|
|
else:
|
|
|
|
print '\x1b[32m✓\x1b[0m'
|
|
|
|
except Exception, e:
|
|
|
|
sys.stderr.write(e.message + '\n')
|
|
|
|
fail(actual_cairo,expected,str(e.message))
|
2012-01-08 15:01:54 +01:00
|
|
|
return m
|
2012-02-24 22:13:56 +01:00
|
|
|
|
2012-04-04 23:54:07 +02:00
|
|
|
if __name__ == "__main__":
|
|
|
|
if '-q' in sys.argv:
|
|
|
|
quiet = True
|
|
|
|
sys.argv.remove('-q')
|
|
|
|
else:
|
|
|
|
quiet = False
|
|
|
|
|
2012-08-21 21:23:05 +02:00
|
|
|
if len(sys.argv) <= 1:
|
|
|
|
active = files
|
|
|
|
elif len(sys.argv) == 2:
|
|
|
|
active = [{"name": sys.argv[1], "sizes": sizes_few_square}]
|
2012-04-04 23:54:07 +02:00
|
|
|
elif len(sys.argv) > 2:
|
2012-08-21 21:23:05 +02:00
|
|
|
active = []
|
|
|
|
if sys.argv[1] == "-s":
|
|
|
|
name = sys.argv[2]
|
|
|
|
for f in files:
|
|
|
|
if f['name'] == name:
|
|
|
|
active.append(f)
|
|
|
|
else:
|
|
|
|
for name in sys.argv[1:]:
|
|
|
|
active.append({"name": name})
|
2012-02-24 22:13:56 +01:00
|
|
|
|
2012-10-03 06:18:45 +02:00
|
|
|
if not os.path.exists(visual_output_dir):
|
|
|
|
os.makedirs(visual_output_dir)
|
|
|
|
|
2012-09-08 00:43:32 +02:00
|
|
|
if 'osm' in mapnik.DatasourceCache.plugin_names():
|
2012-09-13 23:35:42 +02:00
|
|
|
for f in active:
|
2012-08-16 04:22:47 +02:00
|
|
|
config = dict(defaults)
|
|
|
|
config.update(f)
|
|
|
|
for size in config['sizes']:
|
2012-09-26 20:28:23 +02:00
|
|
|
m = render(config['name'], size[0], size[1], config.get('bbox'), quiet=quiet)
|
2012-08-16 04:22:47 +02:00
|
|
|
mapnik.save_map(m, os.path.join(dirname, 'xml_output', "%s-out.xml" % config['name']))
|
2012-01-25 00:00:09 +01:00
|
|
|
|
2012-09-26 20:28:23 +02:00
|
|
|
summary(generate=False)
|