URI

<geometry_uri>/coordTransfer[.<format>]

支持的方法

GETPOSTHEAD

父资源

geometry

介绍

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

支持的方法:

  • GET:获取执行 POST 请求的表单 。
  • POST:根据给定的条件,对点数组或一组几何对象进行投影坐标系转换。
  • HEAD:检查 coordTransfer 资源是否存在,或权限是否可以访问 coordTransfer 资源。

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

资源层次

HTTP 请求方法

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

http://supermapiserver:8090/iserver/services/geometry/restjsr/v1/geometry/coordtransfer.rjson

GET 请求

获取执行 POST 请求的表单 。

POST 请求

根据给定条件,对点数组或一组几何对象进行投影坐标系转换。

请求参数

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

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

sourceEpsgCode

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

响应结构

对 coordTransfer 资源执行 POST 请求,在响应消息的实体主体里是一个转换结果描述集 Geometry[],其中单个结果描述的结构如下:

字段 类型 说明
center Point2D[] 几何对象中心点。
parts int[] 描述几何对象中各个子对象所包含的节点的个数。
style Style 几何对象的风格。
prjCoordSy PrjCoordSys 几何对象的投影坐标系。
id int 几何对象唯一标识符。
pointTopo int[] part的拓补结构,目前仅当 GeometryType = REGION 时,此字段有值,1代表为岛,-1代表为洞。
points Point2D[] 组成几何对象的节点的二维坐标对数组。

示例

对 coordTransfer 资源执行 POST 请求,对传入的点数组进行投影坐标系转换:http://supermapiserver:8090/iserver/services/geometry/restjsr/v1/geometry/coordtransfer.rjson,源坐标系通过 epsgcode 表示,目标坐标系通过坐标系的 json 描述进行设置。请求体参数如下:

{

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

  "sourceEpsgCode":4326,

  "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"

                         }

                  }

      }

}

返回操作结果表述如下:

[

   {

    "center":

      {

        "x":1.2688789880426234E7,

        "y":489371.98562014854

      },

     "parts":[1],

     "style":null,

     "prjCoordSys":null,

     "id":0,

     "type":"POINT",

     "partTopo":null,

     "points":

       [

          {

            "x":1.2688789880426234E7,

            "y":489371.98562014854

           }

        ]

      },

     {

     "center":

       {

         "x":1.257747038963296E7,

         "y":377793.7702294255

       },

     "parts":[1],

     "style":null,

     "prjCoordSys":null,

     "id":0,

     "type":"POINT",

     "partTopo":null,

     "points":

         [

             {

                "x":1.257747038963296E7,

                "y":377793.7702294255

             }

         ]

     }

]

HEAD 请求

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

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

请参见