[webmap-discuss] OGC and google style tiling

Paul Spencer pspencer at dmsolutions.ca
Fri Apr 28 07:42:41 EDT 2006


In tile.php, we use two mapserver tricks to work around this issue:

1) draw an image 10 pixels larger in all dimensions than we really  
want.  The problem with this is that labels, symbols etc can end up  
in the 10 pixel buffer and get clipped, so we ...

2) apply a buffer around the edge of the map to prevent labels and  
symbols from showing up in the to-be-clipped area

The resulting image can then be tiled.

There are really two issues that I would like to see solved in  
MapServer:

1) producing tiles directly

2) labeling in tiled mode

Producing Tiles Directly ...

It would be relatively easy to ask mapserver to generate multiple  
images from a single map draw if you are using mapscript but I don't  
see a way to do it using the cgi.  This means that you really need to  
request single tiles and then cache them using squid or some other  
caching layer in the architecture.

To generate single tiles, you need to automatically buffer and clip  
the edges.  This could be controlled via metadata in the map file, or  
perhaps should be the built-in-default-way-of-operating.  The extra  
overhead would be minimal IMO.

Labeling in Tiled Mode ...

The bigger issue in generating excellent maps is the whole labelling  
thing.  Ultimately, the best map would come from rendering the entire  
map at each scale as a single image and then slicing it.  This is not  
practical since even a 2000x2000 pixel map really slows mapserver down.

In order to do labeling correctly, you need to consider a broader  
spatial context than that being drawn and deterministically place  
labels so that you get consistent results without duplication (or  
with duplicates at pre-determined intervals).  Labels would have to  
be able to cross tile boundaries in such a way that combining  
adjacent tiles would reconstitute the label.

I don't have a really good idea of how this could be done.  Perhaps a  
global, persistent label cache?  Or a pre-generated label layer that  
is processed at particular scales and calculates where each label  
needs to be drawn.  AFAIK there isn't a good solution to this problem :S

Google 'seems' to have solved this problem, but in my opinion, they  
have simply chosen larger meta-tile sizes and have a nearly infinite  
set of resources to pre-render the tiles at all scales prior to going  
live.  They do not generate the tiles on the fly, and I have noticed  
some label duplication in some cases.


On the subject of performance boost, the boost comes from caching the  
tiles once they are generated, not from the generation process.  IMO,  
the generation process can be relatively slow.  This is especially  
true if you want to enable antialiased thick lines and 'curved' text  
that follows streets.  The overhead of rendering far outweighs the  
overhead of cutting tiles.

Cheers

Paul


On 28-Apr-06, at 7:11 AM, Steven M. Ottens wrote:

> Hi Dave,
>
> In my opinion the edge problem is a bug in mapserver and should be
> solved in mapserver, not with a workaround. But i'm not too  
> knowledgable
> on mapserver so I could be mistaken. Anyhow I don't think we should  
> need
> any post-rendering processing of the mapserver-images. The whole point
> of tiling is a performance boost. So if every tile needs to be recut
> after being rendered it'll generate more overhead. I'm believing in a
> WMS-server solution which creates and cuts tiles like tile.php does  
> now.
> This should solve the edge *and* labeling issues.
>
> Steven
>
>
> On Thu, 2006-04-27 at 15:28 -0400, dblasby at openplans.org wrote:
>> I've been thinking of tiling rendering for WMS in general, and  
>> geoserver
>> in particular (especially with OpenLayers apparently coming out soon
>> and mapbuilder also adding similar functionality).
>>
>> Paul gave a good account of the problems that I've been thinking  
>> about:
>> a) Edge Rendering Effects
>> b) cache HTTP headers
>> c) Get capabilities (ie. tell clients about how to make requests --
>> hopefully OGC will define this)
>> d) Labeling
>>
>> I think a-c are actually fairly easy to handle with a "dumb" proxy  
>> WMS.
>> Take a quick look at the two images I attached.
>>
>> a) Edge Rendering Effects
>>      This can be handled simply by intercepting an incoming WMS
>> request, expanding the request bounding box and image size and  
>> sending
>> the request down to the actual WMS server.  The image returned is  
>> then
>> "cookie cut" so its the proper size/extent of the original request.
>>
>>      You'd have to tune the expansion size, but generally you'll  
>> want it
>> to be a few pixels wider than your "widest style."  For example, if
>> your roads are 12 pixels wide you'd want to expand the image by about
>> 14 pixels in all directions (extra pixels are to account for
>> anti-aliasing).
>
>
>>
>> b) cache HTTP headers
>>       Geoserver allows you to set the cache expire headers, but  
>> you can
>> also have the WMS proxy mangle header for servers that dont allow  
>> this.
>>
>> c) Get capabilities
>>       At some time in the future, the WMS 'get capabilities' document
>> will contain the grid information the server wants the client to use
>> for tiling.  Once this is defined, the proxy WMS can augment the real
>> server's get capabilities so that clients make "proper" requests.
>>
>>
>> Unfortunately, I dont see a good solution to labeling issues (except
>> making requests for very large images) - anyone have any ideas?
>>
>> dave
>>
>> ----------------------------------------------------------
>> This mail sent through IMP: https://webmail.limegroup.com/
>> ---------------------------------------------------------------------
>> 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