乐筑天下

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

框选后只有两条线有变化 其他没变化 附代码 求解

[复制链接]

1

主题

1

帖子

1

银币

初来乍到

Rank: 1

铜币
5
发表于 2013-3-24 18:46:00 | 显示全部楼层 |阅读模式
功能  闭合多段线的顶点 转移到 西北角 。。。   
  X-Y 最小值  判定为西北角   
问题: 框选多条线后 只有两条起点坐标 放置到西北角其他无变化  
  求解  ::::   代码如下 (新手  代码很乱)
Sub Gpl()
Dim seer As AcadSelectionSet
Dim seername As String
seername = "seerre"
Dim var As Variant
Dim pp(1) As Double
Dim cc As Double
Dim pl As AcadLWPolyline
Dim coor() As Double
Dim Dx As Double
Dim DY As Double
Dim Bl As Boolean
Bl = False
Set seer = ThisDrawing.SelectionSets.Add(seername)
Dim f(0) As Integer
Dim d(0) As Variant
f(0) = 0
d(0) = "LWPOLYLINE"
seer.SelectOnScreen f, d
' pp = ThisDrawing.Utility.GetPoint
For Each pl In seer
var = pl.Coordinates
i = UBound(var)
ReDim coor(i) As Double
'-------------------------------------------------
'为PP 附值
For we = 0 To i - 2 Step 2
If Bl = False Then
Bl = True
Dx = var(we)
DY = var(we + 1)
Else
cc = var(we) - var(we + 1)
If Dx - DY > cc Then
Dx = var(we)
DY = var(we + 1)
End If
End If
Next
pp(0) = Dx
pp(1) = DY
'--------------------------------------------------
'判断下标
For j = 0 To i - 1
If var(j) = pp(0) And var(j + 1) = pp(1) Then
k = j
'MsgBox k
Exit For
End If
Next
For e = 0 To i - k
coor(e) = var(k + e)
Next
For r = 0 To k - 1
coor(i - k + r + 1) = var(r)
Next
pl.Coordinates = coor
pl.color = acBlue
Next
seer.Delete
End Sub
功能  闭合多段线的顶点 转移到 西北角 。。。   
  X-Y 最小值  判定为西北角   
问题: 框选多条线后 只有两条起点坐标 放置到西北角其他无变化  
  求解  ::::   代码如上 (新手  代码很乱
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-6-29 17:24 , Processed in 0.843887 second(s), 54 queries .

© 2020-2025 乐筑天下

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