• PostGIS之路——线性参考


    1、ST_Line_Interpolate_Point

          返回一个点内插入一条线。第一个参数必须是 一个LINESTRING类型几何对象,第二个参数是一个float8类型,在0和1之间代表总长度一部分的,这个点将被定位。

    geometryST_Line_Interpolate_Point(geometry a_linestring, float a_fraction);

    可参考:http://hi.baidu.com/zhwtteng/item/9a6fcb3f79fe12cb1a96966c

    示例SQL:

    SELECT ST_AsEWKT(ST_Line_Interpolate_Point(the_line, 0.5))
    FROM (SELECT ST_GeomFromEWKT('LINESTRING(1 2 3, 4 5 6, 6 7 8)') as the_line) As foo;

    SELECT ST_AsText(ST_Line_Interpolate_Point(foo.the_line, ST_Line_Locate_Point(foo.the_line, ST_GeomFromText('POINT(4 3)'))))
    FROM (SELECT ST_GeomFromText('LINESTRING(1 2, 4 5, 6 7)') As the_line) As foo;

    2、ST_Line_Locate_Point

          返回a_point离a_linestring在上最近的点位置(这个位置表示为一个0到1浮点数)。点具体的位置我们可以使用前面介绍的ST_Line_Interpolate_Point取出。

    floatST_Line_Locate_Point(geometry a_linestring, geometry a_point);

    示例SQL:

    SELECT ST_AsText(house_loc) As as_text_house_loc,startstreet_num +
    CAST( (endstreet_num - startstreet_num)*ST_Line_Locate_Point(street_line, house_loc) As integer) As street_num
    FROM (SELECT ST_GeomFromText('LINESTRING(1 2, 3 4)') As street_line,ST_MakePoint(x*1.01,y*1.03) As house_loc, 10 As startstreet_num,
    20 As endstreet_num FROM generate_series(1,3) x CROSS JOIN generate_series(2,4) As y)
    As foo WHERE ST_DWithin(street_line, house_loc, 0.2);

    3、ST_Line_Substring

           返回一个线对象,作为一个的子字符串输入开始和结束在二维总长度的分数。第二个和第三个参数是 0和1之间的浮点数。

    geometryST_Line_Substring(geometry a_linestring, float startfraction, float endfraction);

    示例SQL:

    SELECT ST_AsText(ST_Line_SubString(ST_GeomFromText('LINESTRING(25 50, 100 125, 150 190)'), 0.333, 0.666));

    4、ST_LocateAlong

         返回一个根据指定的测量值与元素相匹配的导出几何对象。不支持面元素。

    geometryST_LocateAlong(geometry ageom_with_measure, float a_measure, float offset);

    示例SQL:

    SELECT ST_AsText(the_geom) FROM (SELECT ST_LocateAlong(
    ST_GeomFromText('MULTILINESTRINGM((1 2 3, 3 4 2, 9 4 3),
    (1 2 3, 5 4 5))'),3) As the_geom) As foo;

    5、ST_LocateBetween (2.0.0版本叫 ST_Locate_Between_Measures)

           根据量测值获得几何对象.

    geometryST_LocateBetween(geometry geomA, float measure_start, float measure_end, float offset);

    示例SQL:

    SELECT ST_AsText(the_geom)
    FROM
    (SELECT ST_LocateBetween(
    ST_GeomFromText('MULTILINESTRING M ((1 2 3, 3 4 2, 9 4 3),
    (1 2 3, 5 4 5))'),1.5, 3) As the_geom) As foo;

     6、ST_LocateBetweenElevations

            根据量测值返回一个几何对象集合,这个只支持3D, 4D LINESTRINGS and MULTILINESTRINGS。

     geometryST_LocateBetweenElevations(geometry geom_mline, float elevation_start, float elevation_end);

    示例SQL:

    --Geometry collections are difficult animals so dump them
    --to make them more digestable
    SELECT ST_AsEWKT((ST_Dump(the_geom)).geom)
    FROM
    (SELECT ST_LocateBetweenElevations(
    ST_GeomFromEWKT('LINESTRING(1 2 6, 4 5 -1, 7 8 9)'),6,9)As the_geom) As foo

    7、ST_InterpolatePoint

           返回几何点闭合提供的点的测量维度值。

    floatST_InterpolatePoint(geometry line, geometry point);

    示例SQL:

    SELECT ST_InterpolatePoint('LINESTRING M (0 0 0, 10 0 20)', 'POINT(5 5)');

    8、ST_AddMeasure

          返回一个导出几何对象在开始和结束点之间线性内插一些元素。如果几何没有测量尺寸,添加一个。如果几何形状有一个测量维度,它超出写入一个新值。只支持LINESTRINGS 和 MULTILINESTRINGS。

    geometryST_AddMeasure(geometry geom_mline, float measure_start, float measure_end);

    示例SQL:
    SELECT ST_AsText(ST_AddMeasure(
    ST_GeomFromEWKT('MULTILINESTRINGM((1 0 4, 2 0 4, 4 0 4),(1 0 4, 2 0 4, 4 0 4))'),10,70)) As ewelev;

  • 相关阅读:
    linux下文件搜索命令学习笔记
    【转】C++格式化输出
    UNIX中的文件类型
    Unix内核中打开文件的表示
    网络编程学习笔记:linux下的socket编程
    TCP协议学习笔记(一)首部以及TCP的三次握手连接四次挥手断开
    C/C++源代码从写完到运行发生了什么
    C++ 函数形参发生动态绑定时指针增长步长与静态类型一致
    C++中为什么要将析构函数定义成虚函数
    C++求一个十进制的二进制中1的个数
  • 原文地址:https://www.cnblogs.com/LCGIS/p/2974278.html
Copyright © 2020-2023  润新知