找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

楼主: 炫翔

[研讨] 视口的图层解冻的VLA方法

[复制链接]

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-10-7 12:20:47 来自手机 | 显示全部楼层
翔版主还没有整出来?

点评

惭愧,没有呢!本来是测试一实例用的, 花了几天时间研究,整的晕乎乎的, 打算放弃了!  详情 回复 发表于 2013-10-7 16:14
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1742个

财富等级: 堆金积玉

 楼主| 发表于 2013-10-7 16:14:30 | 显示全部楼层
st788796 发表于 2013-10-7 12:20
翔版主还没有整出来?

惭愧,没有呢!本来是测试一实例用的,
花了几天时间研究,整的晕乎乎的,
打算放弃了!

点评

不会吧, 半成品  详情 回复 发表于 2013-10-7 16:49
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2013-10-7 16:49:35 | 显示全部楼层
炫翔 发表于 2013-10-7 16:14
惭愧,没有呢!本来是测试一实例用的,
花了几天时间研究,整的晕乎乎的,
打算放弃了!

不会吧, 半成品
  1. (defun CopyForViewport (OldVp lyrlst / properties pSp nVp xd xt)
  2.   ;|(defun Position (index lst / i l)
  3.     (setq i 0)
  4.     (foreach x lst
  5.       (if (= x index)
  6.     (setq l (cons i l))
  7.       )
  8.       (setq i (1+ i))
  9.     )
  10.     (reverse l)
  11.   )|;   
  12.   (setq    properties
  13.      '("Center"          "CustomScale"     "Direction"
  14.        "DisplayLocked"    "EntityTransparency"
  15.        "Height"          "GridOn"         "Layer"
  16.        "LensLength"          "Linetype"     "LinetypeScale"
  17.        "Lineweight"          "Material"     "PlotStyleName"
  18.        "SnapBasePoint"    "SnapOn"         "SnapRotationAngle"
  19.        "StandardScale"    "StandardScale2"     "Target"
  20.        "TrueColor"          "TwistAngle"     "UCSIconAtOrigin"
  21.        "UCSIconOn"          "Visible"         "VisualStyle"
  22.        "Width"
  23.       )
  24.   )
  25.   (mapcar '(lambda (x)
  26.          (set (read x) (vlax-get-property oldvp x))
  27.        )
  28.       properties
  29.   )
  30.   (setq    pSp (vla-get-PaperSpace
  31.           (vla-get-ActiveDocument
  32.         (vlax-get-acad-object)
  33.           )
  34.         )
  35.     nVp (vla-AddPViewport
  36.           pSp
  37.           center
  38.           width
  39.           height
  40.         )
  41.   )
  42.   (vla-getxdata oldvp "ACAD" 'xt 'xd)
  43.   (mapcar '(lambda (x)
  44.          (vl-catch-all-apply
  45.            'vlax-put-property
  46.            (list nVp x (eval (read x)))
  47.          )
  48.        )
  49.       properties
  50.   )
  51.   ;|(mapcar '(lambda (x) (set (read x) nil)) properties)
  52.   (setq    xt (safearray-value xt)
  53.     xd (safearray-value xd)
  54.     i (vl-position 1003 xt)
  55.   )
  56.   (mapcar '(lambda (x y)
  57.          (cons x (variant-value y))
  58.        )
  59.       xt
  60.       xd
  61.   )|;
  62.   (vla-setxdata nVp xt xd)
  63.   
  64.   (vla-display nVp :vlax-false)
  65.   (vla-display nVp :vlax-true)
  66.   nVp
  67. )


评分

