明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1620|回复: 0

[函数]

[复制链接]
发表于 2006-9-13 11:34:00 | 显示全部楼层 |阅读模式

作了一个改多线段方向的函数,请高手指正:

Public Sub qq()
Dim pt() As Double
Dim a As Double
Dim obj As AcadLWPolyline
Dim objj As AcadLWPolyline

On Error Resume Next
Dim sset As AcadSelectionSet
If Not IsNull(ThisDrawing.SelectionSets.Item("example")) Then
Set sset = ThisDrawing.SelectionSets.Item("example")
sset.Delete
End If

Set sset = ThisDrawing.SelectionSets.Add("example")
sset.SelectOnScreen
Dim element As AcadEntity

For Each element In sset

Set obj = sset.Item(0)

Next

pt = obj.Coordinates

For i = 0 To (UBound(pt) - 1) / 2
a = pt(i)
pt(i) = pt(UBound(pt) - i)
pt(UBound(pt) - i) = a
Next

For i = 1 To UBound(pt) Step 2
a = pt(i)
pt(i) = pt(i - 1)
pt(i - 1) = a
Next

Set objj = ThisDrawing.ModelSpace.AddLightWeightPolyline(pt)
If obj.Closed = True Then
objj.Closed = True
End If
objj.Linetype = obj.Linetype
objj.LinetypeGeneration = obj.LinetypeGeneration
objj.LinetypeScale = obj.LinetypeScale
objj.Lineweight = obj.Lineweight
objj.TrueColor = obj.TrueColor
objj.Layer = obj.Layer
obj.Delete
End Sub

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-26 22:28 , Processed in 0.166248 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表