[mapserver-users] mapserver vs mapscript: agg + transparency + quantize not working
Tiemens, Gerben
Gerben.Tiemens at grontmij.nl
Mon Nov 9 01:50:09 PST 2009
Bug filed:
http://trac.osgeo.org/mapserver/ticket/3201#preview
Greets
Gerben
-----Oorspronkelijk bericht-----
Van: Tiemens, Gerben
Verzonden: Friday, November 06, 2009 11:41 AM
Aan: Tiemens, Gerben
CC: mapser all users; mapserver-dev at lists.osgeo.org
Onderwerp: RE: [mapserver-users] mapserver vs mapscript: agg + transparency + quantize not working
Also imageObj.Write(stream) makes use of the msSaveImageBufferGD()
Which results in the same error message
Is there any other possibility to save the byteArray of an imageobj with renderer AGG or is this just a bug in mapscript C#?
Greetings
Gerben
-----Oorspronkelijk bericht-----
Van: Tiemens, Gerben
Verzonden: Friday, November 06, 2009 9:30 AM
Aan: Tiemens, Gerben
CC: mapser all users; mapserver-dev at lists.osgeo.org
Onderwerp: RE: [mapserver-users] mapserver vs mapscript: agg + transparency + quantize not working
Drilled down further to the problem.
I use ImageObj.getBytes() to get the bytearray and then save the png in an other part of my code.
However, the getBytes() method uses the msSaveImageBufferGD() even when my imageObj/mapObj uses an outputformat with AGG.
This results in an error in the new beta (5.6.0 beta 5) with the message:
- base {"getBytes: General error message. Failed to get image buffer;msSaveImageBufferGD(): Image handling error. Unknown output image type driver: gd/."} System.Exception {System.ApplicationException}
In previous versions the error was not given, but just went further with making a crippled image.
Is there an other method to save the bytearray of an AGG image?
Greetings
Gerben
-----Oorspronkelijk bericht-----
Van: mapserver-users-bounces at lists.osgeo.org [mailto:mapserver-users-bounces at lists.osgeo.org] Namens Tiemens, Gerben
Verzonden: Thursday, November 05, 2009 9:01 PM
Aan: Roger André
CC: mapser all users
Onderwerp: RE: [mapserver-users] mapserver vs mapscript: agg + transparency + quantize not working
Thanks for your reply Roger André,
But i specified my own outputformat in mapscript.
When using this outputformat without the quantize options, the image comes out as wished and configured. (transparent and fullcolor) When using this outputformat with the quantize options on:
-with the CGI mapserv.exe (and the saved mapfile from mapscript) the image is as configured. (transparent and all needed colors in a small png) -with mapscript, the mapobj.draw(), the image is crippled and not as wished.(not transparent, black lines are strange and labels are disapearing) It should be equal to CGI.
I do'nt know why this difference between mapscript and mapserv.exe exists with the same configuration of mapfile.
Has someone an idea?
I tested this on MS4W 2.29 (mapserver 5.2.0) and MS4W 3.0 (mapserver 5.4.2)
Greetings
Gerben
________________________________________
Van: Roger André [randre at gmail.com]
Verzonden: donderdag 5 november 2009 19:55
Aan: Tiemens, Gerben
CC: mapser all users
Onderwerp: Re: [mapserver-users] mapserver vs mapscript: agg + transparency + quantize not working
Hi Tiemens,
Not sure if this helps, but in some of the testing I did with Python mapscript, I specified the following in my code:
map.selectOutputFormat("AGGPNG24")
That seemed to do the trick for me. The script is inline below, in case it might help give context.
Roger
--
#! /usr/bin/python
# mimic the Mapnik 'hello world' at
# http://trac.mapnik.org/wiki/GettingStarted
# based on example in Web Mapping Illustrated
import mapscript
# create a base mapfile
map = mapscript.mapObj()
map.selectOutputFormat("AGGPNG24")
map.name<http://map.name> = "CustomMap"
map.setSize(1000, 500)
#map.setExtent(-180.0, -90.0, 180.0, 90.0) map.setExtent(-22, -36, 60, 38)
map.imagecolor.setRGB(70,130,180)
map.units = mapscript.MS_DD
# set Web image params
map.web.imagepath = "/var/www/tmp/"
map.web.imageurl = "/tmp"
# create layer object
layer = mapscript.layerObj(map)
layer.name<http://layer.name> = "countries"
#layer.type = mapscript.MS_LAYER_LINE
layer.type = mapscript.MS_LAYER_POLYGON
layer.status = mapscript.MS_DEFAULT
layer.data = "/home/randre/gis_data/unep/unep_coastlines.shp"
layer.template = "template.html"
# create a class
class1 = mapscript.classObj(layer)
class1.name<http://class1.name> = "Countries"
# create a style
style = mapscript.styleObj(class1)
style.outlinecolor.setRGB(125,125,125)
style.width = 1
style.color.setRGB(240,240,240)
#style.antialias = mapscript.MS_TRUE
# write the map object into a map file
#map.save("custom.map")
# write out an image using these params
mapimage = map.draw()
mapimage.save("ms_world.png")
--
On Thu, Nov 5, 2009 at 9:04 AM, Tiemens, Gerben <Gerben.Tiemens at grontmij.nl<mailto:Gerben.Tiemens at grontmij.nl>> wrote:
I am busy writing a application with mapscript in C#.
Currently I am facing the earlier mentioned problems of agg + transparent images + quantization.
Is the new MS4W compiled with the quantization options?
The image background is now Black. The labels are dissapearing.
It should be an image wich is completly transparent with some colored lines and some black labels.
Setting the imagecolor will not help me.
Images without quantization options on, are perfect and beautiful png's.
What I am using now is this:
MS4W 3.0 Beta 7 which contains Mapserver 5.4.2
C# mapscript
Mapfile is completely written in C#, so all default options apply.
I saved this mapfile from my mapobj
----------------------
MAP
EXTENT 104952 495303 105452 495803
IMAGECOLOR 255 255 255
IMAGETYPE gif
SIZE 2000 2000
STATUS ON
UNITS METERS
NAME "MS"
OUTPUTFORMAT
NAME "PNG_mapscript"
MIMETYPE "image/png; mode=24bit"
DRIVER "AGG/PNG"
EXTENSION "PNG"
IMAGEMODE "RGBA"
TRANSPARENT TRUE
FORMATOPTION "QUANTIZE_FORCE=on"
FORMATOPTION "QUANTIZE_DITHER=off"
FORMATOPTION "QUANTIZE_COLORS=256"
END
SYMBOL
NAME "circle"
TYPE ELLIPSE
FILLED TRUE
POINTS
1 1
END
END
--
*snip*
--
END
----------------------------------------
In addition to above: further testing revealed that the transparent color is always black.
So if I set
imagecolor 99 99 99
transparent = true
And outputformat to:
OUTPUTFORMAT
NAME "PNG_mapscript"
MIMETYPE "image/png"
DRIVER "GD/PNG"
EXTENSION "PNG"
IMAGEMODE "RGBA"
TRANSPARENT TRUE
FORMATOPTION "QUANTIZE_FORCE=on"
FORMATOPTION "QUANTIZE_COLORS=256"
FORMATOPTION "QUANTIZE_NEW=on"
END
The image appears grey.
The black labels with white backgroundcolor and black shadowcolor in original image are mapped to: white background with gray outline characters and transparent filling and the shadow is grayoutlined with transparent filling. Probably the antialiasing generates the grey outline, the black filling is converted to transparent.
Something is going wrong.
If I set output format to:
OUTPUTFORMAT
NAME "PNG_mapscript"
MIMETYPE "image/png; mode=24bit"
DRIVER "AGG/PNG"
EXTENSION "PNG"
IMAGEMODE "RGBA"
TRANSPARENT TRUE
FORMATOPTION "QUANTIZE_FORCE=on"
FORMATOPTION "QUANTIZE_DITHER=off"
FORMATOPTION "QUANTIZE_COLORS=256"
END
The same applies for the text/labels, but background of the image is now black in all circumstances (no matter what color of imagecolor setting.
---------------------------------------------------
Further research drills down to where the problem may occur:
If i test my saved mapfile from mapscript into the apache/cgi-bin/mapserv.exe
The image is coming out as it should be.
Transparent background, features like it should be, and text also as it should be., but if I use the draw() method from mapscript, it comes out crippled.
Am i doing something wrong in mapscript? Are there configurations that I may miss in mapscript that are default in mapserv.exe?
I also do'nt know if this is a problem of Mapserver or MS4W, therefore crossposting it.
Greetings
Gerben
<< Please read our E-mail Disclaimer at: Emaildisclaimer.Grontmij.com<http://Emaildisclaimer.Grontmij.com> >>
_______________________________________________
mapserver-users mailing list
mapserver-users at lists.osgeo.org<mailto:mapserver-users at lists.osgeo.org>
http://lists.osgeo.org/mailman/listinfo/mapserver-users
<< Please read our E-mail Disclaimer at: Emaildisclaimer.Grontmij.com >> _______________________________________________
mapserver-users mailing list
mapserver-users at lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/mapserver-users
More information about the MapServer-users
mailing list