找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1075|回复: 5

[求助] 旋转卡壳

[复制链接]

已领礼包: 604个

财富等级: 财运亨通

发表于 2014-11-6 16:57:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
哪位高手能帮忙用lisp完成?

旋转卡壳算法.doc

58.5 KB, 下载次数: 3, 下载积分: D豆 -1 , 活跃度 1

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-11-6 17:02:32 | 显示全部楼层
把其它点用 trans 到当前边,然后排序找出 car 最大, last 最小和最大,实际上就是求出了两个边长,计算面积,这一部分用 AcGeBoundBlock2d 很简单,Autolisp 也可以写,你试着写写
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-11-6 17:16:12 | 显示全部楼层
再补充一个条件,点集要先求出凸包,而且逆时针凸包用起来要方便些
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-11-6 17:29:13 | 显示全部楼层
临时写了一个和一条边对齐的 Rectang 函数,没有测试
  1. (defun MaxRectangOnSide        (p1 p2 pts / lst vy minx maxx area)
  2.   (setq        v    (mapcar '- p2 p1)
  3.         lst  (mapcar '(lambda (x)
  4.                         (trans (mapcar '- x p1) 0 v)
  5.                       )
  6.                      pts
  7.              )
  8.         vy   (vl-sort lst '(lambda (x1 x2) (> (car x1) (car x2))))
  9.         vxl  (vl-sort lst '(lambda (x1 x2) (< (last x1) (last x2))))
  10.         minx (last (car vxl))
  11.         maxx (last (last vxl))
  12.         area (* vy (- maxx minx))
  13.   )
  14.   (list        area ;_矩形面积
  15.         (polar p1 (angle p1 p2) minx) ;_矩形角点
  16.         (angle p1 p2) ;_边
  17.         vy ;_垂直边方向长度
  18.         (- maxx minx) ;_沿边方向长度
  19.   )
  20. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

发表于 2014-11-6 17:35:22 | 显示全部楼层
前几天ST发的帖子, 求 最小包围盒 就是用的旋转卡壳的算法,你去看看帖子。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 264个

财富等级: 日进斗金

发表于 2014-11-6 21:44:45 来自手机 | 显示全部楼层
本帖最后由 iLisp 于 2014-11-6 21:52 编辑

在AutoCAD中 点描述的对象是最基础对象,凡是点描述的都可在AcGe找到对应类,这些算法Autodesk已经提供了,用autolisp还去闷头实现已有高级算法及函数,浪费时间就是浪费生命!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-15 05:26 , Processed in 0.182501 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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