Yes, I'm thinking about the following addition (in writeColor) if you don't mind.<div><br></div><div><div>if (color->alpha >= 0 && color->alpha < 255)</div><div> fprintf(stream, "%s \"#%02x%02x%02x%02x\"\n", name, color->red, color->green, color->blue, color->alpha);</div>
<div> else</div><div> fprintf(stream, "%s %d %d %d\n", name, color->red, color->green, color->blue);</div></div><div><br></div><div><br></div><div><br><br><div class="gmail_quote">2012/9/24 Lime, Steve D (DNR) <span dir="ltr"><<a href="mailto:Steve.Lime@state.mn.us" target="_blank">Steve.Lime@state.mn.us</a>></span><br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div lang="EN-US" link="blue" vlink="purple">
<div>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Could we just write hex if color->alpha<255? At least until all representations support it…<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"><u></u> <u></u></span></p>
<div style="border:none;border-top:solid #b5c4df 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">From:</span></b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif""> Tamas Szekeres [mailto:<a href="mailto:szekerest@gmail.com" target="_blank">szekerest@gmail.com</a>]
<br>
<b>Sent:</b> Monday, September 24, 2012 1:02 PM</span></p><div><div class="h5"><br>
<b>To:</b> Lime, Steve D (DNR)<br>
<b>Cc:</b> thomas bonfort; <a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br>
<b>Subject:</b> Re: [mapserver-dev] Handling alpha values in colors<u></u><u></u></div></div><p></p>
</div><div><div class="h5">
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">I think so. Here is the corresponding code in loadColor (mapfile.c):<u></u><u></u></p>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<div>
<p class="MsoNormal">if(symbol == MS_NUMBER) {<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> color->red = (int) msyynumber;<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if(getInteger(&(color->green)) == -1) return MS_FAILURE;<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if(getInteger(&(color->blue)) == -1) return MS_FAILURE;<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> } else if(symbol == MS_STRING) {<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> int len = strlen(msyystring_buffer);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if(msyystring_buffer[0] == '#' && (len == 7 || len == 9)) { /* got a hex color w/optional alpha */<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[0] = msyystring_buffer[1];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[1] = msyystring_buffer[2];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> color->red = msHexToInt(hex);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[0] = msyystring_buffer[3];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[1] = msyystring_buffer[4];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> color->green = msHexToInt(hex);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[0] = msyystring_buffer[5];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[1] = msyystring_buffer[6];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> color->blue = msHexToInt(hex);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> if(len == 9) {<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[0] = msyystring_buffer[7];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> hex[1] = msyystring_buffer[8];<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> color->alpha = msHexToInt(hex);<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> }<u></u><u></u></p>
</div>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Best regards,<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal">Tamas<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><u></u> <u></u></p>
<div>
<p class="MsoNormal">2012/9/24 Lime, Steve D (DNR) <<a href="mailto:Steve.Lime@state.mn.us" target="_blank">Steve.Lime@state.mn.us</a>><u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d">Is the only way a to have color with a non-opaque alpha<255 if it was originally entered that way
via hex?</span><u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1f497d"> </span><u></u><u></u></p>
<div style="border:none;border-top:solid #b5c4df 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif"">From:</span></b><span style="font-size:10.0pt;font-family:"Tahoma","sans-serif""> Tamas Szekeres [mailto:<a href="mailto:szekerest@gmail.com" target="_blank">szekerest@gmail.com</a>]
<br>
<b>Sent:</b> Monday, September 24, 2012 9:34 AM<br>
<b>To:</b> Lime, Steve D (DNR)<br>
<b>Cc:</b> thomas bonfort; <a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">
mapserver-dev@lists.osgeo.org</a></span><u></u><u></u></p>
<div>
<div>
<p class="MsoNormal"><br>
<b>Subject:</b> Re: [mapserver-dev] Handling alpha values in colors<u></u><u></u></p>
</div>
</div>
</div>
<div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
<p class="MsoNormal">Steve,<u></u><u></u></p>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Reading alpha values (with hex colors) is already implemented in the code. However we have lack of implementation writing hex colors (in writeColor). We might consider writing the
hex format (instead of the integer triplet) when the alpha value is in effect (0<= alpha <255) but it may cause a confusuion that setting the opacity of the style causes to write hex colors. <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">When reading the mapfiles the opacity value overrides the alpha values specified explicitly (in hex colors).<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Best regards,<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal">Tamas<u></u><u></u></p>
</div>
<div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"> <u></u><u></u></p>
<div>
<p class="MsoNormal">2012/9/24 Lime, Steve D (DNR) <<a href="mailto:Steve.Lime@state.mn.us" target="_blank">Steve.Lime@state.mn.us</a>><u></u><u></u></p>
<p class="MsoNormal">I'm guessing it is possible to tweak the parser using re-ahead capabilities. I believe the flex always has the next couple of tokens available for inspection. Haven't done anything
like that but I recall reading about it. Will dig out my yacc/lex book and confirm.<br>
<br>
Montreal was right at the 6.0 release point so it wasn't something I would have recommended at that late date. Hex color support required no parser changes so was a less risky option at the time.<br>
<span style="color:#888888"><br>
Steve</span><u></u><u></u></p>
<div>
<div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><br>
-----Original Message-----<br>
From: <a href="mailto:mapserver-dev-bounces@lists.osgeo.org" target="_blank">mapserver-dev-bounces@lists.osgeo.org</a> [mailto:<a href="mailto:mapserver-dev-bounces@lists.osgeo.org" target="_blank">mapserver-dev-bounces@lists.osgeo.org</a>] On Behalf Of thomas
bonfort<br>
Sent: Sunday, September 23, 2012 5:03 AM<br>
To: Tamas Szekeres<br>
Cc: <a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br>
Subject: Re: [mapserver-dev] Handling alpha values in colors<br>
<br>
Tamas,<br>
The handling of alphas in colors is a bit flakey, I agree. The initial aim when we worked on this at the montreal code sprint was to drop support of the OPACITY keyword at the STYLE level in the mapserver library (while maintaining it in the parser for backwards
compatibility), by allowing colors to be specified with quadruplets instead of triplets. I don't rememember the reason (Steve might recollect), but in the end having the parser be able to parse both triplet and quadruplet integers was not possible, and we
are thus stuck in this less than ideal state.<br>
If someone has a solution for this parser problem that would be great, as it would open up varying opacity for all *COLOR entries.<br>
<br>
regards,<br>
thomas<br>
<br>
On Sun, Sep 23, 2012 at 11:38 AM, Tamas Szekeres <<a href="mailto:szekerest@gmail.com" target="_blank">szekerest@gmail.com</a>> wrote:<br>
> Hi All,<br>
><br>
> I don't properly understand how we intend to handle alpha values of<br>
> colors in mapserver. Currently the alpha values can be specified in<br>
> mapfiles (by using the hexadecimal format), but that values are not<br>
> written back to the file in msSaveMap.<br>
> Style level opacity seems to override alpha values specified in<br>
> mapfiles, but on the other hand we cannot specify opacity at some<br>
> places (like in label text colors).<br>
> By using the opacity values of styles seems to change the alpha values<br>
> of multiple properties (color, outlinecolor, background color etc.)<br>
> which doesn't seems to be as such generic as specifying the alpha<br>
> values for the colors individually.<br>
><br>
> I can also see the conditional compilation flag ALPHACOLOR_ENABLED in<br>
> the code, but it doesn't have much effect for the operation.<br>
><br>
> Could someone explain how the things are expected to work?<br>
><br>
> Best regards,<br>
><br>
> Tamas<br>
><br>
> _______________________________________________<br>
> mapserver-dev mailing list<br>
> <a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br>
> <a href="http://lists.osgeo.org/mailman/listinfo/mapserver-dev" target="_blank">
http://lists.osgeo.org/mailman/listinfo/mapserver-dev</a><br>
><br>
_______________________________________________<br>
mapserver-dev mailing list<br>
<a href="mailto:mapserver-dev@lists.osgeo.org" target="_blank">mapserver-dev@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/mapserver-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/mapserver-dev</a><u></u><u></u></p>
</div>
</div>
</div>
<p class="MsoNormal"> <u></u><u></u></p>
</div>
</div>
</div>
</div>
</div>
</div>
<p class="MsoNormal"><u></u> <u></u></p>
</div>
</div></div></div>
</div>
</blockquote></div><br></div>