[webmap-discuss] OGC and google style tiling
Paul Spencer
pspencer at dmsolutions.ca
Thu Apr 27 16:08:56 EDT 2006
Steven,
(sorry folks, this is getting longer and longer)
On 27-Apr-06, at 10:00 AM, Steven M. Ottens wrote:
> Paul Spencer wrote:
>> Steven
>>
>> there are a couple of very good reasons for this (in my opinion).
>> The
>> approach you suggest is actually the first one I tried because I was
>> focussing on the client side code at the time. It became obvious
>> that
>> it would not actually work in a real world situation because:
>>
>> 1) every request to mapserv starts the CGI, loads the map, renders
>> the
>> map and returns it. This takes a substantial amount of time, even if
>> your map file and data are highly optimized. For instance, my test
>> cases would take about 1-2 seconds per tile, with a HUGE load on the
>> server.
> The idea is to get serverside cache, we have caching working on
> mapserver.cgi requests, which means it can can deliver lots and
> lots of
> tiles in a second. The reason I'm developing tiling is because our
> current setup can only handle 20 concurrent users and we need 300.
> If we
> can server from cache we can do that, and tiling is a way to make sure
> identical images are served to users and as such can be served from
> cache.
> Also in your situation you need to run a tile.php, a mapserver.cgi
> and a
> gd (why btw?) image process. If you multiply this 300 times it's also
> quite a load on the server. I prefer to keep as much load on the
> client
> side as possible.
how are you doing the serverside cache on mapserv requests?
In the ka-Map case, tile.php only loads mapscript and gd if the tile
has not been previously generated. Tiles are genereated the first
time they are requested and subsequently stored on disk and returned
directly by tile.php if they already exists
GD is required because we generate 'metatiles', typically 25-36 tiles
constituting a large map image (1000-2000 pixels square), in a single
map draw and slice it up into smaller tiles using GD after. The
large map draw minimizes the number of times we need to actually load
mapscript and render data, and also minimizes the effect of the label/
symbol/rendering issues.
>>
>> 2) every request to mapserv is treated as a single map draw. This
>> means that all label locations are calculated for that tile only. In
>> many cases, labels are too big to fit on a single tile. In others,
>> you have a label that fills the tile and because the feature extends
>> across multiple tiles, you may get the identical label repeated next
>> to each other many times.
> that is a problem indeed :( But if you keep a reasonable tile size
> it's
> not too disturbing.
ka-Map uses a tile size of 200x200 in its default, but I have started
switching to 300x300. In either case, the tile size minimizes the
number of actual images that are loaded (which impacts browser
performance when dragging the map) while keeping the download size
reasonable for each tile and providing a buffer of tiles 'offscreen'
so that users should rarely see empty tiles menu panning.
-- By comparison, google uses 256x256 (they used 128x128 for a while
then changed)
>>
>> 3) mapserv has rendering issues that are difficult to detect when
>> rendering a single image, but when you render tiles, they become very
>> obvious. The worst is thick lines rendered with a 'circle' symbol,
>> the ends of the line (at the map draw boundary) are tailed off ...
>> when two tiles come together, there is a very noticeable 'shearing'
>> effect on the lines which looks very bad.
> bad, bad, mapserver ;) I noticed the glitches after careful
> inspection.
> So either our data is not sensitive to this error or you have
> better eyes ;)
It is most noticeable when rendering thick lines 10+ pixels wide. I
had never noticed it before I started doing the tiling. When I first
saw it, I actually though the that tiles were mis-aligned by a few
pixels :) I spent quite a bit of time playing with my code before I
figured out I was right and mapserver was wrong ...
>>
>> 4) it is not possible to modify the headers returned from the cgi,
>> which means that you get the default browser caching behaviour. In
>> many cases, tiles can be cached for a long time, and in some specific
>> cases you want no caching at all.
> You can modify headers with apache, we set expiry dates for all of our
> mapimages. In our case the data is not very dynamic so a expiry
> date of
> a day or even a week is fine.
ok
>>
>> 5) I wanted to have some way of providing the capability to switch
>> between maps. This requires some knowledge of what maps are
>> available
>> on the server. There is no way to do this with the CGI
> That's not a real tiling issue, is it? In mapbuilder you can create a
> list of available layers based on the getCapabilitiesDoc. I use
> that to
> provide alternative layers.
I didn't want ka-Map to be tied to ogc since not that many folks
outside our community care about ogc.
>>
>> 6) in ka-Map (as with Google), you are restricted to a specific
>> set of
>> scales for viewing the map. This is not strictly necessary if you
>> are
>> not caching the tiles, but in the case of cached tiles it does become
>> very important. Cartographically, this means you can build your map
>> file for very specific scale breaks and ensure that the map looks
>> exactly right at each of the scales. Using just the cgi, it would be
>> impossible to determine the intended scale breaks for a given map.
> The getCapabilitiesDoc provides minimum and maximum scales so they can
> be used to determine the scale levels. Alternatively you will need to
> configure these scale levels in the configuration file. I do see an
> issue here, but I don't think it's a real showstopper.
agreed that its not a show stopper
>>
>> On a related note, however, if you wanted to try this anyway there is
>> a wmsLayer type in kaMap that can be used to create layers based on
>> remote WMS sources on the fly. It would be a useful exercise to
>> remove the server-side dependency in ka-Map's initialization step and
>> only trigger it on demand so that an 'empty' map could be created to
>> which you could add some number of wms layers. This would be a very
>> good fit as it would remove the server-side dependency and, as
>> MapBuilder is already very ogc-aware, it would be easy to integrate.
> The empty map is the one with the aPixel.src which I find every now
> and
> then in the ka-map code? I'm still trying to understand kamaps
> approach
> to building the tiles. Do you mean that you create a empty 'grid' of
> tiles, where you attach the layers on?
ka-Map has several objects that participate in this ...
kaMap - this is a mixture of several different concepts (and probably
needs to be refactored), but essentially it manages the user
interface by creating a DIV inside the user-specified element that
contains spatially positioned elements - in this case other DIVs.
The spatially positioned elements are absolutely positioned inside
their containing DIVs in a deterministic way (spatial location *
geographicUnitsPerPixel). The top/left style of the container is
changed to 'move' the contained elements. The logic for determining
if new tiles need to be loaded is also in here.
kaTool - base class for kaNavigator and other tools that provide user
controls such as dragging the map. These classes intercept events
from the user and programmatically adjust the top/left of the
container to move the tiles (for instance)
_map - encapsulates the concept of a map that contains layers. It
maintains information specific to a map such as the layers, the
current extents, default extents, maximum extents, background color etc.
_layer - encapsulates the concept of a layer, including name,
visibility, opacity etc. _layer is actually used to set the src of
each image that it contains, allowing for new _layer classes to
request tiles in different ways - I used this to implement a wms
layer that translates the pixel location of each tile into a wms
request rather than a call to tile.php.
By default, when you initialize ka-Map, it executes an ajax request
to init.php which reads config.php and returns javascript objects for
each _map and _layer and triggers the initial _map selection (either
the default from the config.php or the one requested by the user
calling the initialize function. This process could easily be
deferred, allowing the application to build its own _map instance in
the client from a context document. This is what I meant by 'empty
map' - poorly worded, sorry.
If we removed the requirement for calling init.php then you would
have no server-side dependency at all.
-- I just checked how it works and calling initialize is actually not
done in the constructor for kaMap so it should be possible to do this
already. I've attached an html file which uses kaMap to render a wms
layer with no server side interaction at all. You will need to
update kaMap to the latest cvs version because wmsLayer was slightly
out of date with a change I made to the _layer constructor.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.osgeo.org/pipermail/webmap-discuss/attachments/20060427/474d20a9/mbtest.html
-------------- next part --------------
>>
>> I may be willing to invest some effort in getting this to work at
>> some
>> point, especially if there is some interest/cooperation from the
>> MapBuilder community (which has already been offered btw, thanks Mike
>> and Cameron)
> I am the one from the mapbuilder community who is working on tiling ;)
> We (the mb community) are interested in tiling, be it Ka-map style,
> openlayers-style or our own implementation. I prefer cooperation with
> other webmapping projects, instead of our own implementation.
>
> I was brainstorming with Cameron on this topic and I can up with an
> alternative approach to tiling. Based on your concerns on the edges
> and
> the labels (also the performance, but that can be solved by serverside
> caching): Why not extend the WMS standard with a &tile=true parameter.
> It will be one request, but mapserver will create 'absolute' tiles and
> set a set of tiles back.
> This requires modification on both the WMS server and the WMS
> client and
> as such not easily done, but I think it's in the long run a better
> solution. Meanwhile I'll continue on a pure clientside tiling
> mechanism.
> We will probably discuss it at the mapbuilder meeting of next week.
> Anyone interested in this topic is free to join.
I believe that a tiling extension to the spec is in the works? Until
WMS servers catch up, I'll stick with what we've got :)
Cheers
Paul
>
> Steven
>
>>
>> Cheers
>>
>> Paul
>>
>> On 27-Apr-06, at 4:32 AM, Steven M. Ottens wrote:
>>
>>> Hi Paul,
>>>
>>> Why did you choose to use a php script to handle tiling? It makes it
>>> much harder for ka-map to become a general webmapping client,
>>> currently
>>> it is strongly tied to mapserver. Also for me it's more difficult to
>>> integrate it with mapbuilder, if I want to keep mapbuilder general.
>>> Why not integrate the routine in the clientside and request tiles
>>> like this:
>>> http://www.edugis.nl/cgi-bin/edugis/mapserv.cgi?map=maps/edugis/
>>> base.map&VERSION=1.1.0&REQUEST=GetMap&LAYERS=topografie&STYLES=defau
>>> lt&SRS=EPSG:
>>> 4326&BBOX=4.833984375,52.26815737376817,4.921875,52.32191088594773&W
>>> IDTH=256&HEIGHT=256&FORMAT=image/
>>> png&TRANSPARENT=TRUE&EXCEPTIONS=INIMAGE
>>>
>>> (this is a request from a gmap-based application)
>>> The important part, obviously, to make sure that the tiles have
>>> the same
>>> size (easy) and the same coordinates regardless of the client.
>>>
>>>
>>> grt,
>>> Steven
>>>
>>>
>>>
>>> Paul Spencer wrote:
>>>> Ok. I'm not sure if the URLs to the tiles are standard. The
>>>> URL goes
>>>> to a tile.php script which converts special pixel coordinates into
>>>> geographic coordinates. The math for the conversion is very simple
>>>> though, all you need to know is the size of a pixel in geographic
>>>> coordinates.
>>>>
>>>> I'll need to look into mapbuilders controls to understand how to do
>>>> the integration. Perhaps this could be the start of a common
>>>> API? ;)
>>>>
>>>> Cheers
>>>>
>>>> Paul
>>>>
>>>> On 13-Apr-06, at 11:33 PM, Cameron Shorter wrote:
>>>>
>>>>> The "standard URL" I was refering to is the URL of a tile.
>>>>>
>>>>> Both ka-map and mapbuilder have both implemented much of the same
>>>>> functionality. We will need to work out a logical place to split
>>>>> between the ka-map code and the mapbuilder code.
>>>>>
>>>>> I think it would be difficult to use Mapbuilder without Mapbuilder
>>>>> controls. Probably what we would need to do is convert your ka-
>>>>> map
>>>>> tools to fit within the Mapbuilder framework.
>>>>>
>>>>> Paul Spencer wrote:
>>>>>> Cameron,
>>>>>> what do you mean by standard url? ka-Map has a javascript API
>>>>>> that
>>>>>> handles all the navigation including the smooth panning of the
>>>>>> map. While not exactly like google, the api is roughly
>>>>>> equivalent.
>>>>>> Not sure if you could use mapbuilder's controls or not, it
>>>>>> would be
>>>>>> cool if you could.
>>>>>> I'll take a stab at installing/running MapBuilder this
>>>>>> weekend. Do
>>>>>> I need to do anything special to use the Google Map layer?
>>>>>> Cheers
>>>>>> Paul
>>>>>> On 13-Apr-06, at 6:26 AM, Cameron Shorter wrote:
>>>>>>> Paul,
>>>>>>> I'm currently allowing a Google Map layer to be included as
>>>>>>> one of
>>>>>>> the layers rendered by Mapbuilder.
>>>>>>>
>>>>>>> So if you have a standard URL used to call a tiled map server,
>>>>>>> then we can create a Mapbuilder Layer which accesses the URL
>>>>>>> (we'd probably base our code on your existing ka-maps code).
>>>>>>>
>>>>>>> I'd expect that we would use the Mapbuilder pan/zoom type tools
>>>>>>> and buttons rather than the ka-map tools.
>>>>>>>
>>>>>>> Is that what you were thinking about?
>>>>>>>
>>>>>>> Paul Spencer wrote:
>>>>>>>
>>>>>>>> What would be really nice would be to have a MapBuilder widget
>>>>>>>> for ka- Map ;) Mike Adair has mentioned that this is both
>>>>>>>> possible and quite easy to do. Not being very familiar with
>>>>>>>> MapBuilder, I can't comment on that. But if it were
>>>>>>>> possible to
>>>>>>>> do, ka-Map would provide you a tiled interface and you
>>>>>>>> could use
>>>>>>>> your existing map file to do it without breaking ogc
>>>>>>>> compatibility.
>>>>>>>> Cheers
>>>>>>>> Paul
>>>>>>>> On 12-Apr-06, at 4:33 AM, Steven M. Ottens wrote:
>>>>>>>>
>>>>>>>>> Hi Bart,
>>>>>>>>>
>>>>>>>>> Thanks for the mailinglist tip.
>>>>>>>>> It might be possible to rasterize our vector data, but
>>>>>>>>> we've got
>>>>>>>>> quite
>>>>>>>>> some datasets and there will be more of them. It also makes us
>>>>>>>>> less
>>>>>>>>> flexible. Obviously we've to make a trade-off on flexibility
>>>>>>>>> and speed.
>>>>>>>>> We hope that with cached tiles we can have both the
>>>>>>>>> flexibility
>>>>>>>>> and
>>>>>>>>> speed. If we rasterise it would make sense to rasterise into
>>>>>>>>> fixed tiles
>>>>>>>>> I guess.
>>>>>>>>>
>>>>>>>>> Steven
>>>>>>>>>
>>>>>>>>> Bart van den Eijnden wrote:
>>>>>>>>>
>>>>>>>>>> Hi Steven,
>>>>>>>>>>
>>>>>>>>>> there is an OGC list to discuss tiling:
>>>>>>>>>>
>>>>>>>>>> http://lists.eogeo.org/mailman/listinfo/tiling
>>>>>>>>>>
>>>>>>>>>> check the archives there.
>>>>>>>>>>
>>>>>>>>>> What you could also do, since I assume your data is pretty
>>>>>>>>>> much static, is
>>>>>>>>>> use UMN Mapserver to rasterize all your vector data (create
>>>>>>>>>> Geotiffs e.g.)
>>>>>>>>>> and serve out the rasters instead. I guess the
>>>>>>>>>> classifications
>>>>>>>>>> used are
>>>>>>>>>> heavy on CPU usage, and pre-classified rasters would solve
>>>>>>>>>> that part at
>>>>>>>>>> least.
>>>>>>>>>>
>>>>>>>>>> Best regards,
>>>>>>>>>> Bart
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>>> Hi all,
>>>>>>>>>>>
>>>>>>>>>>> For those who don't know: I'm one of the lead developers on
>>>>>>>>>>> the EduGIS
>>>>>>>>>>> project, a site which aims to introduce highschool students
>>>>>>>>>>> to GIS. The
>>>>>>>>>>> site contains a webmapping part, which combined with so
>>>>>>>>>>> called
>>>>>>>>>>> 'lesson-modules' can be used inside the classroom.
>>>>>>>>>>> We aim to be able to have at least 200 students access the
>>>>>>>>>>> site at one
>>>>>>>>>>> time. Since it's being used inside the classroom it means
>>>>>>>>>>> that
>>>>>>>>>>> a lot of
>>>>>>>>>>> students will do more or less the same thing at the same
>>>>>>>>>>> time
>>>>>>>>>>> (following
>>>>>>>>>>> the tasks in the lesson-modules). This causes quite some
>>>>>>>>>>> stress on the
>>>>>>>>>>> server. Since it's a free site we have limited budget and
>>>>>>>>>>> cannot put a
>>>>>>>>>>> google-style server park behind it ;(
>>>>>>>>>>>
>>>>>>>>>>> Right now we've got apache to serverside cache the umn
>>>>>>>>>>> mapserver output.
>>>>>>>>>>> This obviously works only for those images that are
>>>>>>>>>>> requested
>>>>>>>>>>> twice
>>>>>>>>>>> (like the first mapimage). Right now about 30 students can
>>>>>>>>>>> work at the
>>>>>>>>>>> same time without it becoming unworkable slow. Since
>>>>>>>>>>> serverside caching
>>>>>>>>>>> works, the next logical step to boost performance would be
>>>>>>>>>>> using tiles
>>>>>>>>>>> like google.
>>>>>>>>>>> But..
>>>>>>>>>>> From what I know, tiling breaks OGC compatibility, right?
>>>>>>>>>>> We're using Mapbuilder as client and we prefer to keep using
>>>>>>>>>>> it, since
>>>>>>>>>>> it's turning into a rather featureful client on the EduGIS
>>>>>>>>>>> site. But the
>>>>>>>>>>> question arises how to implement tiling inside
>>>>>>>>>>> WMC/OWS-context without
>>>>>>>>>>> breaking OGC too much.
>>>>>>>>>>> Also I'm interested in the used algorithms to get tiling
>>>>>>>>>>> working.
>>>>>>>>>>>
>>>>>>>>>>> Cheers,
>>>>>>>>>>> Steven
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>> ------------------------------------------------------------
>>>>>>>>>>> ------
>>>>>>>>>>>
>>>>>>>>>>> -- -
>>>>>>>>>>> To unsubscribe, e-mail:
>>>>>>>>>>> webmap-discuss-unsubscribe at mail.osgeo.org
>>>>>>>>>>> For additional commands, e-mail: webmap-discuss-
>>>>>>>>>>> help at mail.osgeo.org
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>> -------------------------------------------------------------
>>>>>>>>>> ------
>>>>>>>>>>
>>>>>>>>>> --To unsubscribe, e-mail:
>>>>>>>>>> webmap-discuss-unsubscribe at mail.osgeo.org
>>>>>>>>>> For additional commands, e-mail:
>>>>>>>>>> webmap-discuss-help at mail.osgeo.org
>>>>>>>>>>
>>>>>>>>>>
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> --------------------------------------------------------------
>>>>>>>>> ------
>>>>>>>>>
>>>>>>>>> -
>>>>>>>>> To unsubscribe, e-mail: webmap-discuss-
>>>>>>>>> unsubscribe at mail.osgeo.org
>>>>>>>>> For additional commands, e-mail:
>>>>>>>>> webmap-discuss-help at mail.osgeo.org
>>>>>>>>>
>>>>>>>> +--------------------------------------------------------------
>>>>>>>> ---+
>>>>>>>> |Paul Spencer
>>>>>>>> pspencer at dmsolutions.ca |
>>>>>>>> +--------------------------------------------------------------
>>>>>>>> ---+
>>>>>>>> |Applications & Software
>>>>>>>> Development |
>>>>>>>> |DM Solutions Group Inc http://
>>>>>>>> www.dmsolutions.ca/|
>>>>>>>> +--------------------------------------------------------------
>>>>>>>> ---+
>>>>>>>> ---------------------------------------------------------------
>>>>>>>> ------
>>>>>>>>
>>>>>>>> To unsubscribe, e-mail: webmap-discuss-
>>>>>>>> unsubscribe at mail.osgeo.org
>>>>>>>> For additional commands, e-mail: webmap-discuss-
>>>>>>>> help at mail.osgeo.org
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> --Cameron Shorter
>>>>>>> http://cameron.shorter.net
>>>>>>>
>>>>>>> ----------------------------------------------------------------
>>>>>>> -----
>>>>>>>
>>>>>>> To unsubscribe, e-mail: webmap-discuss-
>>>>>>> unsubscribe at mail.osgeo.org
>>>>>>> For additional commands, e-mail: webmap-discuss-
>>>>>>> help at mail.osgeo.org
>>>>>>>
>>>>>> +----------------------------------------------------------------
>>>>>> -+
>>>>>> |Paul Spencer
>>>>>> pspencer at dmsolutions.ca |
>>>>>> +----------------------------------------------------------------
>>>>>> -+
>>>>>> |Applications & Software
>>>>>> Development |
>>>>>> |DM Solutions Group Inc http://
>>>>>> www.dmsolutions.ca/|
>>>>>> +----------------------------------------------------------------
>>>>>> -+
>>>>>> -----------------------------------------------------------------
>>>>>> ----
>>>>>> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
>>>>>> For additional commands, e-mail: webmap-discuss-
>>>>>> help at mail.osgeo.org
>>>>>
>>>>>
>>>>> --Cameron Shorter
>>>>> http://cameron.shorter.net
>>>>>
>>>>> ------------------------------------------------------------------
>>>>> ---
>>>>> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
>>>>> For additional commands, e-mail: webmap-discuss-
>>>>> help at mail.osgeo.org
>>>>>
>>>>
>>>> +-----------------------------------------------------------------+
>>>> |Paul Spencer pspencer at dmsolutions.ca |
>>>> +-----------------------------------------------------------------+
>>>> |Applications & Software Development |
>>>> |DM Solutions Group Inc http://www.dmsolutions.ca/|
>>>> +-----------------------------------------------------------------+
>>>>
>>>>
>>>>
>>>>
>>>>
>>>> -------------------------------------------------------------------
>>>> --
>>>> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
>>>> For additional commands, e-mail: webmap-discuss-help at mail.osgeo.org
>>>>
>>>
>>>
>>>
>>> --------------------------------------------------------------------
>>> -
>>> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
>>> For additional commands, e-mail: webmap-discuss-help at mail.osgeo.org
>>>
>>
>> +-----------------------------------------------------------------+
>> |Paul Spencer pspencer at dmsolutions.ca |
>> +-----------------------------------------------------------------+
>> |Applications & Software Development |
>> |DM Solutions Group Inc http://www.dmsolutions.ca/|
>> +-----------------------------------------------------------------+
>>
>>
>>
>>
>>
>> ---------------------------------------------------------------------
>> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
>> For additional commands, e-mail: webmap-discuss-help at mail.osgeo.org
>>
>
>
>
> ---------------------------------------------------------------------
> To unsubscribe, e-mail: webmap-discuss-unsubscribe at mail.osgeo.org
> For additional commands, e-mail: webmap-discuss-help at mail.osgeo.org
>
+-----------------------------------------------------------------+
|Paul Spencer pspencer at dmsolutions.ca |
+-----------------------------------------------------------------+
|Applications & Software Development |
|DM Solutions Group Inc http://www.dmsolutions.ca/|
+-----------------------------------------------------------------+
More information about the Webmap-discuss
mailing list