参与人数 1D豆 +5 收起 理由
炫翔 + 5 技术引导讨论和指点奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2013-10-8 08:03:36 | 显示全部楼层
把上面的函数完善了, 翔版测试下, 这样解冻尚未考虑视口的图层替代、视口裁减,仅作为 Lisp 应用探讨
  1. ;;Author: eachy From www.xdcad.net 2013.10.8
  2. (defun Vp:GetFrzLayer (VpObj / xt xd lyrlst)
  3.   (vla-getxdata VpObj "ACAD" 'xt 'xd)
  4.   (mapcar '(lambda (a b)
  5.              (if (= a 1003)
  6.                (setq lyrlst (cons (variant-value y) lyrlst))
  7.              )
  8.            )
  9.           (safearray-value xt)
  10.           (safearray-value xd)
  11.   )
  12.   lyrlst
  13. )
  14. (defun Vp:FrzLayer (VpObj lyrlst / xt xd flyr)
  15.   (vla-getxdata VpObj "ACAD" 'xt 'xd)
  16.   (setq        flyr (mapcar '(lambda (lyr)
  17.                         (list (vlax-make-variant
  18.                                 1003
  19.                                 vlax-vbinteger
  20.                               )
  21.                               (vlax-make-variant lyr vlax-vbString)
  22.                         )
  23.                       )
  24.                      lyrlst
  25.              )
  26.         xt   (reverse (safearray-value xt))
  27.         xd   (reverse (safearray-value xd))
  28.   )
  29.   (vla-setxdata
  30.     VpObj
  31.     "ACAD"
  32.     (vlax-make-variant
  33.       (reverse (append (list (car xt) (cadr xt))
  34.                        (mapcar 'car flyr)
  35.                        (list (cdddr xt))
  36.                )
  37.       )
  38.     )
  39.     (vlax-make-variant
  40.       (reverse (append (list (car xd)
  41.                              (cadr xd)
  42.                              (mapcar 'cadr flyr)
  43.                              (list (cdddr xd))
  44.                        )
  45.                )
  46.       )
  47.     )
  48.   )
  49. )
  50. (defun Vp:ThwLayer (VpObj lyrlst / properties pSp nVp oldFrzlyr)
  51.   (setq        properties
  52.          '("Center"              "CustomScale"         "Direction"
  53.            "DisplayLocked"    "EntityTransparency"
  54.            "Height"              "GridOn"                 "Layer"
  55.            "LensLength"              "Linetype"         "LinetypeScale"
  56.            "Lineweight"              "Material"         "PlotStyleName"
  57.            "SnapBasePoint"    "SnapOn"                 "SnapRotationAngle"
  58.            "StandardScale"    "StandardScale2"         "Target"
  59.            "TrueColor"              "TwistAngle"         "UCSIconAtOrigin"
  60.            "UCSIconOn"              "Visible"                 "VisualStyle"
  61.            "Width"
  62.           )
  63.   )
  64.   (mapcar '(lambda (x)
  65.              (set (read x) (vlax-get-property oldvp x))
  66.            )
  67.           properties
  68.   )
  69.   (setq        pSp (vla-get-PaperSpace
  70.               (vla-get-ActiveDocument
  71.                 (vlax-get-acad-object)
  72.               )
  73.             )
  74.         nVp (vla-AddPViewport
  75.               pSp
  76.               center
  77.               width
  78.               height
  79.             )
  80.   )
  81.   (setq oldFrzlyr (Vp:GetFrzlayer VpObj))
  82.   (mapcar '(lambda (x) (vl-remove x oldFrzlyr)) lyrlst)
  83.   (mapcar '(lambda (x)
  84.              (vl-catch-all-apply
  85.                'vlax-put-property
  86.                (list nVp x (eval (read x)))
  87.              )
  88.            )
  89.           properties
  90.   )
  91.   (if oldFrzlyr
  92.     (Vp:Frzlayer nVp oldFrzlyr)
  93.   )
  94.   (vla-display nVp :vlax-false)
  95.   (vla-display nVp :vlax-true)
  96.   ;;nVp
  97. )

评分

参与人数 2D豆 +10 贡献 +2 收起 理由
xshrimp + 5 + 1 很给力!经验;技术要点;资料分享奖!
炫翔 + 5 + 1 技术引导讨论和指点奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-10-8 13:02:41 来自手机 | 显示全部楼层
本帖最后由 st788796 于 2013-10-8 13:13 编辑

测试有问题,setxdata 参数是 safearray 不是 variant,不能用vlax-make-variant
(vlax-safearray-fill (vlax-make-safearry vlax-vbinteger (cons 0 (1- (length xt)))) xt)
(vlax-safearray-fill (vlax-make-safearray vlax-vbvariant (cons 0 (1- (length xd)))) xd)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 182个

财富等级: 日进斗金

发表于 2013-10-29 11:58:03 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-25 04:40 , Processed in 0.361694 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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