wuyunpeng888
发表于 2018-12-4 16:05:31
jikasurvey 发表于 2018-7-6 22:12
你这个方法还是有个缺陷,如果发完命令(sssetfirst nil (ssget ""))后,程序并不马上退出,后面还有与CAD ...
后面的操作无非就是转为手动,或用当前pick选择集,这种应用一般都是最后一步,中间的很少有用到这功能的
wuyunpeng888
发表于 2019-1-12 10:27:45
我这也有一版
下面是lisp函数,放在窗体上的文本框里,VL类初始化时加载
(defun VBASelectionSet2ALSelectionSet(VBA_SSName / obj ss sss AL_SS) ;命名选择集转换成aut
(setq sss (vlax-get-property (vlax-get-property (vlax-get-acad-object) 'ActiveDocument) 'SelectionSets))
(setq ss (vlax-invoke-method sss 'Item VBA_SSName))
(setq AL_SS(ssadd))
(vlax-for obj ss
(ssadd (vlax-vla-object->ename obj) AL_SS)
)
)
加载代码如下
'加载选择集转换函数
strFileName = Environ("TEMP") & "\SelectionSet.lsp"
Open strFileName For Output As #5
Print #5, Form1.txtSelectionSet.Text
Close #5
VLFS.Item("Load").funcall strFileName
Kill strFileName
VBA实现函数如下
'命名选择集显示夹点并选中
Public Sub ShowPickPoints(ByVal selectionSet As Object, ByVal blnOpen As Boolean)
If blnOpen = True Then
vlax.SetLispSymbol "ShowPickPoints_sset", selectionSet.Name
vlax.EvalLispExpression "(sssetfirst nil (VBASelectionSet2ALSelectionSet ShowPickPoints_sset))"
vlax.NullifySymbol "ShowPickPoints_sset"
Else
vlax.EvalLispExpression "(sssetfirst nil)"
End If
End Sub
wuyunpeng888
发表于 2019-1-12 10:30:12
ShowPickPoints函数的第一个参数是VBA的选择集对象,第二个参数为Ture为显示夹点,False为关闭夹点
wuyunpeng888
发表于 2019-1-12 10:31:31
我已经开始着手做VBA扩展库了,准备把lisp有的VBA里没有的都在VBA的扩展库里实现
wuyunpeng888
发表于 2019-1-12 10:33:36
初步分类为曲线类、事件类、数学类、实用工具类,这几大块
wuyunpeng888
发表于 2019-1-12 10:40:08
attach://102869.png
目前这些都是和lisp里的那几个vlax曲线功能相对应的
jikasurvey
发表于 2019-4-28 13:14:39
wuyunpeng888 发表于 2019-1-12 10:40
attach://102869.png
目前这些都是和lisp里的那几个vlax曲线功能相对应的
希望你早日成功!
zzyong00
发表于 2019-4-28 15:54:28
VL自从R16以后就没有更新过,所以,最好不用
wuyunpeng888
发表于 2019-8-19 11:10:15
这个不需要什么更新吧,本身没什么功能,能解析lisp函数就好,更新也更新不出什么东西
wuyunpeng888
发表于 2021-7-10 12:42:26
这个使用之前要先(vl-load-com)这是前提