python中line.split_python-匀称:沿边缘的任意点分割LineString

事实证明,我正在寻找的答案在documentation中概述为cut方法:

def cut(line, distance):

# Cuts a line in two at a distance from its starting point

if distance <= 0.0 or distance >= line.length:

return [LineString(line)]

coords = list(line.coords)

for i, p in enumerate(coords):

pd = line.project(Point(p))

if pd == distance:

return [

LineString(coords[:i+1]),

LineString(coords[i:])]

if pd > distance:

cp = line.interpolate(distance)

return [

LineString(coords[:i] + [(cp.x, cp.y)]),

LineString([(cp.x, cp.y)] + coords[i:])]

现在,我可以使用投影距离剪切LineString:

...

d = line.project(point)

# print(d) 3.6039927920216237

cut(line, d)

# LINESTRING (0 0, 1.910112359550562 3.056179775280899)

# LINESTRING (1.910112359550562 3.056179775280899, 5 8)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常抱歉给你带来困扰,我之前的回答有一个错误。在 Shapely 库,`translate` 函数的第一个参数应该是几何对象,而不是坐标。因此,在使用 `translate` 函数之前,我们需要将起始和结束转换为 Point 对象。 以下是修正后的示例代码: ```python from shapely.geometry import Polygon, LineString, Point from shapely.ops import unary_union from shapely.affinity import translate def extend_polygon_edges(polygon, length): # 获取多边形的边界线 boundary = polygon.boundary # 初始化新的多边形 new_polygon = Polygon() # 处理每条边界线 for line in boundary: # 计算线段的单位向量 dx = line.coords[1][0] - line.coords[0][0] dy = line.coords[1][1] - line.coords[0][1] length_normalized = length / (dx**2 + dy**2)**0.5 dx_normalized = dx * length_normalized dy_normalized = dy * length_normalized # 创建新的起始和结束 start_point = translate(Point(line.coords[0]), dx_normalized, dy_normalized) end_point = translate(Point(line.coords[1]), -dx_normalized, -dy_normalized) # 将新的起始、边界线、结束依次添加到新的多边形 new_polygon = unary_union([new_polygon, LineString([start_point, line, end_point])]) return new_polygon # 创建一个不规则形状的多边形示例 polygon = Polygon([(0, 0), (1, 1), (2, 0), (1, -1)]) # 扩展多边形的边界线 extended_polygon = extend_polygon_edges(polygon, 5) # 打印扩展后的多边形的顶坐标 for vertex in extended_polygon.exterior.coords: print(vertex) ``` 这段代码会将起始和结束转换为 Point 对象,并使用 `translate` 函数对它们进行平移。然后,我们将新的起始、边界线和结束依次添加到新的多边形,并打印扩展后的多边形的顶坐标。 再次对之前的错误表示歉意,希望这个修正能够帮到你。如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值