URI

/coordtransfer[.<format>]

支持的方法

GETPOSTHEAD

父资源

data

子资源

coordTransferResult

介绍

coordTransfer 资源表示投影坐标系转换结果。通过对该资源执行 POST 请求,可以对点数组或一组几何对象进行投影坐标系转换,步骤如下:

  1. 对 coordTransfer 执行 POST 请求,在请求体中包含必要的参数,返回一个确定的结果资源(coordtransferResult 资源)的 URI;

  2. 对返回的 URI 进行 GET 操作,得到转换结果。

支持的方法:

  • GET:获取执行 POST 请求的表单 。
  • POST:根据给定的条件,创建一个坐标系转换结果资源。
  • HEAD:检查 coordTransfer 资源是否存在,或权限是否可以访问 coordTransfer 资源。

支持的表述格式:RJSON、JSON、HTML、XML。

资源层次

HTTP 请求方法

对如下 URI 执行 HTTP 请求,以 rjson 输出格式为例加以说明,其中,supermapiserver 是服务器名。

http://supermapiserver:8090/iserver/services/data-world/rest/data/coordtransfer.rjson

GET 请求

获取执行 POST 请求的表单 。

POST 请求

根据给定条件,创建一个数据查询结果资源。

请求参数

在请求体中需要包含如下参数:

名称 类型 含义
sourcePoints Point2D[] 源点数组。例如:[{"x":113.98533886568,"y":4.39179640504}]。与 sourceGeometry 必填一项。
sourceGeometries Geometry[] 源几何对象。当要转换的几何对象为线、面时,可使用此参数。可同时传入不同类型的几何对象。例如:[{"type":"REGION","points":[{"x":30,"y":60},{"x":60,"y":60},{"x":60,"y":30},{"x":30,"y":60}]},{"type":"LINE","points":[{"x":45,"y":70},{"x":80,"y":80},{"x":60,"y":30}]}]。与 sourcePoints 必填一项。

sourceEpsgCode

int 源点数组或几何对象的坐标系对应的EPSG Code。与 sourcePrj 必填一项。
sourcePrj PrjCoordSys 源点数组或几何对象的坐标系 json 描述。当坐标系无对应的EpsgCode时,可使用此参数。与sourceEpsgCode 必填一项。
targetPrj PrjCoordSys 目标坐标系。 将转换的目标投影坐标系。当目标坐标系无对应的EpsgCode时,可使用此参数。 参数使用时,需按照PrjCoordSys中的字段结构来构建。与 targetEpsgCode 必填一项。
targetEpsgCode int 目标坐标系对应的EPSG Code。与 targetPrj 必填一项。

响应结构

对 coordTransfer 资源执行 POST 请求,返回的创建结果的结构如下:

字段 类型 说明
succeed boolean 数据查询是否成功。
newResourceID String 创建的 coordTransferResult 资源的 ID。
newResourceLocation String 创建的 coordTransferResult 资源的 URI。

示例1

对 coordTransfer 资源执行 POST 请求,对传入的几何对象进行投影坐标系转换(即创建一个 coordTransferResult 资源):http://supermapiserver:8090/iserver/services/data-world/rest/data/coordtransfer.rjson,源坐标系和目标坐标系都通过 Epsg Code 设置。请求体参数如下:

{

"sourcePoints":[{"x":113.98533886568,"y":4.39179640504}],

"sourceEpsgCode":4326,

"targetEpsgCode":3857

}

返回 rjson 格式的操作结果表述如下:

{

    "newResourceID": "159790bc662f49579a938a5a52ca1415_eb5271f601aa4067905273c18fcc17a5",

    "newResourceLocation": "http://localhost:8090/iserver/services/data-world/rest/data/coordtransfer/159790bc662f49579a938a5a52ca1415_eb5271f601aa4067905273c18fcc17a5.rjson",

    "postResultType": "CreateChild",

    "succeed": true

}

示例2

