Assert.notNull(layerName);
Assert.notNull(info);
Assert.notNull(layerBounds);
final TileCacheInfo tileCacheInfo = info.getTileCacheInfo();
final SpatialReference spatialReference = tileCacheInfo.getSpatialReference();
final SRS srs;
final BoundingBox gridSetExtent;
final boolean alignTopLeft = true;
final double[] resolutions;
/*
* let scale denoms be null so GridSetFactory computes them based on resolutions. The
* resulting values will be pretty close to the ones defined in the ArcGIS tiling scheme
*/
final double[] scaleDenominators = null;
final Double metersPerUnit;
final String[] scaleNames = null;
final int tileWidth = tileCacheInfo.getTileCols();
final int tileHeight = tileCacheInfo.getTileRows();
final boolean yCoordinateFirst = false;
final double pixelSize = 0.0254 / tileCacheInfo.getDPI();// see GridSubset.getDotsPerInch()
{
int epsgNumber = spatialReference.getWKID();
if (0 == epsgNumber) {
}
srs = SRS.getSRS(epsgNumber);
}
{
final List<LODInfo> lodInfos = tileCacheInfo.getLodInfos();
double[][] resAndScales = getResolutions(lodInfos);
resolutions = resAndScales[0];
double[] scales = resAndScales[1];
//TODO: check whether pixelSize computed above should be used instead
metersPerUnit = (GridSetFactory.DEFAULT_PIXEL_SIZE_METER * scales[0]) / resolutions[0];
}
{
// See "How to calculate the -x parameter used in the examples above" at
// http://resources.arcgis.com/content/kbase?q=content/kbase&fa=articleShow&d=15558&print=true
// double XOrigin = spatialReference.getXOrigin();
// double YOrigin = spatialReference.getYOrigin();
// XYScale = 40075017 / 360 = ~111319, where 40075017 is the circumference of the earth
// at the ecuator and 360 the map units at the ecuator
// final double xyScale = spatialReference.getXYScale();
final TileOrigin tileOrigin = tileCacheInfo.getTileOrigin();// top left coordinate
double xmin = tileOrigin.getX();
double ymax = tileOrigin.getY();
double ymin = layerBounds.getMinY();
double xmax = layerBounds.getMaxX();