田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 3 48
     12
3456789
10111213141516
17181920212223
24252627282930
31


站点统计

最新评论



圆形区域覆盖 Position and Size the Document Window (.NET)
未知 单行文字转多行文字带背景遮罩   [ 日期:2018-12-05 ]   [ 来自:本站原创 ]  HTML
http://bbs.xdcad.net/thread-643906-1-1.html

-----------------------------程序代码--------------------------------------------

;这个lisp程序的作用是,将单行文本转换为多行文本,为多行文本设置背景遮罩
;背景遮罩边界偏移因子为1.1,使用图形背景颜色填充。
;s1选择集名称,i m n 计数器,addlist增加的组码
;entname 图元名,nlist 图元数据,tid 图元标志(若为TEXT则表示为单行文本),tt 文本,th文本高度
;pt 文本基点,tang 文本旋转角度,ttlen 文本大致长度,tstr 相对坐标形式的多行文本的另一点


(defun c:bg()
     ;首先要对图形进行一些设置,否则将会影响程序的使用。在程序结束前将会恢复这些设置!
  (setq sysosnap (getvar "OSMODE")) ;取得对象捕捉设置
  (setvar "OSMODE" 16384)  ;关闭对象捕捉
  (setq sysang (getvar "ANGDIR")) ;取得角度方向(顺时针/逆时针)
  (setvar "ANGDIR" 0)   ;设置为逆时针方向
  (setq sysabase (getvar "ANGBASE")) ;取得方向的基准角度
  (setvar "ANGBASE" 0)   ;设置方向的基准角度为东
  (command "ucs" "")   ;设置为wcs
  

  (setq s1 (ssget))    ;选取单行文本或多行文本,构造非空选择集
  (if (/= s1 nil) (print)    ;构造选择集成功,继续
      (progn      ;构造失败,恢复设置退出
          (setvar "OSMODE" sysosnap)  ;恢复对象捕捉设置
          (setvar "ANGDIR" sysang)  ;恢复角度方向
          (setvar "ANGBASE" sysabase)  ;恢复方向的基准角度
          (command "ucs" "p")   ;恢复ucs
          (exit)    ;退出
       )
   )


  (setq i 0 m 0 n 0)    ;设置计数器,m为转换单行文本个数,n为多行文本个数
  (repeat (sslength s1)
     (setq entname (ssname s1 i))
     (setq nlist (entget entname))
     (setq tid (cdr (assoc 0 nlist)))  ;判断是单行文本或多行文本
     (if (= tid "TEXT")     ;如果是单行文本,先转换为多行文本
         (progn
             (setq m (1+ m))    ;计数器
             (setq tt (cdr (assoc 1 nlist)))  ;取得文字
             (setq th (cdr (assoc 40 nlist)))  ;取得文字高度
             (setq pt (cdr (assoc 10 nlist)))  ;取得文字插入点
             (setq ang (cdr (assoc 50 nlist)))  ;取得文字旋转角度
             (setq ttlen (strlen tt))   ;取得文字长度
             (setq twid (* (* th 0.7) ttlen))  ;计算文字宽度,不同字体、CAD版本、图形,文字高度与宽度关系可能不同,可直接修改系数0.7为适当值
             (setq tang (/ (* 180 (+ ang (atan(/ th twid)))) pi)) ;计算多行文本对角点的旋转角度
             (setq tlen (sqrt (+ (* th  th) (* twid twid))))  ;计算多行文本对角线的长度
             (setq tstr (strcat "@" (rtos tlen) "<" (rtos tang))) ;对角点的相对坐标
             (setq ang (/ (* ang 180) pi))    ;转换弧度为角度
             (command "-mtext" pt "h" th "r" ang tstr tt "")  ;在原位置以原角度原高度生成多行文本
             (entdel entname)      ;删除单行文本

             (setq entname (entlast))   ;取出最近转换成的多行文本
             (setq nlist (entget entname))
             (setq addlist (list(cons 45 1.1)))  ;背景遮罩边界偏移因子为1.1
             (setq addlist (cons (cons 63 256) addlist));填充颜色使用图形背景颜色
             (setq addlist (cons (cons 90 3) addlist)) ;表示使用背景颜色,另外组码441为背景的透明度,目前版本无法使用,系统会自动增加该组码
             (if (= (assoc 45 nlist) nil)   ;如果多行文本未使用背景遮罩,增加组码
                 (progn
                    (setq nlist (append nlist addlist)) ;增加上面3个组码
                    (entmod nlist)   ;更新显示
                 )
                 (progn     ;如果已使用背景遮罩,直接更改组码
                    (setq nlist (subst (cons 45 1.1) (assoc 45 nlist) nlist)) ;作用同上
                    (setq nlist (subst (cons 63 256) (assoc 63 nlist) nlist))
                    (setq nlist (subst (cons 90 3) (assoc 90 nlist) nlist))
                    (entmod nlist)
                 )
             )
          )
          (progn
              (if (= tid "MTEXT")      ;如果是多行文本
                  (progn
                       (setq n (1+ n))     ;计数器
                       (setq addlist (list(cons 45 1.1)))  ;背景遮罩边界偏移因子为1.1
                       (setq addlist (cons (cons 63 256) addlist)) ;填充颜色使用图形背景颜色
                       (setq addlist (cons (cons 90 3) addlist)) ;表示使用背景颜色,另外组码441为背景的透明度,目前版本无法使用,系统会自动增加该组码
                       (if (= (assoc 45 nlist) nil)    ;如果多行文本未使用背景遮罩,增加组码
                           (progn
                               (setq nlist (append nlist addlist)) ;增加上面3个组码
                               (entmod nlist)    ;更新显示
                           )
                           (progn     ;如果已使用背景遮罩,直接更改组码
                              (setq nlist (subst (cons 45 1.1) (assoc 45 nlist) nlist)) ;作用同上
                              (setq nlist (subst (cons 63 256) (assoc 63 nlist) nlist))
                              (setq nlist (subst (cons 90 3) (assoc 90 nlist) nlist))
                              (entmod nlist)
                           )
                       )
                  )
              )
          )
      )
      (setq i (1+ i))  
   )


  (setvar "OSMODE" sysosnap)  ;恢复对象捕捉设置
  (setvar "ANGDIR" sysang)  ;恢复角度方向
  (setvar "ANGBASE" sysabase)  ;恢复方向的基准角度
  (command "ucs" "p")   ;恢复ucs
  (prompt (strcat "转换单行文本" (itoa m) "个,多行文本" (itoa n) "个。请验证是否正确!")) 

)




暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:2*2=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©