明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: vocabulary

[求助]文字分解的问题?

  [复制链接]
发表于 2009-4-10 11:08:00 | 显示全部楼层
(defun c:xt (/ bz ss n lvs lss lvp lvl lul ent luu)
(prompt "\n文字分解")
(while (setq ss (ssget ":S" '((0 . "*text"))))
(setvar "cmdecho" 0) (command "undo" "be") (setvar "mirrtext" 1)
(command "zoom" "e")
(setq bz (getvar "osmode")) (setvar "osmode" 0)
(setq lvs (getvar "viewsize") lss (getvar "screensize") lvp (getvar "viewctr")
      lvl (list (list (- (car lvp) (* 0.5 (* lvs (/ (car lss) (cadr lss))))) (- (cadr lvp) (* 0.5 lvs)))
                   (list (+ (car lvp) (* 0.5 (* lvs (/ (car lss) (cadr lss))))) (+ (cadr lvp) (* 0.5 lvs))))
          lul (list (caar lvl) (cadadr lvl)) n 0)
(repeat (sslength ss)
  (setq ent (ssname ss n))
  (setq luu (strcat (getenv "Temp") "\\textb.wmf"))
  (command "mirror" ent "" lvp "@0,1" "y"
  "wmfout" luu ent "" "erase" ent ""
  "wmfin" luu lul "2" "" ""
  "mirror" (entlast) "" lvp "@0,1" "y"
  "explode" (entlast) "erase" (ssget "p") "r" "w"
  (polar (car lvl) (* 0.25 pi) (max (abs (/ lvs (cadr lss))) (abs (/ (* lvs (/ (car lss) (cadr lss))) (car lss)))))
  (cadr lvl) "") ;;end_command
  (setq n (+ n 1))
)
(command "zoom" "p")
(setvar "mirrtext" 0) (setvar "osmode" bz) (command "undo" "e")
(vl-file-delete luu)
)
(princ)
)
发表于 2009-4-10 11:11:00 | 显示全部楼层

(defun c:xt (/ bz ss n lvs lss lvp lvl lul ent luu)
(prompt "\n文字分解")
(while (setq ss (ssget ":S" '((0 . "*text"))))
(setvar "cmdecho" 0) (command "undo" "be") (setvar "mirrtext" 1)
(command "zoom" "e")
(setq bz (getvar "osmode")) (setvar "osmode" 0)
(setq lvs (getvar "viewsize") lss (getvar "screensize") lvp (getvar "viewctr")
      lvl (list (list (- (car lvp) (* 0.5 (* lvs (/ (car lss) (cadr lss))))) (- (cadr lvp) (* 0.5 lvs)))
            (list (+ (car lvp) (* 0.5 (* lvs (/ (car lss) (cadr lss))))) (+ (cadr lvp) (* 0.5 lvs))))
   lul (list (caar lvl) (cadadr lvl)) n 0)
(repeat (sslength ss)
  (setq ent (ssname ss n))
  (setq luu (strcat (getenv "Temp") "\\textb.wmf"))
  (command "mirror" ent "" lvp "@0,1" "y"
  "wmfout" luu ent "" "erase" ent ""
  "wmfin" luu lul "2" "" ""
  "mirror" (entlast) "" lvp "@0,1" "y"
  "explode" (entlast) "erase" (ssget "p") "r" "w"
  (polar (car lvl) (* 0.25 pi) (max (abs (/ lvs (cadr lss))) (abs (/ (* lvs (/ (car lss) (cadr lss))) (car lss)))))
  (cadr lvl) "") ;;end_command
  (setq n (+ n 1))
)
(command "zoom" "p")
(setvar "mirrtext" 0) (setvar "osmode" bz) (command "undo" "e")
(vl-file-delete luu)
)
(princ)
)

不怎么完善,有空也帮我优化一下

发表于 2009-4-10 21:04:00 | 显示全部楼层
改天我上个比较复杂的代码
发表于 2009-4-11 00:23:00 | 显示全部楼层

大家可以看看陈伯雄老师的代码,如下:

(Defun C:TextB (/ lvl lul lvp lvs lss ViewPL)
       ;(SetIErr)
       (SetQ lvs (GetVar "viewsize")
             lss (GetVar "screensize")
       )
       (Defun ViewPL ( / vi vw vh vc)
              (setq vi (* lvs (/ (Car lss) (Cadr lss)))
                    vc (GetVar "viewctr")
                    vw (list (- (car vc)  (* 0.5 vi))
                             (- (cadr vc) (* 0.5 lvs))
                       )
                    vh (list (+ (car vc)  (* 0.5 vi))
                             (+ (cadr vc) (* 0.5 lvs))
                       )
              )
              (List vw vh)
       )
       (PrinC "\nÇëÑ¡ÔñÒª·Ö½âµÄÎÄ×Ö: ")
       (SetQ ltl (SSGet)
             lvl (ViewPL)
             lul (List (Caar lvl) (Cadadr lvl))
             lvp (GetVar "viewctr")
       )
       (Command "mirror" ltl "" lvp "@0,1" "y"
                "wmfout" "textb" ltl ""
                "erase" ltl ""
                "wmfin" "textb" lul "2" "" ""
                "mirror" (EntLast) "" lvp "@0,1" "y"
                "explode" (EntLast)
                "erase" (ssget "p") "R" "W"
                        (polar (car lvl) (* 0.25 Pi)
                               (Max (Abs (/ lvs (Cadr lss)))
                                    (Abs (/ (* lvs
                                               (/ (Car lss) (Cadr lss))
                                            )
                                            (Car lss)
                                         )
                                     )
                               )
                        )
                        (cadr lvl)
                    ""
       )
       ;(ReErr)
  (PrinC)
)

发表于 2009-4-23 12:37:00 | 显示全部楼层

看我改编的文字炸开简写命令

(defun c:xt() (princ "txtexp") (command (c:txtexp)))

我也在其他地方找到的,并非原创!

发表于 2009-4-23 17:24:00 | 显示全部楼层
vocabulary发表于2006-8-1 0:32:00我用4楼大侠的方法试了一下,将输出的的WMF文件插入后,用X命令炸不开,不知是怎么回事?请各位帮忙看看,先谢谢了!

对于TTF字体,需要设置为反向(镜像一下),然后再WMFOUT,WMFIN

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

本版积分规则

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

GMT+8, 2025-7-16 15:04 , Processed in 0.204290 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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