乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 53|回复: 1

[编程交流] LISP新手帮助。。。

[复制链接]

1

主题

1

帖子

0

银币

初来乍到

Rank: 1

铜币
5
发表于 2022-7-6 09:08:31 | 显示全部楼层 |阅读模式
对lisp很陌生,想知道如何获得点列表(例如X1 Y1 X2 Y2)或在当前绘图空间范围内绘制矩形。我需要能够在任何缩放时执行此操作,换句话说,不只是最大化,我不需要图形的限制,只需要围绕当前显示的内容绘制一个框。
 
谢谢大家!
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 10:43:37 | 显示全部楼层
以下函数将返回当前视图范围的列表:
 
  1. (defun LM:WindowExtents nil ;; © Lee Mac 2011
  2. (
  3.    (lambda ( c v ) (list (trans (mapcar '- c v) 1 0) (trans (mapcar '+ c v) 1 0)))
  4.    (getvar 'VIEWCTR)
  5.    (
  6.      (lambda ( h s ) (list (* h s) h))
  7.      (/ (getvar 'VIEWSIZE) 2.) (apply '/ (getvar 'SCREENSIZE))
  8.    )
  9. )
  10. )

 
可以使用Rectang命令调用:
 
  1. (defun c:test ( / lst )
  2. (setq lst (LM:WindowExtents))
  3. (command "_.rectang" "_non" (car lst) "_non" (cadr lst))
  4. (princ)
  5. )

 
或者,使用entmake(以下内容也适用于所有UCS/View):
 
  1. (defun c:test ( / lst nrm )
  2. (setq nrm (trans '(0. 0. 1.) 1 0 t)
  3.        lst (mapcar 'trans (LM:WindowExtents) '(0 0) (list nrm nrm))
  4. )
  5. (entmakex
  6.    (list
  7.      (cons 0 "LWPOLYLINE")
  8.      (cons 100 "AcDbEntity")
  9.      (cons 100 "AcDbPolyline")
  10.      (cons 90 4)
  11.      (cons 70 1)
  12.      (cons 10 (car  lst))
  13.      (cons 10 (list (caadr lst) (cadar  lst)))
  14.      (cons 10 (cadr lst))
  15.      (cons 10 (list (caar  lst) (cadadr lst)))
  16.      (cons 210 nrm)
  17.    )
  18. )
  19. (princ)
  20. )
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-7 05:31 , Processed in 0.592472 second(s), 56 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表