明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: F海市蜃楼

移到指定点

[复制链接]
发表于 2024-8-31 16:35:39 | 显示全部楼层
我简化了 统一网名 网友的代码,你看看行不行。


  1. (defun c:11(/ dxname  p0 p1 p2 p3)
  2.        (if (setq dxname (entsel "\n选择五角星:"))      
  3.        (progn
  4.      (setq p1 (getreal "\n向右距离:"))
  5.         (setq p2 (getreal "\n向上距离:"))
  6.         (setq p0 (osnap (cadr dxname) "nea"))
  7.         (setq p3 (list (+ (car p0) p1) (+ (cadr p0) p2)))        
  8.         (command "copy" dxname "" p0 p3)
  9.     )
  10.     )
  11.         (princ))


 楼主| 发表于 2024-8-31 20:00:40 | 显示全部楼层
qazxswk 发表于 2024-8-31 16:18
你这句话,我看了很久,明白大概的意思,你意思,是不是选择对象,然后在命令行直接输入:200,500  然后 ...

嗯嗯,就是这样的,实现了第一种,就是想着两种方式,第二种就是先点击起点P0,在分别点击P0-P1(表示横向距离)和P0-P2(表示纵向距离),最后移动(复制)到P1和P2的交点(P1,P2)
 楼主| 发表于 2024-8-31 20:01:47 | 显示全部楼层
qazxswk 发表于 2024-8-31 16:35
我简化了 统一网名 网友的代码,你看看行不行。

嗯,就是这样,实现了第一种方式👍👍👍👍👍👍👍
发表于 2024-9-2 15:58:42 | 显示全部楼层
(defun c:tt(/ dat dxlx en i lst p0 p1 p2 p3 pt pt1 pt2 ptlst sl ss)
        (setq ss(ssget))
        (setq i 0 lst nil sl (sslength ss))
        (repeat sl
                (setq en (ssname ss i));取图元名
    (setq dat (entget en))
                (setq dxlx (cdr (assoc 0 dat)));获取对象的类型
                (if(= dxlx "LWPOLYLINE")(setq coobj en))
                (cond
                        ((= dxlx "POINT")
                                (setq pt (cdr(assoc 10 dat)))
                                (setq lst (cons pt lst))
                        );假设是点对象
                        ((= dxlx  "LINE")
                                (setq pt1 (cdr(assoc 10 dat)))
                                (setq pt2 (cdr(assoc 11 dat)))
                                (if (not (member pt1 lst))(setq lst (cons pt1 lst)))
                                (if (not (member pt2 lst))(setq lst (cons pt2 lst)))
                        );假设是2条直线相交
                        ((= dxlx  "DIMENSION")
                                (setq pt1 (cdr(assoc 13 dat)))
                                (setq pt2 (cdr(assoc 14 dat)))
                                (if (not (member pt1 lst))(setq lst (cons pt1 lst)))
                                (if (not (member pt2 lst))(setq lst (cons pt2 lst)))
                        );假设是标注
                )
                (setq i (1+ i))
        )       
        (cond
                ((= (length lst) 1)
                        (setq p0 (nth 0 lst))
                        (setq p1 (getreal "\n向右距离:"))
            (setq p2 (getreal "\n向上距离:"))
                )
                ((= (length lst) 3)
                        (setq
                                ptlst (vl-sort lst (function (lambda (e1 e2)(< (car e1) (car e2)))))
                                p2 (nth 0 ptlst) p0 (nth 1 ptlst) p1 (nth 2 ptlst);取得3个点
                                p1(distance p0 p1);向右距离
                                p2(distance p0 p2);向上距离
                        )
                )
        )
        (setq p3 (list(+(car p0)p1)(+(cadr p0)p2)))
        (command "copy" coobj "" p0 p3)
        (princ)
)
把能想到几种情况都写进去了
1、已有五角星和一个点
2、已有五角星和三个点
3、已有五角星和两条直线
4、已有五角星和2个标注
 楼主| 发表于 2024-9-3 00:36:58 | 显示全部楼层
统一网名 发表于 2024-9-2 15:58
(defun c:tt(/ dat dxlx en i lst p0 p1 p2 p3 pt pt1 pt2 ptlst sl ss)
        (setq ss(ssget))
        (setq i 0 l ...

优秀优秀&#128077;&#128077;&#128077;&#128077;&#128077;&#128077;,已经解决了,非常感谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-18 06:21 , Processed in 0.163201 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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