changing the color of polygons in a layer???
Matthew Roberson
matt at MSILEADS.COM
Fri Jul 8 08:19:38 PDT 2005
Hi,
I am having a problem getting some PHP/Mapscript to work like I want
it to and I hope that somebody can offer some help.
Here is what I am trying to do.
I have a shp file from the US Census Bureau that contains 5-digit zip
code boundaries for a particular state(Texas in this case). I do a
query to find the zip codes i'm interested in. I want some of the
zipcode boundaries to be red(or whatever color) and some to be blue
(or whatever color). I have written the PHP/Mapscript that I think
will produce the results I want, however what
I get is all yellow zip codes(see the link below). I have included
the php and .map file that generates this map. I would really
appreciate any suggestions.
Thanks,
Matt
------------------------------------------------- php file
---------------------------------------------
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<TITLE>2080 Machine</TITLE>
<meta http-equiv = "Content-Language" content="en-us">
<meta http-equiv = "Content-Type" content="text/html;
charset=iso-8859-1">
<style type="text/css">
<!--
.red {color: red; font-size: 10pt;}
.black {color: black; font-size: 10pt;}
.bold {color: black; font-size: 12pt;font-weight:bold;}
-->
</style>
</head>
<body>
<table width="300" align="center" bgcolor="#FFFFFF">
<tr>
<td><img src="http://localhost/JW8020/MSILOGO1.gif" alt=""
width="120" height="112"></td>
</tr>
</table>
<?php
//require('/Library/WebServer/Documents/fpdf.php');
//require('/Library/WebServer/Documents/create8020PDF.php');
ini_set("display_errors","1");
//$username = "sa";
$username = "admin";
//$password = "s1q2l3S1";
$password = "w3xp2BA5";
$hostName = "localhost";
$databaseName = "8020Machine";
$sQVal = "";
$jID8020 = 3;
function get8020CountPercent($val,
$iTotalVal)
{
if($iTotalVal>0)
{
$dPercent=($val/$iTotalVal)*100;
$dPercent = number_format($dPercent, 2, '.', '');
}// ($iTotalVal>0)
else
{
$dPercent = 0.0;
//print "{$iTotalVal} is iTotalVal<br>";
}// end if ($iTotalVal>0)
return $dPercent;
}
function create8020OutputRecord($query,
$zip_array,
$adPercents)
{
// Run the query on the server
if (!($result = @ mysql_query ($query)))
if ($result)
{
$jobID = mysql_insert_id();
}
//return $jobID;
} // end of function
mysql_connect ($hostName,$username,$password);
mysql_select_db($databaseName);
$address_query = mysql_query("select distinct ZipCode from
eightytwentyinput where ZipCode <> '' and ZipCode is not NULL");
$address_rows = mysql_num_rows($address_query);
for($i=0; $i<$address_rows; $i++)
{
$address_array = mysql_fetch_array($address_query);
$temp_zip = $address_array['ZipCode'];
$zip_array[$temp_zip] =0;
$adPercents[$temp_zip]=0;
$data[$i][0]=0;
$data[$i][1]=0;
$data[$i][2]=0;
}
$address_query2 = mysql_query("select ZipCode from eightytwentyinput
where ZipCode <> '' and ZipCode is not NULL");
$address_rows2 = mysql_num_rows($address_query2);
for($i=0;$i<$address_rows2;$i++)
{
$address_array2 = mysql_fetch_array($address_query2);
$temp_zip2 = $address_array2['ZipCode'];
$zip_array[$temp_zip2] += 1;
}
arsort($zip_array);
arsort($adPercents);
//mapserver stuff
dl("php_mapscript.so");
$map_file="/Library/WebServer/Documents/test/TX1.map";
$map = ms_newMapObj($map_file);
$oZipLayer = $map->getLayerByName("TX zip code boundaries");
$sAttrName = 'ZCTA';
//print_r($zip_array);
print("There are <strong>$address_rows</strong> total unique zip
codes<BR>");
$iTotalVal = array_sum($zip_array);
$percent_num = $address_rows*.20;
$i=0;
print("<table border=\"1\"><tr><td class=\"bold\">Zip Code</td><td
class=\"bold\">Count</td><td class=\"bold\">Percent</td></tr>");
while (list($key, $val) = each($zip_array))
{
$i++;
if($i <= $percent_num)
{
$dPercent = get8020CountPercent($val,$iTotalVal);
$qry8020Output = mysql_query("INSERT INTO EightyTwentyOutput
VALUES (NULL,'{$jID8020}','{$key}','{$val}','{$dPercent}')");
create8020OutputRecord($qry8020Output, $zip_array, $adPercents);
echo "<tr><td class=\"red\">$key</td><td class=\"red\">$val</
td><td class=\"red\">$dPercent</td></tr>";
//pdf stuff
$data[$i][0]=$key;
$data[$i][1]=$val;
$data[$i][2]=$dPercent;
//mapserver stuff
if(strlen($key)<=5)
{
if(strncmp($key, "77", 2)== 0)
{
$oZipLayer->set("labelitem", 'ZCTA');
$sQVal=$sQVal.$key."|";
$oZipClassRed = ms_newClassObj($oZipLayer);
$oZipClassRed->setexpression($key);
$oZipStyleRed = ms_newStyleObj($oZipClassRed);
$oZipStyleRed->color->setRGB(250,0,0);
}
}
} // ($i <= $percent_num)
else
{
$dPercent = get8020CountPercent($val,$iTotalVal);
$qry8020Output = mysql_query("INSERT INTO EightyTwentyOutput
VALUES (NULL,'{$jID8020}','{$key}','{$val}','{$dPercent}')");
create8020OutputRecord($qry8020Output, $zip_array, $adPercents);
echo "<tr><td class=\"black\">$key</td><td class=\"black\">
$val</td><td class=\"black\">$dPercent</td></tr>";
//pdf stuff
$data[$i][0]=$key;
$data[$i][1]=$val;
$data[$i][2]=$dPercent;
//mapserver stuff
if(strlen($key)==5)
{
if(strncmp($key, "77", 2)== 0)
{
$oZipLayer->set("labelitem", 'ZCTA');
$sQVal=$sQVal.$key."|";
$oZipClassBlue = ms_newClassObj($oZipLayer);
$oZipClassBlue->setexpression($key);
$oZipStyleBlue = ms_newStyleObj($oZipClassBlue);
$oZipStyleBlue->color->setRGB(0,0,255);
}
}
}// end if ($i <= $percent_num)
$adPercents[$key] = $dPercent;
}// end while
print("</table>");
//more mapserver stuff
$sQVal = substr($sQVal, 0, strlen($sQVal)-1);
//Do query
$qresult = @$oZipLayer->queryByAttributes($sAttrName,"/".
$sQVal."/",MS_MULTIPLE);
$image = $map->drawQuery();
$image_url = $image->saveWebImage();
$error = ms_GetErrorObj();
while($error && $error->code != MS_NOERR)
{
printf("Error in %s: %s \n", $error->routine, $error->messaage);
$error = $error->next();
}
?>
<img SRC="<?php echo $image_url?>">
<p>This is an unprojected map of the 5 digit zip code boundries for
the state of Texas,
from the <a href="http://www.census.gov/geo/www/cob/z52000.html"> US
Census Bureau</a>.</p>
<p>To find the categories for the legend, I used the <code>ogrinfo</
code> utility twice.
<code>ogrinfo -a -summary zt48_d00.shp</code> let me see what fields
were available, and
<code>ogrinfo -a zt48_d00.shp|grep SYMBOL|sort -u</code> told me what
all of the unique values were so that
I could build my <code>CLASS</code> definitions in <code>TX1.map</code>.
</p>
<?php
//print_r($oZipLayer);
print_r($qresult);
if ($oZipLayer->getNumResults() > 0)
echo $oZipLayer->getNumResults()." zips found.";
else
echo "No zips found."
?>
</body>
</html>
------------------------------------------------- map file
---------------------------------------------
MAP
NAME TX
IMAGETYPE PNG
SIZE 600 600
IMAGECOLOR 255 255 255
SHAPEPATH "/Library/WebServer/Documents/data"
FONTSET "/Library/fonts/fonts.list"
EXTENT -106.645646 25.837377 -93.516407 36.500704
UNITS METERS
WEB
IMAGEPATH "/Library/WebServer/Documents/test/"
IMAGEURL "/test/"
END
LEGEND
STATUS EMBED
POSITION UR
END
SCALEBAR
TRANSPARENT ON
BACKGROUNDCOLOR 0 0 0
STATUS EMBED
POSITION LR
STYLE 1
END
LAYER
NAME "TX zip code boundaries"
TYPE POLYGON
STATUS DEFAULT
DATA "zt48_d00"
CLASS
COLOR 255 255 255
OUTLINECOLOR 0 0 0
END
TEMPLATE "x"
END
LAYER
NAME "credits"
STATUS DEFAULT
TRANSFORM FALSE
TYPE ANNOTATION
FEATURE
POINTS
10 480
END
TEXT 'Made with Mapserver.'
END
CLASS
LABEL
TYPE BITMAP
POSITION CR
COLOR 0 0 0
END
END
END
END
More information about the MapServer-users
mailing list