明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1646|回复: 5

请大神完善CASS的高程注记消隐程序

[复制链接]
发表于 2014-12-23 10:47:18 | 显示全部楼层 |阅读模式
昨天无意间看到一篇论文,就是关于lisp插件的,有关高程注记的消隐
感觉这个思路非常好,有一定的实用性。
里面有程序的主要部分,无奈本人对Lisp不在行,只会用……
大神们,可以下载了解下,看看有没有完善它的价值?小弟还是有必要的!期盼大神完善程序。

论文截图

效果截图

部分代码,根据论文,小弟手敲的哈:
(princ"请选择高程点:")
  (setq s1(ssget":s"'((0. "insert"))))
    (if s1
       (progn
         (setq a1(ssname s1 9))
         (setq txt(entnext al))
         (setq txt(entget txt))
         (if(=(cdr(assoc 0 txt))  "ATTRIB")
            (prign
              (setq pt1(cdr(assoc 10 txt)))
              (setq pt1(list(car pt1)(cadr pt1)))
              (setq txtbox(textbox txt))
              (setq txtbox(cdr txtbox))
              (setq txtbox(car txtbox))
              (setq x(car txtbox))
              (setq y(cadr txtbox))
              (setq pt1(polar pt1( *1.25 pi)0.1414))
              (setq pt2(polor pt2( *0.5pi)( +y0.2)))
              (setq pt3(polor pt2( *0.5pi)( +y0.2)))
              (command "wipeout" pt1 pt2 pt3 pt4 "c")
              (command "draworder" al "" "f")
            )
        (print"你选择的高程点没有属性!")
      )
   )
)

论文下载链接:http://yunpan.cn/cfUeKRBr2tiZa (提取码:1a7b)

本帖子中包含更多资源

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

x
发表于 2014-12-23 16:42:20 | 显示全部楼层
好多错误,先纠正错误先
(defun c:tt (/ s1 a1 txt pt1 txtbox x y pt2 pt3)
  (princ "\n请选择高程点:")
  (setq s1 (ssget ":s" '((0 . "INSERT"))))
  (if s1
    (progn
      (setq a1 (ssname s1 0))
      (setq txt (entnext a1))
      (setq txt (entget txt))
      (if (= (cdr (assoc 0 txt)) "ATTRIB")
        (progn
          (setq pt1 (cdr (assoc 10 txt)))
          (setq pt1 (list (car pt1) (cadr pt1)))
          (setq txtbox (textbox txt))
          (setq txtbox (cdr txtbox))
          (setq txtbox (car txtbox))
          (setq x (car txtbox))
          (setq y (cadr txtbox))
          (setq pt1 (polar pt1 (* 1.25 pi) 0.1414))
          (setq pt2 (polar pt1 0.0 (+ x 0.2)))
          (setq pt3 (polar pt2 (* 0.5 pi) (+ y 0.2)))
          (setq pt4 (polar pt1 (* 0.5 pi) (+ y 0.2)))
          (command "wipeout" pt1 pt2 pt3 pt4 "c")
          (command "draworder" al "" "f")
        )
        (print "你选择的高程点没有属性!")
      )
    )
  )
)
发表于 2014-12-23 16:42:56 | 显示全部楼层
好多错误,纠正错误先
  1. (defun c:tt (/ s1 a1 txt pt1 txtbox x y pt2 pt3)
  2.   (princ "\n请选择高程点:")
  3.   (setq s1 (ssget ":s" '((0 . "INSERT"))))
  4.   (if s1
  5.     (progn
  6.       (setq a1 (ssname s1 0))
  7.       (setq txt (entnext a1))
  8.       (setq txt (entget txt))
  9.       (if (= (cdr (assoc 0 txt)) "ATTRIB")
  10.         (progn
  11.           (setq pt1 (cdr (assoc 10 txt)))
  12.           (setq pt1 (list (car pt1) (cadr pt1)))
  13.           (setq txtbox (textbox txt))
  14.           (setq txtbox (cdr txtbox))
  15.           (setq txtbox (car txtbox))
  16.           (setq x (car txtbox))
  17.           (setq y (cadr txtbox))
  18.           (setq pt1 (polar pt1 (* 1.25 pi) 0.1414))
  19.           (setq pt2 (polar pt1 0.0 (+ x 0.2)))
  20.           (setq pt3 (polar pt2 (* 0.5 pi) (+ y 0.2)))
  21.           (setq pt4 (polar pt1 (* 0.5 pi) (+ y 0.2)))
  22.           (command "wipeout" pt1 pt2 pt3 pt4 "c")
  23.           (command "draworder" al "" "f")
  24.         )
  25.         (print "你选择的高程点没有属性!")
  26.       )
  27.     )
  28.   )
  29. )
发表于 2014-12-23 20:46:20 | 显示全部楼层
能改成ARX的吗?
发表于 2014-12-24 00:19:03 | 显示全部楼层
ARX好像是这样写,好像有点问题
  1.         acDocManager->lockDocument(acDocManager->curDocument());        
  2.         ads_name ss;
  3.         struct resbuf *rb;
  4.         rb = acutBuildList(RTDXF0, _T("INSERT"), 2, _T("GC200"), RTNONE);
  5.         int rt = acedSSGet(NULL, NULL, NULL, rb, ss);
  6.         if (rt != RTNORM)
  7.         {
  8.             acutRelRb(rb);
  9.             acedSSFree(ss);
  10.             return;
  11.         }
  12.         acutRelRb(rb);
  13.         long len;
  14.         acedSSLength(ss, &len);

  15.         for (int i = 0; i < len; i++)
  16.         {
  17.             ads_name ent, ssName, nextName;
  18.             acedSSName(ss, i, ssName);
  19.             acdbEntNext(ssName, nextName);

  20.             AcDbObjectId entId = AcDbObjectId::kNull;
  21.             AcDbEntity *pEnt = NULL;
  22.             acdbGetObjectId(entId, nextName);
  23.             if (acdbOpenObject(pEnt, entId, AcDb::kForWrite) == eOk)
  24.             {
  25.                 if (pEnt->isKindOf(AcDbText::desc()))
  26.                 {
  27.                     AcDbText *pText = AcDbText::cast(pEnt);
  28.                     AcGePoint3d posPt = pText->position();
  29.                     double ptX, ptY, boxX, boxY;
  30.                     ptX = posPt.x;
  31.                     ptY = posPt.y;
  32.                     AcDbExtents Ext;
  33.                     pText->getGeomExtents(Ext);
  34.                     AcGePoint3d minPt, maxPt;
  35.                     minPt = Ext.minPoint();
  36.                     maxPt = Ext.maxPoint();
  37.                     boxX = maxPt.x;
  38.                     boxY = maxPt.y;
  39.                     ads_point pt1, pt2, pt3, pt4;
  40.                     acutPolar(asDblArray(posPt), 1.25 * PI, 0.1414, pt1);
  41.                     acutPolar(pt1, 0.0, boxX + 0.2, pt2);
  42.                     acutPolar(pt2, 0.5 * PI, boxY + 0.2, pt3);
  43.                     acutPolar(pt1, 0.5 * PI, boxY + 0.2, pt4);

  44.                     acedCommand(RTSTR, TEXT("wipeout"),
  45.                         RT3DPOINT, pt1,
  46.                         RT3DPOINT, pt2,
  47.                         RT3DPOINT, pt3,
  48.                         RT3DPOINT, pt4,
  49.                         RTSTR, _T("C"),
  50.                         RTNONE);
  51.                     acedCommand(RTSTR, TEXT("draworder"),
  52.                         RTENAME, ssName,
  53.                         RTSTR, TEXT(""),
  54.                         RTSTR, _T("F"),
  55.                         RTNONE);
  56.                     pText->close();

  57.                 }
  58.                 pEnt->close();
  59.             }
  60.         }
  61.         acedSSFree(ss);
  62.         acDocManager->unlockDocument(acDocManager->curDocument());
复制代码
发表于 2014-12-24 00:21:34 | 显示全部楼层
// 这里不对
boxX = maxPt.x;
boxY = maxPt.y;
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-12-23 13:12 , Processed in 0.202745 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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