明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3297|回复: 6

表格 源代码

[复制链接]
发表于 2017-8-4 11:00:28 | 显示全部楼层 |阅读模式
(defun c:bg  ()    ;;;画表格
  (setvar "cmdecho" 0)
  (setq os (getvar "osmode"))
  (setvar "osmode" 0)
  (setq pt1 (getpoint      "\n 第一角点:"))
  (setq pt3 (getcorner pt1 "\n 另一角点:"))
  (command "rectang" "w" 0 pt1 pt3)
  (setq wnn (1+ (getint "\n 列数||| <5>:")))
  (if (null wnn)  (setq wnn 5))
  (setq hnn (1+ (getint "\n 行数--- <5>:")))
  (if (null hnn)  (setq hnn 5))
  (setq pt2 (list (car pt3) (cadr pt1)))
  (setq pt4 (list (car pt1) (cadr pt3)))
  (setq ang (angle pt1 pt3))
  (cond
    ((and (> ang 0) (< ang (/ pi 2) ) )(setq   pp1 pt1 pp2  pt2  pp3  pt3 pp4  pt4))
    ((and (> ang (/ pi 2) ) (< ang pi) )
     (setq pp1 pt2
           pp2 pt1
           pp3 pt4
           pp4 pt3))
    ((and (> ang pi) (< ang (* pi 1.5) ))
     (setq pp1 pt3
           pp2 pt4
           pp3 pt1
           pp4 pt2))
    ((and (> ang (* pi 1.5) ) (< ang (* pi 2) ))
     (setq pp1 pt4
           pp2 pt3
           pp3 pt2
           pp4 pt1))
    )
  (setq        num 1
        txt 65)
  (setq ww (distance pp1 pp2))
  (setq hh (distance pp1 pp4))
  (setq        pt1   pp4
        ppbas pp4
        key   1)
  (repeat hnn
;;;绘制行
    (setq pt1 (polar pt1 (* pi 1.5) (/ hh hnn)))
    (setq pt2 (polar pt1 0 ww))
    (command "line" pt1 pt2 "")
    (if        (> key 1)
      (progn
        (setq txtins (inters ppbas
                             (polar pt1 0 (/ ww wnn))
                             pt1
                             (polar ppbas 0 (/ ww wnn))))
        (command "text" "m" txtins (/ hh hnn 2) 0 (itoa num))
        (setq num (1+ num))
        )
      )
    (setq ppbas        pt1
          key        (1+ key))
    )

  (setq        pt1   pp4
        ppbas pp4
        key   1)
  (repeat wnn
;;;绘制列
    (setq pt1 (polar pt1 0 (/ ww wnn)))
    (setq pt2 (polar pt1 (* pi 1.5) hh))
    (command "line" pt1 pt2 "")
    (if        (> key 1)
      (progn
        (setq txtins (inters ppbas
                             (polar pt1 (* pi 1.5) (/ hh hnn))
                             pt1
                             (polar ppbas (* pi 1.5) (/ hh hnn))))
        (command "text" "m" txtins (/ hh hnn 2) 0 (chr txt))
        (setq txt (1+ txt))
        )
      )
    (setq ppbas        pt1
          key        (1+ key))
    )
  (prin1)
  )

发表于 2017-8-6 15:17:51 | 显示全部楼层
谢谢分享,支持
发表于 2021-12-26 22:39:55 | 显示全部楼层
谢谢,正好试试看
发表于 2022-1-30 12:51:27 | 显示全部楼层
可以,学习一下
发表于 2022-7-9 15:08:37 | 显示全部楼层
可以,學習一下
发表于 2022-8-9 22:11:21 | 显示全部楼层
谢谢分享学习了
发表于 2023-3-7 10:53:44 | 显示全部楼层

谢谢分享学习了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 07:42 , Processed in 0.142537 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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