明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1590|回复: 3

[求助]vlisp中,怎么给Group对象的AppendItems方法赋值

[复制链接]
发表于 2010-4-28 12:12:00 | 显示全部楼层 |阅读模式

源代码如下

(vl-load-com)
(setq *AcadDoc* (vla-get-ActiveDocument (vlax-get-Acad-Object)))
(setq *ModelSpace* (vla-get-ModelSpace *AcadDoc*))
(setq *PaperSpace* (vla-get-PaperSpace *AcadDoc*))
(setq *Groups* (vla-get-Groups *AcadDoc*))
(defun C:MakeGroup()
      (setq cirobj (vla-addCircle *ModelSpace* (vlax-3d-point '(3.0 3.0 0.0)) 2.0))
      (setq txtobj (vla-addText *MOdelSpace* (vlax-3d-point '(3.0 3.0 0.0)) "Test" 10))
      (setq objlist (list cirobj txtnoobj))
      (setq objgroup (vla-add *Groups* "Test01"))
      (setq objarray (vlax-make-safearray vlax-vbVariant '(0 . 1)))
      (vlax-safearray-fill objarray objlist)
      (vla-appenditems objgroup objarray)
)

执行后总是提示

; 错误: Automation 错误。 对象数组无效

请教高手,问题出在哪里?先谢了

发表于 2010-4-28 12:44:00 | 显示全部楼层
(vl-load-com)
(setq *AcadDoc* (vla-get-ActiveDocument (vlax-get-Acad-Object)))
(setq *ModelSpace* (vla-get-ModelSpace *AcadDoc*))
(setq *PaperSpace* (vla-get-PaperSpace *AcadDoc*))
(setq *Groups* (vla-get-Groups *AcadDoc*))
(defun C:MakeGroup()
      (setq cirobj (vla-addCircle *ModelSpace* (vlax-3d-point '(3.0 3.0 0.0)) 2.0))
      (setq txtobj (vla-addText *MOdelSpace*  "Test" (vlax-3d-point '(3.0 3.0 0.0)) 10))
      (setq objlist (list cirobj txtobj))
      (setq objgroup (vla-add *Groups* "Test01"))
      (setq objarray (vlax-make-safearray vlax-vbobject '(0 . 1)))
      (vlax-safearray-fill objarray objlist)
      (vla-appenditems objgroup objarray)
)
 楼主| 发表于 2010-4-28 12:50:00 | 显示全部楼层

谢谢高手,解决了,第三行是关键,前面两行是笔误,我从大段代码中提取出来的时候有的地方没修改好,总之解决了,太感谢了

 楼主| 发表于 2010-4-28 13:02:00 | 显示全部楼层

根据sailorcwx大大的提示,修改了以后,给出个列表转化为对象数组的函数,希望能有用

(defun Ut:list->Obj-Array (ptsList / arraySpace sArray)
     ; 给对象数组分配空间
  (setq arraySpace
  (vlax-make-safearray
    vlax-vbObject  ; 元素类型
    (cons 0
   (1- (length ptsList))
    )    ; 数组维数
  )
  )
  (setq sArray (vlax-safearray-fill arraySpace ptsList))
     ; 返回对象数组)
)

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

本版积分规则

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

GMT+8, 2024-10-2 01:28 , Processed in 0.183971 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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