Package org.geotools.tile
Class TileFactory
Object
TileFactory
- Direct Known Subclasses:
- WebMercatorTileFactory,- WMTSTileFactory
A TileFactory is responsible for finding and/or creating tiles for a given TileService and area. Here we make no
 distinction whereas a requested tile is created or retrieved form an internal cache.
 
When creating/finding a tile, the factory must know the zoom level for which the tile is required. Also, a geographic position or, alternatively a reference tile, must be passed.
- Since:
- 12
- Author:
- Tobias Sauerwein, Ugo Taddei
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionabstract Tilecreate(TileIdentifier identifier, TileService service) Creates a new tile for the given position using a service.abstract TilefindLowerNeighbour(Tile tile, TileService service) Finds the tile for a service at the given position and zoom level, which is immediately below the the passed tile.abstract TilefindRightNeighbour(Tile tile, TileService service) Finds the tile for a service at the given position and zoom level, which is immediately to the right of the passed tile.abstract TilefindTileAtCoordinate(double lon, double lat, ZoomLevel zoomLevel, TileService service) Finds the tile for a service at the given position and zoom level.abstract ZoomLevelgetZoomLevel(int zoomLevel, TileService service) Gets the ZoomLevel (object) for a given zoom level integer.static doublenormalizeDegreeValue(double value, int maxValue) Some clients, e.g. uDig, may produce numbers like -210° for the longitude, but we need a number in the range -180 to 180, so instead of -210 we want 150.
- 
Constructor Details- 
TileFactorypublic TileFactory()
 
- 
- 
Method Details- 
createCreates a new tile for the given position using a service.- Parameters:
- identifier-
- service-
- Returns:
 
- 
findTileAtCoordinatepublic abstract Tile findTileAtCoordinate(double lon, double lat, ZoomLevel zoomLevel, TileService service) Finds the tile for a service at the given position and zoom level.- Parameters:
- lon- the longitude
- lat- the latitude
- zoomLevel- the zoom level
- service- the service
- Returns:
- a tile
 
- 
getZoomLevelGets the ZoomLevel (object) for a given zoom level integer.- Parameters:
- zoomLevel- the zoom level
- service- the service
- Returns:
- a zoom level
 
- 
findRightNeighbourFinds the tile for a service at the given position and zoom level, which is immediately to the right of the passed tile.- Parameters:
- tile- the reference tile
 
- 
findLowerNeighbourFinds the tile for a service at the given position and zoom level, which is immediately below the the passed tile.- Parameters:
- tile- the reference tile
 
- 
normalizeDegreeValuepublic static double normalizeDegreeValue(double value, int maxValue) Some clients, e.g. uDig, may produce numbers like -210° for the longitude, but we need a number in the range -180 to 180, so instead of -210 we want 150.- Parameters:
- value- the number to normalize (e.g. -210)
- maxValue- the maximum value (e.g. 180 -> the range is: -180..180)
- Returns:
- a number between (-maxvalue) and maxvalue
 
 
-