[mapserver-users] querying in mode=tile
Mr. Puneet Kishor
punk.kish at gmail.com
Sun Sep 11 20:37:13 PDT 2011
On Sep 11, 2011, at 10:03 PM, Richard Greenwood wrote:
> On Sun, Sep 11, 2011 at 8:48 AM, Mr. Puneet Kishor <punk.kish at gmail.com> wrote:
>>
>> On Sep 11, 2011, at 8:03 AM, Richard Greenwood wrote:
>>
>>> On Sat, Sep 10, 2011 at 1:35 PM, Mr. Puneet Kishor <punk.kish at gmail.com> wrote:
>>>> Now that I have mode=tile working with Google Maps API v3, I am on my way to implement querying like so
>>>>
>>>> 0. Bind an infowindow.close() to a click event listener on the map
>>>> 1. Bind an infowindow.open() to a click event listener on the MapServer layer
>>>> 2. Fill the infowindow content with the result from an Ajax query to MapServer
>>>> 3. When the user clicks on the MapServer layer, the Ajax query is fired
>>>> 4. MapServer responds with the query result as a JSON object
>>>> 5. Fill the infowindow with the JSON result
>>>> 6. Close any already open infowindow via #0 above
>>>> 7. Open a new infowindow with the result
>>>>
>>>> Is the general approach outlined above sound? Any pointers to existing code samples for the above?
>>>
>>>
>>> Puneet,
>>>
>>> I'm doing pretty much that here:
>>> http://records.sublettewyo.com/mapserver/map.html
>>> I'm using jQuery in this example and putting the info into a jQuery
>>> dialog, however I have used a standard browser window in the past.
>>> Only thing is that I don't thinnk you really need step 0, simply
>>> replace the contents of the container with the new info.
>>
>>
>> Yup, I don't have to worry about #0. Howerver, #1 above is problematic, and I don't have a resolution for it yet. Seems like in Google Maps API v3 I can't addListener to an ImageMapType overlay. See, I am adding a MapServer layer as ImageMapType overlay like so
>>
>> "mapserverLayer" : new google.maps.ImageMapType({ .. })
>> map.overlayMapTypes.insertAt(0, mapserverLayer);
>>
>>
>> If I do the following --
>>
>> google.maps.event.addListener(map, "click", function (event) { }
>>
>> it works, however, the following doesn't work at all
>>
>> google.maps.event.addListener(mapserverLayer, "click", function (event) { }
>>
>> Which is silly, isn't it? I don't want the entire map to be listening to the "click" events. I just want the MapServer layer to be doing so. Haven't yet found a resolution to this.
>>
>>
>>>
>>> Also, if your data is in PostGIS you can skip mapserver for attribute
>>> queries and do an info query against the PostGIS db via PHP or other
>>> server-side tool.
>>>
>>
>> Ok, I am very interested in the above, but I am not sure I understand you. For the most part, I want to click on the map, and find out more about what I clicked on. In order to do that query via Perl MapScript (I don't know PHP) and Pg, I would need to create the $mapObj. I am able to do that fine, but I don't know how to run MapServer in `mode=tile` via MapScript. This is the question I have asked a couple of times -- if I have a pure MapScript app (no map files involved at all, which is what I want), how no earth do I tell the app to use `mode=tile`?
>>
>> Puneet.
>>
>>
>
> Puneet,
>
> I do not know how to bind an infowindow.open() to a click event
> listener on the MapServer layer (#1 above) because I do not use the
> Google API. But using Perl, PHP or whatever it is easy to query a
> PostGIS database, and even get GeoJSON back should you want to
> highlight the selected object on the map.
>
> I am using OpenLayers so I can easily convert the mouse click (or box)
> to a real-world coordinate(s). I pass the point or box to a PHP page
> which connects to a PostGIS db, does the query, and returns JSON. Does
> that help? I'm not sure that I understand everything that you're doing
> and maybe my approach is not appropriate in your case.
I am assuming you are using OL with MapServer WMS. If I could get MapServer WMS (via MapScript) working, it would have been good, but after screwing around for a day and a half unsuccessfully, I gave up (for now).
Then I tried `mode=tile` and it just worked. However, even that is not fully satisfactory as it is not via MapScript. Without MapScript I am severely hampered -- the complexity of the datasets makes for beastly map files. My map file with just one data source is already almost 9000 lines long. In fact, I generate the map file via MapScript, and then further tweak it by hand.
Even with WMS or tile mode, I will have to implement some kind of tile caching either with tilecache or map proxy or some such to improve the performance.
However, since I am not using MapScript (even though I would prefer to), I would have to implement both CGI and MapScript to do what you are suggesting above -- CGI to display the map and MapScript to do the query.
For now, I have been able to get this clicky thing working -- I click on the map, do a `mode=query` and display the result in an infowindow. That part is working.
Ideally, I would like to have a single technology -- MapScript to generate the maps that can be displayed via multiple front-ends -- OL, Gmaps, perhaps Leaflet, and MapScript to query the attributes via clicks and selects on the map. For now, I am flailing.
>
> Are you in Denver for FOSS4G??
>
Unfortunately no. Too much work here, and no funding to travel. I am sure you all will have a blast.
Puneet.
More information about the MapServer-users
mailing list