参数化对象 ================ 对象构造 ----------------- ELLIPTICALSTRING ~~~~~~~~~~~~~~~~ 参数化的椭圆弧对象,支持存储为 WKT 和 WKB 数据格式,支持Z、M属性。 此椭圆弧对象在参与空间计算时(如缓冲区计算、空间关系计算),需先通过ST_Curvetoline()函数,将参数化对象转换成普通的矢量线或面对象,再进行空间计算。 |1.png| **语法** .. code:: ELLIPTICALSTRING(xstart ystart,xend yend ,xcenter ycenter,minor,clockwise,rotation,axis,ratio) ------含Z属性的椭圆弧------ ELLIPTICALSTRINGZ(xstart ystart,xend yend ,xcenter ycenter,minor,clockwise,rotation,axis,ratio) ------含M属性的椭圆弧------ ELLIPTICALSTRINGM(xstart ystart,xend yend ,xcenter ycenter,minor,clockwise,rotation,axis,ratio) 参数: xstart,ystart - 椭圆弧起点坐标 xend,yend - 椭圆弧终点坐标 xcenter,ycenter - 椭圆弧中心点坐标 minor - 椭圆弧方向,值域为 0 或 1 clockwise - 保留参数,暂未使用 rotation - 椭圆弧旋转角度 axis - 长半轴长度 ratio - 短轴与长轴之比 注意: 椭圆的起始点和终止点必须要在椭圆上,否则会报错: ERROR: the parameters of the ellipse must be valid **示例** .. code:: SQL -----构造一个椭圆弧对象----- SELECT 'ELLIPTICALSTRING(-2 0,2 0,0 0,0,0,0,2,0.5)'::geometry; -----创建包含椭圆弧对象的表---- create table ellipsetest(id serial,geom geometry(ELLIPTICALSTRING,4326)); COMPOUNDCURVE ~~~~~~~~~~~~~ 含线、椭圆弧的复合线对象。 注意:COMPOUNDCURVE 中每个单元对象的几何必须连续。 **示例** .. code:: SQL -----构造一个含一条线、一条椭圆弧的复合线对象----- select ST_AsText(st_curvetoline('COMPOUNDCURVE((1 0,2 0),ELLIPTICALSTRING(2 0 ,4 0, 3 0 ,1,0,0,1,0.5))')); |2.png| CURVEPOLYGON ~~~~~~~~~~~~~ 含椭圆弧的面对象。 注意:CURVEPOLYGON 中的各个子对象必须是闭合的。 **示例** .. code:: SQL -----构造一个含一条线、一条椭圆弧的复合线对象----- select ST_AsText(st_curvetoline('COMPOUNDCURVE((1 0,2 0),ELLIPTICALSTRING(2 0 ,4 0, 3 0 ,1,0,0,1,0.5))')); |4.png| 转换函数 ---------- ST_AsText ~~~~~~~~~~ 将 geometry 类型转换为 text 文本类型。 **语法** .. code:: text ST_AsText(geometry geom); 参数: geom - 椭圆弧对象 返回: 返回空间对象几何的文本字符串。 **示例** .. code:: SQL select ST_AsText('ELLIPTICALSTRINGM (-2 0 0,2 0 0,0 0 0,0,0,0,2,0.5)'::geometry); -------------------------- ELLIPTICALSTRINGM(-2 0 0,2 0 0,0 0 0,0,0,0,2,0.5) ST_Curvetoline ~~~~~~~~~~~~~~~ 将椭圆弧对象转换为线对象。 **语法** .. code:: geometry ST_Curvetoline(geometry geom); 参数: geom - 椭圆弧对象 返回: 返回椭圆弧对象的 geometry。 **示例** .. code:: SQL select ST_Curvetoline('ELLIPTICALSTRING(-2 0,1.1602773 0.8145177,0 0,0,0,0,2,0.5)'); -------------------------- 0102000020E61000004000000000000000000000C0075C143326A6A13C4387327875FFFFBFBC07AA7B168A873FE128DAC918F7FFBF3583AAE032DDA73FD5FF6AB8A2E4FFBF96A165FD2AE8B43F22560F1919C8FFBF08A76F9021DBBD3F3D0AEFEF84A1FFBFE272BEAC5462C33F8C50566DF270FFBF130CC3C1F8D0C73FD1DDDBE97036FFBF6776188C1638CC3F04B287E112F2FEBF543595F8244BD03FB60BFCEDEDA3FEBF2AD1BFD31875D23F675CA2BF1A4CFEBF76112CD33799D43FB565DE15B5EAFDBFC73822CAD4B6D63F55F649B6DB7FFDBF085F499A44CDD83FE60BFC62B00BFDBF95B9B769DEDBDA3FE86BDECF578EFCBF0A814BD8FBE1DC3F91121597F907FCBF1B9A3B34F9DEDE3F51217B2CC078FBBFE9B2E7D61A69E03F114139D0D8E0FABF1FB116C5895DE13FF9B479807340FABF1F47982A7C4CE23F0FA23EEAC297F9BFE2681A89A635E33F1A565F59FCE6F8BFD87FE535BF18E43FBE9CB1A7572EF8BF7DAF22717EF5E43FB474642B0F6EF7BF2403877C9ECBE53F68B891A45FA6F6BF755B5CB1DB9AE63F9A8C0C2A88D7F5BF6825E195F462E73F80A57215CA01F5BF131AF8F1A923E83F8DAE86EE6825F4BF007E21E3BEDCE83FC65ADA55AA42F3BFB690B7EFF88DE93F5EDBCEEED559F2BF771868192037EA3FC7AFF248356BF1BF1434E5EEFED7EA3FE2F5C3C81377F0BFE0DBC79C6270EB3F1C24BD1F7DFBEEBF29BC9EFD1A00EC3F4B6B3BC908FFECBF6F5624A9FA86EC3FD9ED70326BF9EABFF69A9702D704ED3FDCAEC2E447EBE8BF707232468879ED3F987AE11A45D5E6BFCCF6B995E9E4ED3FEE11458C0BB8E4BF0F632404D946EE3F9626DE374694E2BF0D0C51A0379FEE3F42FF0F2EA26AE0BF16FFCE7EE9EDEE3FD7AA05B49C77DCBFF42FAFC2D532EF3F6966C094F610D8BFB46C5FA5E66DEF3F488E15F3B5A2D3BFE99B8B7D099FEF3F24368D55825CCEBFF71803C52EC6EF3FF04DB11A016AC5BF8C51A01D4AE3EF3FAEB1F5C077E1B8BF8017315552F6EF3F64501BA8439C9BBF286B5E6841FFEF3F2449D56E082BA63F13D3928414FEEF3FF218FCDA980EBD3F85A7DE08CCF2EF3FEF23C4A93F7FC73F9009DA856BDDEF3FB99D9B36E337D03F5B8F84BCF9BDEF3FC1C07BD606ABD43F8C00239C8094EF3F392283CDA217D93F8ECF1B3F0D61EF3FCF52D844517CDD3F7D4DD3E6AF23EF3F8C246B73D7EBE03F95E788F67BDCEE3F3C24A8A72D14E33F800D37ED878BEE3F3BDD73BD7C36E53F05B0775EED30EE3FC666A81A1852E73FD2966FEAC8CCED3F698131435566E93F1B1BC3343A5FED3F969AE90E8C72EB3F6C2297DA63E8EC3F8788BADE1676ED3F4782A1676B68EC3F4C35F1D05270EF3F00414C4A79DFEB3F65D859FA4FB0F03F5273EFC6B84DEB3FB9B344BE30A3F13FD5BF25EA57B3EA3F44C3F2F77E90F23FFAD93F7A8710EA3F 测量函数 ---------- ST_Area ~~~~~~~~~~ 计算椭圆弧对象的面积,区别于ST_AreaParam。 **语法** .. code:: float ST_Area(geometry geom); 参数: geom - 椭圆弧对象 返回: 返回椭圆弧对象的面积。 **示例** .. code:: SQL select ST_Area('COMPOUNDCURVE(ELLIPTICALSTRING(-1 0, -1 0, 0 0,1,0,0,1,0.5))'); -------------------------- 1.5707963267948966 ST_AreaParam ~~~~~~~~~~~~~~~ 计算椭圆弧对象的精确面积。 **语法** .. code:: float ST_AreaParam(geometry geom); 参数: geom - 椭圆弧对象 返回: 返回椭圆弧对象的精确面积。 **示例** .. code:: SQL select ST_AreaParam('CURVEPOLYGON(CIRCULARSTRING(-1 5, 1 5 ,-1 5))'); -------------------------- 3.141592653589793 ST_Length ~~~~~~~~~~ 计算椭圆弧对象的周长 **语法** .. code:: float ST_Length(geometry geom); 参数: geom - 椭圆弧对象 返回: 返回椭圆弧对象的周长。 **示例** .. code:: SQL select ST_Length('ELLIPTICALSTRING(0 0,0 0,2 0,0,1,0,2,0.5)'); -------------------------- 9.685374273494208 .. |1.png| image:: /../_static/images/ellipse/1.png .. |2.png| image:: /../_static/images/ellipse/2.png .. |3.png| image:: /../_static/images/ellipse/3.png .. |4.png| image:: /../_static/images/ellipse/4.png