[MapServer Error]: msQueryByPoint(): No matching record(s) found. /OGR/MYSQL
Fawcett, David
David.Fawcett at STATE.MN.US
Mon May 8 07:22:48 PDT 2006
Grabiel,
My guess on the reason for no responses to your question is that there
are not a lot of people using MySQL in joins in MapServer. Even fewer
in MapScript.
I recently wrote a HowTo on using a direct connection to MySQL for a
point data layer. This method uses MySQL for both the spatial data and
the attribute data. No shapefile needed.
This method may work for you. The HowTo is at:
http://mapserver.gis.umn.edu/docs/howto/ogrmysql
David.
-----Original Message-----
From: UMN MapServer Users List [mailto:MAPSERVER-USERS at LISTS.UMN.EDU] On
Behalf Of grabiel
Sent: Monday, May 08, 2006 5:58 AM
To: MAPSERVER-USERS at LISTS.UMN.EDU
Subject: [UMN_MAPSERVER-USERS] [MapServer Error]: msQueryByPoint(): No
matching record(s) found. /OGR/MYSQL
Hi
I have posted one message for ogr/mysql problem(No reply so far). If
anyone has implemented ogr/mysql/php Plz. help me out. What i am trying
is to relate a shape file with mysql table. I can able to fetch the data
through ogrinfo in command line which is like this--->
[root at localhost bin]ogrinfo
/usr/local/apache/htdocs/gmap/htdocs/data/n_state.shp -sql "SELECT
st_nm, nsdata.name,nsdata.capital,nsdata.id from n_state LEFT JOIN
'MYSQL:test,host=localhost,user=root,tables=nsdata'.nsdata ON
n_state.st_nm=nsdata.name"
The command above woks fine but when i try the same from mapfile, I am
getting the following error.
>Warning: [MapServer Error]: msQueryByPoint(): No matching record(s)
>found.
>in /usr/local/apache/htdocs/gmap/htdocs/gmap75.inc.php on line 425
The error above is only for the layer where i have used OGR/MySql
table, whereas for layers where i havenot used OGR/MySql(simply shape
file & Metadata) its showing the results.
My mapfile code for ogr is something like this-->
................
................
LAYER
NAME "n_state"
TYPE POINT
CONNECTIONTYPE OGR
CONNECTION "/usr/local/apache/htdocs/gmap/htdocs/data/n_state.shp"
DATA "SELECT * from n_state left join
'MYSQL:test,host=localhost,user=root,tables=nsdata'.nsdata ON
n_state.st_nm=nsdata.name"
STATUS ON
CLASSITEM "st_nm"
CLASS
NAME "NEIGHBOURING STATE"
EXPRESSION /A*/
COLOR 255 0 0
OUTLINECOLOR 255 0 0
SYMBOL "NS"
END
END
..........
..........
I have given the mapfile(.map) and Php code(.php) in two files below for
better understanding.
If anyone has implemented this by PHP plz share your ideas/experience
for the query part. Maybe something went terribly wrong in my
PHP/Mapscript(I assume). In detail explanation for Php/mapscript will
really be appreciated.
Expecting some reply this time(What time!!!)
Thanks in advance
With regards
MAP FILE:
*********
NAME "test"
SIZE 400 400
STATUS ON
SYMBOLSET "DATA/symbols.sym"
EXTENT 27000.860 2462.020 3582.801 3012.468
UNITS METERS
.................
.................
................
QUERYMAP
STYLE HILITE
COLOR 255 0 0
STATUS ON
END
LAYER
NAME "TEST"
METADATA
..........
..........
END
TYPE POINT
STATUS ON
DATA "TEST"
CLASS
NAME "CITY"
COLOR 26 37 255
OUTLINECOLOR 120 120 120
TEMPLATE "ttt_query.html"
STYLE
COLOR 110 50 100
OUTLINECOLOR 200 200 200
SYMBOL 0
END
END
END
LAYER
NAME "n_state"
TYPE POINT
CONNECTIONTYPE OGR
CONNECTION "/usr/local/apache/htdocs/gmap/htdocs/data/n_state.shp"
DATA "SELECT * from n_state left join
'MYSQL:test,host=localhost,user=root,tables=nsdata'.nsdata ON
n_state.st_nm=nsdata.name"
STATUS ON
CLASSITEM "st_nm"
CLASS
NAME "NEIGHBOURING STATE"
EXPRESSION /A*/
COLOR 255 0 0
OUTLINECOLOR 255 0 0
SYMBOL "NS"
END
END
END
************* END OF MAP FILE********************
************* START OF PHP FILE ***************
<?php
if (sizeof($HTTP_POST_VARS) > 0)
$HTTP_FORM_VARS = $HTTP_POST_VARS;
else if (sizeof($HTTP_GET_VARS) > 0)
$HTTP_FORM_VARS = $HTTP_GET_VARS;
else
$HTTP_FORM_VARS = array("");
/* ====================================================================
*/
/* Find out whether GIF is supported... if not falback on PNG/JPG
*/
/* ====================================================================
*/ if (strpos( ms_GetVersion(), "OUTPUT=GIF") > 0 ) {
$gAppletImgFmt = MS_GIF;
$gImagesFmt = MS_GIF;
}
else
{
$gAppletImgFmt = MS_JPEG;
$gImagesFmt = MS_PNG;
}
/***********************************************************************
*/
/* function GMap75CheckClick()
*/
/*
*/
/* Function to set the status ON/OFF of a layer according to
*/
/* htrtp parameters passed. (paremeters are here equal to the
*/
/* layer name).
*/
/***********************************************************************
*/
function GMap75CheckClick()
{
GLOBAL $HTTP_FORM_VARS;
GLOBAL $gpoMap, $gbShowQueryResults, $gszZoomBoxExt;
GLOBAL $dfMapExtMinX;
GLOBAL $dfMapExtMinY;
GLOBAL $dfMapExtMaxX;
GLOBAL $dfMapExtMaxY;
GLOBAL $dfMaxExtMinX;
GLOBAL $dfMaxExtMinY;
GLOBAL $dfMaxExtMaxX;
GLOBAL $dfMaxExtMaxY;
reset( $HTTP_FORM_VARS );
// $gbShowQueryResults=TRUE;
// while ( list( $key, $val ) = each( $HTTP_FORM_VARS ) )
// {
// printf("%s=%s<BR>\n", $key, $val);
// }
/* --------------------------------------------------------------------
*/
/* look for all layers set to on/off
*/
/* --------------------------------------------------------------------
*/
if (sizeof($HTTP_FORM_VARS) >= 2)
{
$poLayer = $gpoMap->getlayerbyname(asmroad);
if ($HTTP_FORM_VARS["asmroad"])
$poLayer->set("status", 1);
else
$poLayer->set("status", 0);
$poLayer = $gpoMap->getlayerbyname(newvill);
if ($HTTP_FORM_VARS["newvill"])
$poLayer->set("status", 1);
else
$poLayer->set("status", 0);
$poLayer = $gpoMap->getlayerbyname(n_state);
if ($HTTP_FORM_VARS["n_state"])
$poLayer->set("status", 1);
else
$poLayer->set("status", 0);
$poLayer = $gpoMap->getlayerbyname(raster_back);
if ($HTTP_FORM_VARS["raster_back"])
$poLayer->set("status", 1);
else
$poLayer->set("status", 0);
}
/* --------------------------------------------------------------------
*/
/* these are the extents of waht is seen actually, they are
*/
/* generated in function GMapRedraw().
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["minx"])
{
$dfMinX = doubleval($HTTP_FORM_VARS["minx"]);
$dfMinY = doubleval($HTTP_FORM_VARS["miny"]);
$dfMaxX = doubleval($HTTP_FORM_VARS["maxx"]);
$dfMaxY = doubleval($HTTP_FORM_VARS["maxy"]);
// printf("minx\n");
}
else
{
$dfMinX = $gpoMap->extent->minx;
$dfMinY = $gpoMap->extent->miny;
$dfMaxX = $gpoMap->extent->maxx;
$dfMaxY = $gpoMap->extent->maxy;
}
/* --------------------------------------------------------------------
*/
/* check for image width, hight changes.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["MapSize"])
{
if (ereg("([0-9]+),([0-9]+)",
$HTTP_FORM_VARS["MapSize"], $MapSizeExtents))
{
$dfWidthPix = intval($MapSizeExtents[1]);
$dfHeightPix = intval($MapSizeExtents[2]);
$gpoMap->set("width",$dfWidthPix);
$gpoMap->set("height",$dfHeightPix);
SetMapExtents($dfMinX, $dfMinY, $dfMaxX, $dfMaxY);
}
}
/* --------------------------------------------------------------------
*/
/* check if the key map has been cliked.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["KEYMAP_x"])
{
/* --------------------------------------------------------------------
*/
/* initilalize the georef extents of the key map.
*/
/* --------------------------------------------------------------------
*/
$dfKeyMapXMin = $gpoMap->reference->extent->minx;
$dfKeyMapYMin = $gpoMap->reference->extent->miny;
$dfKeyMapXMax = $gpoMap->reference->extent->maxx;
$dfKeyMapYMax = $gpoMap->reference->extent->maxy;
// printf("dfkeyxmin %f<BR>\n",$dfKeyMapXMin);
// printf("dfkeyymin %f<BR>\n",$dfKeyMapYMin);
// printf("dfkeyxmax %f<BR>\n",$dfKeyMapXMax);
// printf("dfkeyymax %f<BR>\n",$dfKeyMapYMax);
$nClickPixX = intval($HTTP_FORM_VARS[KEYMAP_x]);
$nClickPixY = intval($HTTP_FORM_VARS[KEYMAP_y]);
$dfWidthPix = doubleval($HTTP_FORM_VARS[KEYMAPXSIZE]);
$dfHeightPix = doubleval($HTTP_FORM_VARS[KEYMAPYSIZE]);
$nClickGeoX = GMapPix2Geo($nClickPixX, 0, $dfWidthPix,
$dfKeyMapXMin,
$dfKeyMapXMax, 0);
$nClickGeoY = GMapPix2Geo($nClickPixY, 0, $dfHeightPix,
$dfKeyMapYMin,
$dfKeyMapYMax, 1);
$dfDeltaX = $dfMaxX - $dfMinX;
$dfDeltaY = $dfMaxY - $dfMinY;
$dfMiddleX = $nClickGeoX;
$dfMiddleY = $nClickGeoY;
$dfNewMinX = $dfMiddleX - ($dfDeltaX/2);
$dfNewMinY = $dfMiddleY - ($dfDeltaY/2);
$dfNewMaxX = $dfMiddleX + ($dfDeltaX/2);
$dfNewMaxY = $dfMiddleY + ($dfDeltaY/2);
/* --------------------------------------------------------------------
*/
/* not go outside the borders.
*/
/* --------------------------------------------------------------------
*/
if ($dfNewMinX < $dfMaxExtMinX)
{
$dfNewMinX = $dfMaxExtMinX;
$dfNewMaxX = $dfNewMinX + ($dfDeltaX);
}
if ($dfNewMaxX > $dfMaxExtMaxX)
{
$dfNewMaxX = $dfMaxExtMaxX;
$dfNewMinX = $dfNewMaxX - ($dfDeltaX);
}
if ($dfNewMinY < $dfMaxExtMinY)
{
$dfNewMinY = $dfMaxExtMinY;
$dfNewMaxY = $dfNewMinY + ($dfDeltaY);
}
if ($dfNewMaxY > $dfMaxExtMaxY)
{
$dfNewMaxY = $dfMaxExtMaxY;
$dfNewMinY = $dfNewMaxY - ($dfDeltaY);
}
SetMapExtents($dfNewMinX, $dfNewMinY, $dfNewMaxX, $dfNewMaxY);
// return;
}
/* --------------------------------------------------------------------
*/
/* province selection.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["ViewRegion"])
{
if (ereg("(-?[0-9]+),(-?[0-9]+),(-?[0-9]+),(-?[0-9]+)",
$HTTP_FORM_VARS["ViewRegion"], $ProvExtents))
{
$dfMinX = doubleval($ProvExtents[1]);
$dfMinY = doubleval($ProvExtents[2]);
$dfMaxX = doubleval($ProvExtents[3]);
$dfMaxY = doubleval($ProvExtents[4]);
SetMapExtents($dfMinX, $dfMinY, $dfMaxX, $dfMaxY);
}
}
/* --------------------------------------------------------------------
*/
/* extract the current width and height.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["imagewidth"])
{
$dfWidthPix = intval($HTTP_FORM_VARS["imagewidth"]);
$dfHeightPix = intval($HTTP_FORM_VARS["imageheight"]);
}
else
{
$dfWidthPix = $gpoMap->width;
$dfHeightPix = $gpoMap->height;
}
/* --------------------------------------------------------------------
*/
/* check if it the redraw button which is pressed : if it is
*/
/* the case redraw the same extents.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["redraw_x"])
{
SetMapExtents($dfMinX, $dfMinY, $dfMaxX, $dfMaxY);
}
/* --------------------------------------------------------------------
*/
/* Check for zoom out (auto-submit) button.
*/
/* --------------------------------------------------------------------
*/
else if ($HTTP_FORM_VARS["CMD"] == "ZOOM_OUT" &&
!($HTTP_FORM_VARS["mainmap_x"] ||
$HTTP_FORM_VARS["INPUT_COORD"]))
{
$oPixelPos = ms_newpointobj();
$oGeorefExt = ms_newrectobj();
$oGeorefMaxExt = ms_newrectobj();
$oPixelPos->setxy($dfWidthPix/2.0, $dfHeightPix/2.0);
$oGeorefExt->setextent($dfMinX, $dfMinY, $dfMaxX, $dfMaxY);
$oGeorefMaxExt->setextent($dfMaxExtMinX, $dfMaxExtMinY,
$dfMaxExtMaxX, $dfMaxExtMaxY);
if (!$gpoMap->zoompoint(-2, $oPixelPos, $dfWidthPix,
$dfHeightPix,
$oGeorefExt, $oGeorefMaxExt))
{
$gpoMap->setExtent($dfMapExtMinX, $dfMapExtMinY,
$dfMapExtMaxX, $dfMapExtMaxY);
}
}
/* --------------------------------------------------------------------
*/
/* check for zoom / query through applet or image click
*/
/* --------------------------------------------------------------------
*/
else
{
$dfDeltaX = $dfMaxX - $dfMinX;
$dfDeltaY = $dfMaxY - $dfMinY;
/* --------------------------------------------------------------------
*/
/* extract click position.
*/
/* Convert the click pos to georeref coordinates.
*/
/* --------------------------------------------------------------------
*/
if ($HTTP_FORM_VARS["mainmap_x"] ||
$HTTP_FORM_VARS["INPUT_TYPE"])
{
$bRectangleInput = 0;
if ($HTTP_FORM_VARS["INPUT_TYPE"])
{
$szCoord = strval($HTTP_FORM_VARS["INPUT_COORD"]);
$szCoordType = strval($HTTP_FORM_VARS["INPUT_TYPE"]);
if (strcmp($szCoordType,"auto_point") == 0)
{
$szCoordArray =explode(",", $szCoord);
$nClickPixX = $szCoordArray[0];
$nClickPixY = $szCoordArray[1];
}
/* --------------------------------------------------------------------
*/
/* Rosa applet is used and the input is a rectangle
*/
/* (syntax is X1,Y1;X2,Y2).
*/
/* If the 2 sets of points are the same treat the case as a
*/
/* point click.
*/
/* --------------------------------------------------------------------
*/
else if (strcmp($szCoordType,"auto_rect") == 0)
{
$bRectangleInput = 1;
$szFirstSetXY = strtok($szCoord, ";");
$szSecondSetXY = strtok("\n");
$szFirstCoord = explode(",", $szFirstSetXY);
$szSecondCoord = explode(",", $szSecondSetXY);
$oPixelRect = ms_newrectobj();
$oPixelRect->setextent($szFirstCoord[0],
$szFirstCoord[1],
$szSecondCoord[0],
$szSecondCoord[1]);
if ($oPixelRect->minx == $oPixelRect->maxx &&
$oPixelRect->miny == $oPixelRect->maxy)
{
$bRectangleInput = 0;
$nClickPixX = $oPixelRect->minx;
$nClickPixY = $oPixelRect->miny;
}
else
{
if ($oPixelRect->minx > $oPixelRect->maxx)
{
// Use *1 to avoid dfTmp becoming a
reference
// to $oPixelRect->minx with PHP4 !?!?!?
$dfTmp = $oPixelRect->minx*1;
$oPixelRect->set("minx",$oPixelRect->maxx);
$oPixelRect->set("maxx",$dfTmp);
}
if ($oPixelRect->miny < $oPixelRect->maxy)
{
$dfTmp = $oPixelRect->miny*1;
$oPixelRect->set("miny", $oPixelRect->maxy);
$oPixelRect->set("maxy", $dfTmp);
}
}
// We'll insert a copy of the box's georef extent in
a
// comment in the HTML output... useful for defining
views.
$gszZoomBoxExt = sprintf("<!-- BOX= (%f, %f)-(%f,
%f) -->",
GMapPix2Geo($oPixelRect->minx, 0,
$dfWidthPix,
$dfMinX,
$dfMaxX, 0),
GMapPix2Geo($oPixelRect->miny, 0,
$dfHeightPix,
$dfMinY,
$dfMaxY, 1),
GMapPix2Geo($oPixelRect->maxx, 0,
$dfWidthPix,
$dfMinX,
$dfMaxX, 0),
GMapPix2Geo($oPixelRect->maxy, 0,
$dfHeightPix,
$dfMinY,
$dfMaxY, 1) );
}
}
else
{
$nClickPixX = intval($HTTP_FORM_VARS[mainmap_x]);
$nClickPixY = intval($HTTP_FORM_VARS[mainmap_y]);
}
$oPixelPos = ms_newpointobj();
$oGeorefExt = ms_newrectobj();
$oGeorefMaxExt = ms_newrectobj();
$oPixelPos->setxy($nClickPixX, $nClickPixY);
$oGeorefExt->setextent($dfMinX, $dfMinY, $dfMaxX, $dfMaxY);
$oGeorefMaxExt->setextent($dfMaxExtMinX, $dfMaxExtMinY,
$dfMaxExtMaxX, $dfMaxExtMaxY);
if ($HTTP_FORM_VARS["CMD"] == "ZOOM_IN")
{
if ($bRectangleInput)
{
$gpoMap->zoomrectangle($oPixelRect, $dfWidthPix,
$dfHeightPix, $oGeorefExt);
}
else
$gpoMap->zoompoint(2, $oPixelPos, $dfWidthPix,
$dfHeightPix, $oGeorefExt,
$oGeorefMaxExt);
}
if ($HTTP_FORM_VARS["CMD"] == "ZOOM_OUT")
{
if (!$gpoMap->zoompoint(-2, $oPixelPos, $dfWidthPix,
$dfHeightPix, $oGeorefExt,
$oGeorefMaxExt))
{
$gpoMap->setExtent($dfMapExtMinX, $dfMapExtMinY,
$dfMapExtMaxX, $dfMapExtMaxY);
}
}
if ($HTTP_FORM_VARS["CMD"] == "RECENTER")
{
$gpoMap->zoompoint(1, $oPixelPos, $dfWidthPix,
$dfHeightPix, $oGeorefExt,
$oGeorefMaxExt);
}
else if ($HTTP_FORM_VARS["CMD"] == "QUERY_POINT")
{
/* --------------------------------------------------------------------
*/
/* Query selected layers at point location or in a rectangle.
*/
/* DumpQueryResults() will be called later to display the
*/
/* results.
*/
/* --------------------------------------------------------------------
*/
if ($bRectangleInput)
{
$oGeorefRect = ms_newrectobj();
$oGeorefRect->set("minx",
GMapPix2Geo($oPixelRect->minx, 0,
$dfWidthPix,
$dfMinX,
$dfMaxX, 0));
$oGeorefRect->set("maxx",
GMapPix2Geo($oPixelRect->maxx, 0,
$dfWidthPix,
$dfMinX,
$dfMaxX, 0));
$oGeorefRect->set("miny",
GMapPix2Geo($oPixelRect->miny, 0,
$dfHeightPix,
$dfMinY,
$dfMaxY, 1));
$oGeorefRect->set("maxy",
GMapPix2Geo($oPixelRect->maxy, 0,
$dfHeightPix,
$dfMinY,
$dfMaxY, 1));
// Use '@' to avoid warning if query found nothing
@$gpoMap->queryByRect($oGeorefRect);
$gbShowQueryResults = TRUE;
}
else
{
$nClickGeoX = GMapPix2Geo($nClickPixX, 0,
$dfWidthPix,
$dfMinX, $dfMaxX, 0);
$nClickGeoY = GMapPix2Geo($nClickPixY, 0,
$dfHeightPix,
$dfMinY, $dfMaxY, 1);
$oClickGeo = ms_newPointObj();
$oClickGeo->setXY($nClickGeoX, $nClickGeoY);
// Use '@' to avoid warning if query found nothing
$gpoMap->queryByPoint($oClickGeo, MS_SINGLE, -1);
$gbShowQueryResults = TRUE;
}
}
}
}
}
/***********************************************************************
*/
/* fuction GMapGetStatus($szLayerName)
*/
/*
*/
/* return if the layer is on or off (displayed or not) :
*/
/*
*/
/* ON = MS_ON =1
*/
/* OFF = MS_OFF = 0
*/
/*
*/
/***********************************************************************
*/
function GMapGetStatus($szLayerName)
{
GLOBAL $gpoMap;
$poLayer = $gpoMap->getlayerbyname($szLayerName);
$nStatus = $poLayer->status;
return ($nStatus);
}
/***********************************************************************
*/
/* function GMapDrawMap()
*/
/*
*/
/* Funcion to draw the contains of the map.
*/
/***********************************************************************
*/
function GMapDrawMap()
{
GLOBAL $gpoMap, $gbShowQueryResults;
GLOBAL $gbIsHtmlMode;
GLOBAL $gszCommand, $gszZoomBoxExt;
GLOBAL $gAppletImgFmt, $gImagesFmt;
if ($gbShowQueryResults)
{
$img = $gpoMap->drawQuery();
}
else
$img = $gpoMap->draw();
$url = $img->saveWebImage($gAppletImgFmt, 0, 0, -1);
echo "\n".$gszZoomBoxExt."\n";
printf("<INPUT TYPE=HIDDEN NAME=minx VALUE=\"%f\">",
$gpoMap->extent->minx);
printf("<INPUT TYPE=HIDDEN NAME=miny VALUE=\"%f\">",
$gpoMap->extent->miny);
printf("<INPUT TYPE=HIDDEN NAME=maxx VALUE=\"%f\">",
$gpoMap->extent->maxx);
printf("<INPUT TYPE=HIDDEN NAME=maxy VALUE=\"%f\">",
$gpoMap->extent->maxy);
printf("<INPUT TYPE=HIDDEN NAME=imagewidth VALUE=\"%d\">",
$gpoMap->width);
printf("<INPUT TYPE=HIDDEN NAME=imageheight VALUE=\"%d\">",
$gpoMap->height);
/* --------------------------------------------------------------------
*/
/* Use the command to update the rosa applet.
*/
/* --------------------------------------------------------------------
*/
if ( strlen($gszCommand) == 0)
{
$szButtonName = "zoomin";
}
else
{
if ($gszCommand == "ZOOM_IN")
$szButtonName = "zoomin";
// Do not keep zoomout pressed ot avoid infinite zoomout loop!!!
// if ($gszCommand == "ZOOM_OUT")
// $szButtonName = "zoomout";
if ($gszCommand == "RECENTER")
$szButtonName = "recentre";
if ($gszCommand == "QUERY_POINT")
$szButtonName = "pquery";
}
if (!$gbIsHtmlMode) //use applet
{
printf("\n");
printf("<APPLET NAME=\"RosaApplet\" ARCHIVE=\"./rosa/rosa.jar\"
CODE=\"Rosa2000\" WIDTH=\"%d\" HEIGHT=\"%d\" MAYSCRIPT>\n",
$gpoMap->width, $gpoMap->height);
printf("<PARAM NAME=\"TB_POSITION\" VALUE=\"right\">\n");
printf("<PARAM NAME=\"TB_ALIGN\" VALUE=\"top\">");
printf("<PARAM NAME=\"IMG_URL\" VALUE=\"%s\">",$url);
printf("<PARAM NAME=\"INP_FORM_NAME\" VALUE=\"myform\">");
printf("<PARAM NAME=\"TB_BUTTONS\"
VALUE=\"zoomin|zoomout|recentre|pquery\">\n");
printf("<PARAM NAME=\"INP_TYPE_NAME\" VALUE=\"INPUT_TYPE\">\n");
printf("<PARAM NAME=\"INP_COORD_NAME\"
VALUE=\"INPUT_COORD\">\n");
printf("<PARAM NAME=\"TB_SELECTED_BUTTON\"
VALUE=\"%s\">",$szButtonName);
printf("<PARAM NAME=\"TB_BUT_zoomin_IMG\"
VALUE=\"./images/tool_zoomin_1.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomin_IMG_PR\"
VALUE=\"./images/tool_zoomin_2.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomin_HINT\" VALUE=\"Zoom in:
Click the button|and the map will zoom in\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomin_INPUT\"
VALUE=\"auto_rect\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomin_NAME\" VALUE=\"CMD\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomin_VALUE\"
VALUE=\"ZOOM_IN\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_IMG\"
VALUE=\"./images/tool_zoomout_1.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_IMG_PR\"
VALUE=\"./images/tool_zoomout_2.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_HINT\" VALUE=\"Zoom out:
Click the button|and the map will zoom out\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_INPUT\"
VALUE=\"submit\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_NAME\" VALUE=\"CMD\">\n");
printf("<PARAM NAME=\"TB_BUT_zoomout_VALUE\"
VALUE=\"ZOOM_OUT\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_IMG\"
VALUE=\"./images/tool_recentre_1.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_IMG_PR\"
VALUE=\"./images/tool_recentre_2.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_HINT\" VALUE=\"Recenter:
Click the button|and the map will recenter\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_INPUT\"
VALUE=\"auto_point\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_NAME\" VALUE=\"CMD\">\n");
printf("<PARAM NAME=\"TB_BUT_recentre_VALUE\"
VALUE=\"RECENTER\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_IMG\"
VALUE=\"./images/tool_info_1.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_IMG_PR\"
VALUE=\"./images/tool_info_2.gif\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_HINT\" VALUE=\"Point Query:
Click a point on the map|for information about that point\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_INPUT\"
VALUE=\"auto_rect\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_NAME\" VALUE=\"CMD\">\n");
printf("<PARAM NAME=\"TB_BUT_pquery_VALUE\"
VALUE=\"QUERY_POINT\">\n");
printf("</APPLET>");
printf("<INPUT TYPE=\"HIDDEN\" NAME=\"CMD\" VALUE=\"\">");
printf("<INPUT TYPE=\"HIDDEN\" NAME=\"INPUT_TYPE\"
VALUE=\"\">");
printf("<INPUT TYPE=\"HIDDEN\" NAME=\"INPUT_COORD\"
VALUE=\"\">");
}
else
{
echo"<INPUT TYPE=image SRC=$url BORDER=0 WIDTH=$gpoMap->width
HEIGHT=$gpoMap->height NAME=mainmap>";
printf("<INPUT TYPE=\"HIDDEN\" NAME=\"CMD\" VALUE=\"%s\">",
$gszCommand);
}
// printf("<IMG SRC=%s WIDTH=%d HEIGHT=%d>\n", $url, $gpoMap->width,
$gpoMap->height);
}
/***********************************************************************
*/
/* function GMapDrawKeyMap()
*/
/*
*/
/* Utility function to draw the refernece map (key map).
*/
/***********************************************************************
*/
function GMapDrawKeyMap()
{
GLOBAL $gpoMap;
GLOBAL $gAppletImgFmt, $gImagesFmt;
$img = $gpoMap->drawreferencemap();
$url = $img->saveWebImage($gImagesFmt, 0, 0, -1);
printf("<INPUT TYPE=HIDDEN NAME=KEYMAPXSIZE VALUE=\"%d\">",
$img->width);
printf("<INPUT TYPE=HIDDEN NAME=KEYMAPYSIZE VALUE=\"%d\">",
$img->height);
// echo"<IMG SRC=$url BORDER=0 >\n";
echo"<INPUT TYPE=image SRC=$url BORDER=0 NAME=KEYMAP>";
}
/***********************************************************************
*/
/* function GMapDrawScaleBar()
*/
/*
*/
/* Draw sacle bar.
*/
/***********************************************************************
*/
function GMapDrawScaleBar()
{
GLOBAL $gpoMap;
GLOBAL $gAppletImgFmt, $gImagesFmt;
$img = $gpoMap->drawScaleBar();
$url = $img->saveWebImage($gImagesFmt, 0, 0, -1);
echo"<IMG SRC=$url BORDER=0 >\n";
}
/***********************************************************************
*/
/*function GMapPix2Geo($nPixPos, $dfPixMin, $dfPixMax, $dfGeoMin,
dfGeoMax,*/
/* $nInversePix)
*/
/*
*/
/* Utility function to convert a pixel position to geocoded
*/
/* position.
*/
/*
*/
/* The parameter $nInversePix could be set to 1 for Y pixel
*/
/* coordinates where the UL > LR. Else set to 0.
*/
/***********************************************************************
*/
function GMapPix2Geo($nPixPos, $dfPixMin, $dfPixMax, $dfGeoMin,
$dfGeoMax,
$nInversePix)
{
// if ($nPixPos < $dfPixMin)
// return -1;
// if ($nPixPos > $dfPixMax)
// return -1;
// if ($dfPixMin >= $dfPixMaX ||
// $dfGeoMin >= $dfGeoMax)
// return -1;
$dfWidthGeo = $dfGeoMax - $dfGeoMin;
$dfWidthPix = $dfPixMax - $dfPixMin;
$dfPixToGeo = $dfWidthGeo / $dfWidthPix;
if (!$nInversePix)
$dfDeltaPix = $nPixPos - $dfPixMin;
else
$dfDeltaPix = $dfPixMax - $nPixPos;
$dfDeltaGeo = $dfDeltaPix * $dfPixToGeo;
$dfPosGeo = $dfGeoMin + $dfDeltaGeo;
return ($dfPosGeo);
}
/***********************************************************************
*/
/* function SetMapExtents($dfNewMinX, $dfNewMinY, $dfNewMaxX,
$dfNewMaxY)*/
/*
*/
/* Set map extents of the map. We also make a test here with
*/
/* the min/max scale set in the .map file (the web object)
*/
/* to verify if the extents are respected. If it is the
*/
/* case return true. Else return false.
*/
/*
*/
/* Note : the extents of the map are still set using the
*/
/* parameters passed in argument. The caller has the
*/
/* responsability to check the return value.
*/
/***********************************************************************
*/
function SetMapExtents($dfNewMinX, $dfNewMinY, $dfNewMaxX, $dfNewMaxY) {
GLOBAL $gpoMap;
$gpoMap->setExtent($dfNewMinX, $dfNewMinY, $dfNewMaxX, $dfNewMaxY);
$dfScale = $gpoMap->scale;
// printf("scale : %f <BR>\n", $dfScale);
// printf("minscale : %f<BR>\n",$gpoMap->web->minscale);
// printf("maxscale : %f<BR>\n",$gpoMap->web->maxscale);
if ($dfScale < $gpoMap->web->minscale ||
$dfScale > $gpoMap->web->maxscale)
return false;
return true;
}
/***********************************************************************
*/
/* function GMapDumpQueryResults()
*/
/*
*/
/* Produce a table with query results.
*/
/* Simply prints an " " if there are no query results. */
/***********************************************************************
*/
function GMapDumpQueryResults()
{
GLOBAL $gpoMap, $gbShowQueryResults;
if (! $gbShowQueryResults )
{
printf(" ");
return;
}
$numResultsTotal = 0;
for($iLayer=0; $iLayer < $gpoMap->numlayers; $iLayer++)
{
$oLayer = $gpoMap->GetLayer($iLayer);
$numResults = $oLayer->getNumResults();
printf($oLayer.name);
if ($numResults == 0)
continue; // No results in this layer
// Open layer's table... take the list of fields to display from
// the "RESULT_FIELDS" metadata in the layer object.
$oLayer->open();
//
// One row in table for each selected record
//
for ($iRes=0; $iRes < $numResults; $iRes++)
{
$oRes = $oLayer->getResult($iRes);
$oShape =
$oLayer->getShape($oRes->tileindex,$oRes->shapeindex);
if ($iRes == 0)
{
//
// Table header: attribute names...
//
if ($oLayer->getMetaData("RESULT_FIELDS"))
{
// Display fields listed in RESULT_FIELDS metadata
$selFields = explode(" ",
$oLayer->getMetaData("RESULT_FIELDS"));
}
else
{
// RESULT_FIELDS not set. display first 4 fields
$i=0;
while ( list($key,$val) = each($oShape->values) )
{
$selFields[$i++] = $key;
if ($i>=4) break;
}
}
printf("<TABLE BORDER=0 CELLSPACING=1 CELLPADDING=2
WIDTH=100%%>\n");
printf("<TR>\n");
printf("<TD COLSPAN=%d BGCOLOR=#C1D8E3>",
count($selFields));
printf("<CENTER> %s </CENTER>",
$oLayer->getMetaData("DESCRIPTION"));
printf("</TD>\n");
printf("</TR>\n");
printf("<TR>\n");
for ($iField=0; $iField < count($selFields); $iField++)
{
printf("<TD BGCOLOR=#E2EFF7>");
printf("%s",$selFields[$iField]);
printf("</TD>\n");
}
printf("</TR>\n");
}
printf("<TR>\n");
printf("<!-- bounds(%f, %f)-(%f, %f)-->\n",
$oShape->bounds->minx, $oShape->bounds->miny,
$oShape->bounds->maxx, $oShape->bounds->maxy);
// printf("<!-- ");
// print_r($oShape);
// printf(" -->\n");
for($iField=0; $iField < sizeof($selFields); $iField++)
{
printf("<TD BGCOLOR=#FFFFFF>");
printf("%s", $oShape->values[$selFields[$iField]]);
printf("</TD>\n");
}
printf("</TR>\n");
$oShape->free();
$numResultsTotal++;
}
$oLayer->close();
printf("</TABLE>\n");
}
//printf($oLayer);
if ($numResultsTotal == 0)
echo "Nothing at query point.";
}
?>
****************END OF PHP SCRIPT***************************
_______________________________________________
No banners. No pop-ups. No kidding.
Make My Way your home on the Web - http://www.myway.com
More information about the MapServer-users
mailing list