<table cellspacing="0" cellpadding="0" border="0" ><tr><td valign="top" style="font: inherit;">Hi Robert,<br><br>I have resolved a similar issue with mapserver (where mapserver variable substitution couldn't supply the required functionality) by having a cgi script write the mapfile on the fly, using some logic to customise the mapfile as required. Then the script invokes mapserver with the mapfile.<br><br>Sort of:<br><br>write mapfile header down to common layer details <br>for class in LIST ; do<br>  write class with random colour<br>done<br>close mapfile<br>invoke mapserver with new mapfile<br><br>The issue with this approach is that every invocation will have different colours (unless you always start with the same random seed & use a pseudorandom sequence).<br><br><br>Option 2 is similar. I believe mapserver's runtime variable substitution supports the CLASS expression. A cgi could generate the name/value pairs for the required random
 colours, append them to the URL query string, invoke mapserver & have mapserver carry out the variable substitution as it preprocesses the mapfile.<br><br><br>Another similar issue I resolved recently: A WMS polygon layer with various but fixed colours & a WFS layer with a point in each polygon with the metadata in OpenLayers.<br><br>A table stores the RGB values used in the WMS classes, a query generates a java #hex string from the RGB values, so the WFS layer provides the colour to render each point in, OpenLayers reads the colour for each feature from the WFS fields, so they match the WMS polygons.<br><br>The query in the data statement generates java #hex from rgb values, which is fine from postgis, I'm not sure if you can do this from a shapefile, but if so, you could  perhaps predefine your colours in the shapefile, with a value per feature:<br><br><span style="font-family: courier,monaco,monospace,sans-serif;">geom from (select r.gid
 + (100 * p.id) as gid,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                            r.gid as r_id,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                            p.id as p_id,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                            r.regioncode,</span><br
 style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                            r.regionname,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                            p.geom,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                     ('#'||case when (length(to_hex(r_fill))=1)</span><br style="font-family:
 courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(r_fill)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     else to_hex(r_fill) end||</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family:
 courier,monaco,monospace,sans-serif;">                           case when (length(to_hex(g_fill))=1)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(g_fill)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     else
 to_hex(g_fill) end||</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                           case when (length(to_hex(b_fill))=1)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(b_fill)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family:
 courier,monaco,monospace,sans-serif;">                           else to_hex(b_fill) end) as hex_fill,</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                     ('#'||case when (length(to_hex(r_pen))=1)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(r_pen)</span><br style="font-family:
 courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     else to_hex(r_pen) end||</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                           case when (length(to_hex(g_pen))=1)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family:
 courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(g_pen)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     else to_hex(g_pen) end||</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                           case when
 (length(to_hex(b_pen))=1)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                                     then '0'||to_hex(b_pen)</span><br style="font-family: courier,monaco,monospace,sans-serif;"><span style="font-family: courier,monaco,monospace,sans-serif;">                           else to_hex(b_pen) end) as
 hex_pen</span><br>                                                      ...<br><br><br>Cheers,<br><br>   Brent<br> <br><blockquote style="border-left: 2px solid rgb(16, 16, 255); margin-left: 5px; padding-left: 5px;"><div id="yiv1882648854"><div class="yiv1882648854WordSection1"><div><p class="yiv1882648854MsoNormal" style="margin-right: 0in; margin-bottom: 12pt; margin-left: 0in;"><br>
Dear Mapserver users<br>
<br>
Just wondering if it is possible to colour a polygon Shape file layer with each distinct polygon having a different colour?<br>
<br>
Many thanks,<br>
<br>
Robert Sanson</p> 
</div>
<p class="yiv1882648854MsoNormal" style="margin-right: 0in; margin-bottom: 12pt; margin-left: 0in;">
  </p> 
<p style="text-align: center;" align="center"><span style="background: white none repeat scroll 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;">This email and any attachments are confidential and intended solely for the addressee(s). If you are not the intended recipient, please notify us immediately and then delete this email
 from your system.</span></p> 
<p style="text-align: center;" align="center"><span style="background: white none repeat scroll 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;">This message has been scanned for Malware and Viruses by Websense Hosted Security.
</span><a rel="nofollow" target="_blank" href="http://www.websense.com/"><span style="background: white none repeat scroll 0%; color: black; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;">www.websense.com</span></a></p> 
</div>
 
</div><br>-----Inline Attachment Follows-----<br><br><div class="plainMail">_______________________________________________<br>mapserver-users mailing list<br><a ymailto="mailto:mapserver-users@lists.osgeo.org" href="/mc/compose?to=mapserver-users@lists.osgeo.org">mapserver-users@lists.osgeo.org</a><br><a href="http://lists.osgeo.org/mailman/listinfo/mapserver-users" target="_blank">http://lists.osgeo.org/mailman/listinfo/mapserver-users</a><br></div></blockquote></td></tr></table>