乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 135|回复: 0

[编程交流] 两点断裂

[复制链接]

14

主题

42

帖子

28

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
70
发表于 2022-7-6 22:37:03 | 显示全部楼层 |阅读模式
大家好!又是我,
 
所以,我们一直在做一些杂耍,我遇到了将一条多段线分成三位的问题,让中间的一个存在,删除另外两个。这是通过选择两个点来实现的,不需要在pline上。现在,我已经编程一段时间了,显然它被卡住了,因为下面的代码用于从两个选定点之一计算到多段线线段的最近点,并计算最近点和选定点之间的距离。
 
我需要一些其他编程也这一部分,所以我会非常感谢!
 
retCoord=aPoly。坐标u=UBound(retCoord)'取决于最近点,计算i=0到u-2步骤2 k=(retCoord(i+3)-retCoord(i+1))/(retCoord(i+2)-retCoord(i))的断点1和2,如果k=-1,则x0=(B0(0)-retCoord(i))/2 y0=x0-retCoord(i)x1=(B1(0)-retCoord(i))/2 y1=x1-retCoord(i)ElseIf k=0,则x0=B0(0)y0=0 x1=B1(2)y1=0否则x0=(k*retCoord(i)-retCoord(i+1)+B0(0)/k+B0(1))/(1/k+1)y0=-x0/k+B0(0)/k+B0(1)x1=(k*retCoord(i)-retCoord(i+1)+B1(0)/k+B1(1))/(1/k+1)y1=-x1/k+B1(0)/k+B1(1)End如果x0=(retCoord(i+2)),则Dist0=Sqr((B0(0)-x0)^2)+(B0(0)-y0)^2))ElseIf x0>Abs(retCoord(i))和x0<(retCoord(i+2)),则Dist0=Sqr((B0(0)-x0)^2)+(B0(0)-y0)^2))End如果x1=(retCoord(i+2))然后Dist1=Sqr(((B1(0)-x1)^2)+((B1(0)-y1)^2))ElseIf x1>Abs(retCoord(i))和x1<(retCoord(i+2)),然后Dist1=Sqr((B1(0)-x1)^2)+((B1(0)-y1)^2))结束If(Dist0)
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-4 05:33 , Processed in 1.033220 second(s), 65 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表