对 coordTransfer 资源执行 POST 请求,对传入的几何对象进行投影坐标系转换(即创建一个 coordTransferResult 资源):http://supermapiserver:8090/iserver/services/data-world/rest/data/coordtransfer.rjson,源坐标系和目标坐标系都通过坐标系的 json 描述进行设置。请求体参数如下:

{

"sourcePoints":[{"x":113.98533886568, "y":4.39179640504}],

"sourcePrj":{

   "distanceUnit":"METER",

   "projectionParam":null,

   "epsgCode":4326,

   "coordUnit":"DEGREE",

   "name":"Longitude / Latitude Coordinate System---GCS_WGS_1984",

   "projection":null,

   "type":"PCS_EARTH_LONGITUDE_LATITUDE",

   "coordSystem":{

       "datum":{

          "name":"D_WGS_1984",

          "type":"DATUM_WGS_1984",

          "spheroid":{

              "flatten":0.00335281066474748,

              "name":"WGS_1984", "axis":6378137,

              "type":"SPHEROID_WGS_1984"

            }

       },

    "unit":"DEGREE",

    "spatialRefType":"SPATIALREF_EARTH_LONGITUDE_LATITUDE",

    "name":"GCS_WGS_1984",

    "type":"GCS_WGS_1984",

    "primeMeridian":{

         "longitudeValue":0,

         "name":"Greenwich",

         "type":"PRIMEMERIDIAN_GREENWICH"  

        }

     }

},

"targetPrj":{

    "distanceUnit":"METER",

    "projectionParam":{

       "centralParallel":0,

       "firstPointLongitude":0,

       "rectifiedAngle":0,

       "scaleFactor":1,

       "falseNorthing":0,

       "centralMeridian":0,

       "secondStandardParallel":0,

       "secondPointLongitude":0,

       "azimuth":0, "falseEasting":0,

       "firstStandardParallel":0

    },

    "epsgCode":3857,

    "coordUnit":"METER",

    "name":"User Define",

    "projection":{

       "name":"SPHERE_MERCATOR",

       "type":"PRJ_SPHERE_MERCATOR"},

       "type":"PCS_USER_DEFINED",

       "coordSystem":{

          "datum":{

              "name":"D_WGS_1984",

              "type":"DATUM_WGS_1984",

              "spheroid":{

                   "flatten":0.00335281066474748,

                   "name":"WGS_1984",

                   "axis":6378137,

                   "type":"SPHEROID_WGS_1984"}},

                   "unit":"DEGREE",

                   "spatialRefType":"SPATIALREF_EARTH_LONGITUDE_LATITUDE",

                   "name":"GCS_WGS_1984",

                   "type":"GCS_WGS_1984",

                   "primeMeridian":{

                       "longitudeValue":0,

                       "name":"Greenwich",

                       "type":"PRIMEMERIDIAN_GREENWICH"

                    }

                }

       }

}

返回 rjson 格式的操作结果表述如下:

{

    "newResourceID": "159790bc662f49579a938a5a52ca1415_e9d2badac8bf4be4a562a31e2103f7f4",

    "newResourceLocation": "http://localhost:8090/iserver/services/data-World/rest/data/coordtransfer/159790bc662f49579a938a5a52ca1415_e9d2badac8bf4be4a562a31e2103f7f4.rjson",

    "postResultType": "CreateChild",

    "succeed": true

}

HEAD 请求

返回跟 GET 请求一样的 HTTP 响应头,但是没有响应实体。可以在不必传输整个响应内容的情况下,获取包含在响应消息头中的元数据信息。元数据信息包括媒体类型,字符编码,压缩编码,实体内容长度等。

HEAD 请求可以用来判断 coordTransfer 资源是否存在,或者客户端是否有权限访问 coordTransfer 资源。通过对加.<format>的 URI 执行 HEAD 请求,还可以快速判断 coordTransfer 资源是否支持<format>格式的表述。

请参见