Class RestMapProvider
- java.lang.Object
-
- com.supermap.services.providers.RestProviderBase
-
- com.supermap.services.providers.RestMapProvider
-
- All Implemented Interfaces:
- ChartMapProvider, Disposable, DynamicProjectionable, MapProvider, ProviderContextAware
public class RestMapProvider extends RestProviderBase implements ProviderContextAware, DynamicProjectionable, MapProvider, ChartMapProvider
REST map service provider.
RESTMapProvider provides services for getting SuperMap iServer maps from the REST services and encapsulates GIS functionalities related to SuperMap iServer map.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.supermap.services.providers.RestProviderBase
RestProviderBase.CacheModel, RestProviderBase.RestRequestException
-
-
Field Summary
Fields Modifier and Type Field and Description static java.lang.StringDISTANCE-
Fields inherited from class com.supermap.services.providers.RestProviderBase
JAVA_POSTFIX, javaConverter, JSON_POSTFIX, jsonConverter, jsonDecoder, lock, logger, message
-
-
Constructor Summary
Constructors Constructor and Description RestMapProvider()The constructor.RestMapProvider(RestMapProviderSetting setting)The constructor.
-
Method Summary
Methods Modifier and Type Method and Description protected static voidcheckParameterNull(java.lang.Object obj, java.lang.String parameterName)voidclearCache(java.lang.String mapName, Rectangle2D bounds)Clears the cached tiles within the specified bounds.protected java.lang.StringcreateMapParamKVPPart(MapParameter param, OutputFormat format, boolean transparent)Serializes the MapParameter object to generate MapParameter related items for the Get method of the image resource.voiddispose()Release the resource object.QueryResultfindNearest(java.lang.String mapName, Geometry geometry, double maxDistance, QueryParameterSet queryParameterSet)Queries the nearest geometric object on a specified map whose distance to a specified geometry is within a certain value.java.util.List<ChartFeatureInfoSpec>getChartFeatureInfoSpecs()Gets all object typesMapParametergetDefaultMapParameter(java.lang.String mapName)Gets the default map parameters of the specified map.java.util.List<PrjCoordSys>getDynamicPrjCoordsyses(java.lang.String mapName)Map supported dynamic projection lists.protected java.util.List<Layer>getLayers(java.lang.String mapName)MapImagegetMapImage(MapParameter mapParameter, ImageOutputOption outputOption)Gets map images according to map parameters and image output settings.MapParametergetMapParameter(java.lang.String mapName)Gets map parameters.java.util.List<java.lang.String>getNames()Returns the list of map names.OverviewgetOverview(MapParameter mapParameter, ImageOutputOption outputOption)Gets eagle-eye map according to map parameters and image output settings.java.lang.StringgetResource(java.lang.String mapName, ResourceParameter resourceParameter)Gets the resource image of a specified map according to a resource image parameter.byte[]getResource(java.lang.String mapName, ResourceParameter resourceParameter, Point2D[] points)Gets the resource image of a specified map according to a resource image parameter.protected RestProviderSettinggetRestProviderSetting()Return the rest service provider configuration information.VectorStylegetVectorStyle(java.lang.String mapName, java.lang.String[] layerNames, VectorStyleType type)Gets the specified vector layer style in the specified map.MeasureResultmeasureArea(java.lang.String mapName, Point2D[] points, MeasureParameter measureParam)Measures areas on a specified map based on 2D geographic coordinates and a measuring parameter.MeasureResultmeasureDistance(java.lang.String mapName, Point2D[] points, MeasureParameter measureParam)Measures distances on a specified map based on 2D geographic coordinates and a measuring parameter.QueryResultqueryByBounds(java.lang.String mapName, Rectangle2D bounds, QueryParameterSet queryParameterSet)Queries the geometries in the specified range on the map.QueryResultqueryByDistance(java.lang.String mapName, Geometry geometry, double distance, QueryParameterSet queryParameterSet)Queries all the geometric objects on a specified map whose distances to a specified geometry are within a certain value.QueryResultqueryByGeometry(java.lang.String mapName, Geometry geometry, SpatialQueryMode spatialQueryMode, QueryParameterSet queryParameterSet)Queries geometric objects that satisfy a certain spatial relationship with a specified geometric object and meet query conditions on a specified map.QueryResultqueryBySQL(java.lang.String mapName, QueryParameterSet queryParameterSet)Performs SQL query on specified map.QueryResultqueryChart(java.lang.String mapName, java.lang.String[] chartLayerNames, ChartQueryParameterSet chartQueryParams)Sea chart function, object attribute query.QueryResultqueryChart(java.lang.String mapName, java.lang.String[] chartLayerNames, ChartQueryParameterSet chartQueryParams, Rectangle2D bounds)Sea chart function, object bounds query.MapParametersetDefaultMapParameter(MapParameter mapParameter)Sets the default map parameters.voidsetProviderContext(ProviderContext context)Sets the service provider context.booleansupport(java.lang.String mapname, MapCapability capability)Determines whether the map supports the specified function.booleanupdateMap(MapParameter mapParameter)Updates the map status permanently, which will do a persistence in the disk.MapImageviewEntire(java.lang.String layerName, MapParameter mapParameter, ImageOutputOption outputOption)Displays a map in the Full Extent mode according to map layer name, map parameters and image output settings.-
Methods inherited from class com.supermap.services.providers.RestProviderBase
clearCache, executeRequest, executeRequest, executeRequest, executeRequestForByteArray, executeRequestForByteArray, executeRequestForByteArray, executeRequestForByteArray, executeRequestForList, executeRequestForList, executeRequestForList, executeRequestForList, executeRequestForStream, executeRequestForStream, executeRequestForStream, executeRequestForText, executeRequestForText, executeRequestForText, handleExeption, init, newAndSetClient, rectifyRestServiceRootURL
-
-
-
-
Constructor Detail
-
RestMapProvider
public RestMapProvider(RestMapProviderSetting setting)
The constructor.
- Parameters:
setting-
-
RestMapProvider
public RestMapProvider()
The constructor.
-
-
Method Detail
-
checkParameterNull
protected static void checkParameterNull(java.lang.Object obj, java.lang.String parameterName)
-
setProviderContext
public void setProviderContext(ProviderContext context)
Sets the service provider context.
- Specified by:
setProviderContextin interfaceProviderContextAware- Parameters:
context- The service provider context.
-
getNames
public java.util.List<java.lang.String> getNames()
Returns the list of map names.
- Specified by:
getNamesin interfaceMapProvider- Returns:
- Map name list.
-
getMapParameter
public MapParameter getMapParameter(java.lang.String mapName)
Gets map parameters.
- Specified by:
getMapParameterin interfaceMapProvider- Parameters:
mapName- The map name.- Returns:
- Map parameters.
-
clearCache
public void clearCache(java.lang.String mapName, Rectangle2D bounds)Clears the cached tiles within the specified bounds.
- Specified by:
clearCachein interfaceMapProvider- Parameters:
mapName- The map name.bounds- The specified map extent.
-
getMapImage
public MapImage getMapImage(MapParameter mapParameter, ImageOutputOption outputOption)
Gets map images according to map parameters and image output settings.
- Specified by:
getMapImagein interfaceMapProvider- Parameters:
mapParameter- Map parameter, can not be null.outputOption- Image output settings.- Returns:
- The map image object.
-
getResource
public java.lang.String getResource(java.lang.String mapName, ResourceParameter resourceParameter)Gets the resource image of a specified map according to a resource image parameter.
- Specified by:
getResourcein interfaceMapProvider- Parameters:
mapName- Map name, can not be null.resourceParameter- The resource image parameter.- Returns:
- The resource image address.
-
measureDistance
public MeasureResult measureDistance(java.lang.String mapName, Point2D[] points, MeasureParameter measureParam)
Description copied from interface:MapProviderMeasures distances on a specified map based on 2D geographic coordinates and a measuring parameter.
- Specified by:
measureDistancein interfaceMapProvider- Parameters:
mapName- The map name.points- The array of 2D geographic coordinates.measureParam- The measuring parameter.- Returns:
- Measurement result object.
-
measureArea
public MeasureResult measureArea(java.lang.String mapName, Point2D[] points, MeasureParameter measureParam)
Description copied from interface:MapProviderMeasures areas on a specified map based on 2D geographic coordinates and a measuring parameter.
- Specified by:
measureAreain interfaceMapProvider- Parameters:
mapName- The map name.points- The array of 2D geographic coordinates.measureParam- The measuring parameter.- Returns:
- Measurement result object.
-
queryByDistance
public QueryResult queryByDistance(java.lang.String mapName, Geometry geometry, double distance, QueryParameterSet queryParameterSet)
Description copied from interface:MapProviderQueries all the geometric objects on a specified map whose distances to a specified geometry are within a certain value.
Which means to query all the geometries within a circle whose center is the specified geometry.
- Specified by:
queryByDistancein interfaceMapProvider- Parameters:
mapName- The map name.geometry- The geometric object.distance- The querying distance.queryParameterSet- Query parameters can query multiple layers of a map. The query parameters in a single layer can be set inqueryParameterSet.queryParams[i].- Returns:
- Query result object.
-
queryByGeometry
public QueryResult queryByGeometry(java.lang.String mapName, Geometry geometry, SpatialQueryMode spatialQueryMode, QueryParameterSet queryParameterSet)
Description copied from interface:MapProviderQueries geometric objects that satisfy a certain spatial relationship with a specified geometric object and meet query conditions on a specified map.
- Specified by:
queryByGeometryin interfaceMapProvider- Parameters:
mapName- The map name.geometry- The geometric object, which has spatial information and shape information, but no attribute information.spatialQueryMode- The spatial query mode, which defines several spatial relationships between geometries, and it allows users to construct filter conditions to perform querying. For example, searching spatial objects which are contained in specified region object, or which have a disjoint or adjacent relationship with the specified region object.queryParameterSet- Query parameters can query multiple layers of a map. The query parameters in a single layer can be set inqueryParameterSet.queryParams[i].- Returns:
- Query result object.
-
queryByBounds
public QueryResult queryByBounds(java.lang.String mapName, Rectangle2D bounds, QueryParameterSet queryParameterSet)
Description copied from interface:MapProviderQueries the geometries in the specified range on the map.
- Specified by:
queryByBoundsin interfaceMapProvider- Parameters:
mapName- The map name.bounds- The specified query bounds.- Returns:
- Query result object.
-
queryBySQL
public QueryResult queryBySQL(java.lang.String mapName, QueryParameterSet queryParameterSet)
Description copied from interface:MapProviderPerforms SQL query on specified map.
- Specified by:
queryBySQLin interfaceMapProvider- Parameters:
mapName- The map name.queryParameterSet- Query parameters can query multiple layers of a map. The query parameters in a single layer can be set inqueryParameterSet.queryParams[i].- Returns:
- Query result object.
-
setDefaultMapParameter
public MapParameter setDefaultMapParameter(MapParameter mapParameter)
Description copied from interface:MapProviderSets the default map parameters.
- Specified by:
setDefaultMapParameterin interfaceMapProvider- Parameters:
mapParameter- Map parameters.- Returns:
- The map parameter object.
-
getDefaultMapParameter
public MapParameter getDefaultMapParameter(java.lang.String mapName)
Description copied from interface:MapProviderGets the default map parameters of the specified map.
Retrieval of the initial default map parameter depends on the type of the service accessed. For example, if the GIS functions provided by SuperMap Objects Java are accessed, the initial default map parameter is obtained from a workspace file; if the GIS functions of a WMS service are accessed, the default map parameter is determined in the WMS service.
- Specified by:
getDefaultMapParameterin interfaceMapProvider- Parameters:
mapName- The map name.- Returns:
- The map parameter object.
-
viewEntire
public MapImage viewEntire(java.lang.String layerName, MapParameter mapParameter, ImageOutputOption outputOption)
Displays a map in the Full Extent mode according to map layer name, map parameters and image output settings.
The full geographic map extent to display is the minimum circumscribed rectangle of the specified layer.
- Specified by:
viewEntirein interfaceMapProvider- Parameters:
layerName- Layer name, used to determine the full map extent.mapParameter- Map parameters.outputOption- Image output settings.- Returns:
- The Map object.
-
getOverview
public Overview getOverview(MapParameter mapParameter, ImageOutputOption outputOption)
Description copied from interface:MapProviderGets eagle-eye map according to map parameters and image output settings.
- Specified by:
getOverviewin interfaceMapProvider- Parameters:
mapParameter- Map parameters.outputOption- Image output settings.- Returns:
- Eagle-eye object.
-
findNearest
public QueryResult findNearest(java.lang.String mapName, Geometry geometry, double maxDistance, QueryParameterSet queryParameterSet)
Description copied from interface:MapProviderQueries the nearest geometric object on a specified map whose distance to a specified geometry is within a certain value. When limit the number of returned geometric objects (specified by
QueryParameterSet.expectCount), the query result is the expectCount features nearest to the center in the records. There is no orders of expectCount.- Specified by:
findNearestin interfaceMapProvider- Parameters:
mapName- The map name.geometry- The geometric object.maxDistance- The maximum distance, of which the unit is identical with that of the map specified with mapName parameter.queryParameterSet- Query parameters can query multiple layers of a map. The query parameters in a single layer can be set inqueryParameterSet.queryParams[i].- Returns:
- Query result object.
-
getRestProviderSetting
protected RestProviderSetting getRestProviderSetting()
Description copied from class:RestProviderBaseReturn the rest service provider configuration information.- Specified by:
getRestProviderSettingin classRestProviderBase- Returns:
-
getDynamicPrjCoordsyses
public java.util.List<PrjCoordSys> getDynamicPrjCoordsyses(java.lang.String mapName)
Description copied from interface:DynamicProjectionableMap supported dynamic projection lists.- Specified by:
getDynamicPrjCoordsysesin interfaceDynamicProjectionable- Returns:
-
getChartFeatureInfoSpecs
public java.util.List<ChartFeatureInfoSpec> getChartFeatureInfoSpecs()
Description copied from interface:ChartMapProviderGets all object types- Specified by:
getChartFeatureInfoSpecsin interfaceChartMapProvider
-
queryChart
public QueryResult queryChart(java.lang.String mapName, java.lang.String[] chartLayerNames, ChartQueryParameterSet chartQueryParams)
Description copied from interface:ChartMapProviderSea chart function, object attribute query.- Specified by:
queryChartin interfaceChartMapProvider
-
queryChart
public QueryResult queryChart(java.lang.String mapName, java.lang.String[] chartLayerNames, ChartQueryParameterSet chartQueryParams, Rectangle2D bounds)
Description copied from interface:ChartMapProviderSea chart function, object bounds query.- Specified by:
queryChartin interfaceChartMapProvider
-
getLayers
protected java.util.List<Layer> getLayers(java.lang.String mapName)
-
createMapParamKVPPart
protected java.lang.String createMapParamKVPPart(MapParameter param, OutputFormat format, boolean transparent)
Serializes the MapParameter object to generate MapParameter related items for the Get method of the image resource. The redirect parameters are not included. The function does not perform null or validity checks on the parameter, not checking whether MapParameter.name is correct for instance. However, it performs null check on the fields of the parameter.
- Parameters:
param- The MapParameter object that needs to be serialized.format-transparent-- Returns:
- ?center=xxx&viewer=xxx
-
support
public boolean support(java.lang.String mapname, MapCapability capability)Description copied from interface:MapProviderDetermines whether the map supports the specified function.- Specified by:
supportin interfaceMapProvider- Parameters:
mapname- The map name.capability- Function type.- Returns:
- true means to support; otherwise, false.
-
getResource
public byte[] getResource(java.lang.String mapName, ResourceParameter resourceParameter, Point2D[] points)Description copied from interface:MapProviderGets the resource image of a specified map according to a resource image parameter.
- Specified by:
getResourcein interfaceMapProvider- Parameters:
mapName- The map name.resourceParameter- The resource image parameter.points- The points used to draw resource images.- Returns:
- Binary stream of the image.
-
getVectorStyle
public VectorStyle getVectorStyle(java.lang.String mapName, java.lang.String[] layerNames, VectorStyleType type)
Description copied from interface:MapProviderGets the specified vector layer style in the specified map.- Specified by:
getVectorStylein interfaceMapProvider- Parameters:
mapName- The map name.layerNames- The layer name.type- The vector style type.- Returns:
- Vector layer style.
-
dispose
public void dispose()
Description copied from interface:DisposableRelease the resource object.
- Specified by:
disposein interfaceDisposable- Overrides:
disposein classRestProviderBase
-
updateMap
public boolean updateMap(MapParameter mapParameter)
Description copied from interface:MapProviderUpdates the map status permanently, which will do a persistence in the disk.- Specified by:
updateMapin interfaceMapProvider- Parameters:
mapParameter- The map status to update to.- Returns:
- Whether the update is successful.
-
-