明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4517|回复: 20

有没有让属性块的属性文字“复位”的lsp

  [复制链接]
发表于 2011-5-14 15:36:23 | 显示全部楼层 |阅读模式
如图所求,求lsp,将属性块的“属性文字”归位。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2024-5-22 10:40:21 | 显示全部楼层
啵浪鼓 发表于 2011-7-10 22:10
回复 Gu_xl 的帖子

命令: (gxl-blk-att2init (car(entsel "\n选择图块")))

这种情况→说明有镜像了的!如果是高程块→那么就复制一个初始属性块→粘贴进去→更新高程属性值→再删除旧属性块就搞定了
发表于 2024-5-13 09:35:39 | 显示全部楼层
Gu_xl 发表于 2011-7-10 15:24
回复 jfxia 的帖子

GXL-CATCHAPPLY 函数三楼已补上了!

属性文字“复位”的lsp哪里可以获取?
发表于 2017-12-20 23:14:11 | 显示全部楼层
错误: 函数错误: nil

求助,我也是这样改不了
发表于 2011-5-14 23:55:37 | 显示全部楼层

null

这个功能有点像CASS里的重生成
发表于 2011-5-16 09:52:45 | 显示全部楼层
本帖最后由 Gu_xl 于 2011-7-10 15:21 编辑

回复 pxt2001 的帖子


  1. ;;;(gxl-blk-att2init ent) 图块属性还原归位
  2. ;测试 (gxl-blk-att2init (car(entsel "\n选择图块")))
  3. (defun gxl-blk-att2init (ent /     obj   inspt
  4.         Ownerobj    atts   objs
  5.         attinspt    rot   xscale
  6.         yscale    zscale  Alignment
  7.         Backward    ObliqueAngle  Rotation
  8.         TextAlignmentPoint
  9.         TextGenerationFlag   UpsideDown
  10.         TrueColor
  11.        )
  12.   (if (= 'ename (type ent))
  13.     (setq obj (vlax-ename->vla-object ent))
  14.     (setq obj ent)
  15.     )
  16.   (setq Ownerobj (vla-Item (vla-get-blocks (vla-get-ActiveDocument(vlax-get-acad-object))) (vla-get-name obj)))
  17.   (vlax-for a Ownerobj
  18.     (setq objs (cons a objs))
  19.     )
  20.   (setq objs (reverse objs))
  21.   (setq rot (vla-get-Rotation obj)
  22. xscale (vla-get-XScaleFactor obj)
  23. yscale (vla-get-yScaleFactor obj)
  24. zscale (vla-get-zScaleFactor obj)
  25. )
  26.   (vla-put-Rotation obj 0)
  27.   (vla-put-XScaleFactor obj 1)
  28.   (vla-put-yScaleFactor obj 1)
  29.   (vla-put-zScaleFactor obj 1)
  30.   (setq atts (vla-GetAttributes obj)
  31. atts (safearray-value(vlax-variant-value atts))
  32. inspt (vlax-safearray->list(vlax-variant-value (vla-get-InsertionPoint obj)))
  33. )
  34.   (if atts
  35.     (progn
  36.       (foreach att atts
  37. (vl-some '(lambda (x) (= (GXL-CATCHAPPLY vla-get-TagString (list (setq Ownerobj x))) (vla-get-TagString att)))  objs)
  38. (setq attinspt (vlax-safearray->list (vlax-variant-value(vla-get-InsertionPoint Ownerobj))))
  39. (setq Alignment (vla-get-Alignment Ownerobj)
  40.        Backward (vla-get-Backward Ownerobj)
  41.        ObliqueAngle (vla-get-ObliqueAngle Ownerobj)
  42.        Rotation (vla-get-Rotation Ownerobj)
  43.        TextAlignmentPoint (vla-get-TextAlignmentPoint Ownerobj)
  44.        TextGenerationFlag (vla-get-TextGenerationFlag Ownerobj)
  45.        UpsideDown(vla-get-UpsideDown Ownerobj)
  46.        TrueColor (vla-get-TrueColor Ownerobj)
  47.        )

  48.       (vla-put-Alignment att Alignment)
  49.       (vla-put-Backward att Backward)
  50.       (vla-put-ObliqueAngle att ObliqueAngle)
  51.       (vla-put-Rotation att Rotation)
  52.       (VL-CATCH-ALL-APPLY 'vla-put-TextGenerationFlag (list att TextGenerationFlag))
  53.       (vla-put-Alignment att Alignment)
  54.       (vla-put-UpsideDown att UpsideDown)
  55.       (vla-put-TrueColor att TrueColor)
  56.       (VL-CATCH-ALL-APPLY ‘vla-put-TextAlignmentPoint (list att (vlax-3d-point (mapcar '+ inspt (vlax-safearray->list (vlax-variant-value TextAlignmentPoint))))))
  57.       )
  58.       (vla-put-Rotation obj rot)
  59.       (vla-put-XScaleFactor obj XScale)
  60.       (vla-put-yScaleFactor obj yScale)
  61.       (vla-put-zScaleFactor obj zScale)
  62.       )
  63.     )
  64.   )
  65. (defun gxl-CatchApply (fun args / rtn )
  66.   (if
  67.     (not
  68.       (vl-catch-all-error-p
  69.         (setq rtn
  70.           (vl-catch-all-apply (function fun) args)
  71.         )
  72.       )
  73.     )
  74.     rtn
  75.   )
  76. )
  77. ;;;属性复位 编制 Gu_xl 2011.05.15
  78. (defun c:initatt ()
  79.   (while (setq ss (ssget '((0 . "insert"))))
  80.     (setq n (sslength ss))
  81.     (repeat n
  82.       (gxl-blk-att2init (ssname ss (setq n (1- n))))
  83.       )
  84.     )
  85.   (princ)
  86.   )


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2011-5-16 21:09:21 | 显示全部楼层
不错,CAD自带的也有的,在修改2里,同部属性块
发表于 2011-7-8 16:35:07 | 显示全部楼层
回复 Gu_xl 的帖子

缺少函数 GXL-CATCHAPPLY
发表于 2011-7-8 18:51:23 | 显示全部楼层
CAD本身命令 battman
发表于 2011-7-9 10:40:53 | 显示全部楼层
battman修改全部的,不是很方便
发表于 2011-7-10 00:23:42 | 显示全部楼层
看看不能用啊!!
发表于 2011-7-10 11:17:58 | 显示全部楼层
留个脚印,等GXL-CATCHAPPLY
发表于 2011-7-10 15:02:55 | 显示全部楼层
chshsl 发表于 2011-5-16 21:09
不错,CAD自带的也有的,在修改2里,同部属性块

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

本版积分规则

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

GMT+8, 2024-11-25 17:43 , Processed in 0.162749 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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