BufferWithTolerance(geometry 数据类型)

返回表示所有点值的并集的几何对象,这些点到 geometry 实例的距离小于或等于指定值,允许存在指定的公差。

语法

.BufferWithTolerance (distance,tolerance,relative)

参数

  • distance
    一个指定到 geometry 实例的距离的 float 表达式,缓冲区就是环绕该实例而计算出的。

  • tolerance
    指定缓冲区距离的公差的 float 表达式。

    “公差”指的是理想的缓冲区距离与返回的线性近似段之间的最大偏差。

    例如,点的理想缓冲区距离为圆圈,但是这必须与多边形近似。公差越小,多边形具有的点就越多,这将增加结果的复杂度,但可减少错误。

  • relative
    一个 bit,指定 tolerance 值是相对值还是绝对值。如果为“TRUE”或 1,则公差为相对值并按 tolerance 参数与该实例的边界框的直径之间的乘积进行计算。如果为“FALSE”或 0,则公差为绝对值并且 tolerance 值为理想缓冲区距离与返回的线性近似段之间的绝对最大偏差。

返回类型

SQL Server 返回类型:geometry

CLR 返回类型:SqlGeometry

注释

负的缓冲区将删除 geometry 实例的给定距离的边界内的所有点。

理论缓冲区和计算出的缓冲区之间的误差是 max(tolerance, extents * 1.E-7),其中 tolerance 是 tolerance 参数的值。有关“区”的详细信息,请参阅geometry 数据类型方法引用

示例

下面的示例创建 Point 实例,并使用 BufferWithTolerance() 获取环绕该实例的大致缓冲区。

DECLARE @g geometry;
SET @g = geometry::STGeomFromText('POINT(3 3)', 0);
SELECT @g.BufferWithTolerance(1, .5, 0).ToString();