找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1179|回复: 13

[求助] [求助]:求助:[0112]怎样求出封闭区间(LWPOLYLINE)内的形心座标点呢?

[复制链接]
发表于 2006-1-12 16:25:38 | 显示全部楼层 |阅读模式

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

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

×
求助:[0112]怎样求出封闭区间(LWPOLYLINE)内的形心座标点呢?
我想再一个由(LWPOLYLINE)所形成的
封闭空间中,找出它的形心座标点?
请问该怎样做才可以完成呢?

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

已领礼包: 2个

财富等级: 恭喜发财

发表于 2006-1-12 16:46:47 | 显示全部楼层

Re: [求助]:求助:[0112]怎样求出封闭区间(LWPOLYLINE)内的形心座标点呢?

最初由 xyz518mm 发布
[B]求助:[0112]怎样求出封闭区间(LWPOLYLINE)内的形心座标点呢?
我想再一个由(LWPOLYLINE)所形成的
封闭空间中,找出它的形心座标点?
请问该怎样做才可以完成呢?

烦请帮忙解答
谢谢~ [/B]


几何知识忘记了,解释一下形心的定义吧!

下面的程序,不记得是哪里找的了.不知道合你意否?

  1.   [FONT=courier new]
  2. (defun centroid (poly / pl ms va reg cen)
  3.   (setq pl (vlax-ename->vla-object poly)
  4.         ms (vla-get-modelspace (vla-get-activedocument
  5.                                                        (vlax-get-acad-object)
  6.                                )
  7.            )
  8.         va (vlax-make-safearray vlax-vbobject '(0 . 0))
  9.   )
  10.   (vlax-safearray-put-element va 0 pl)
  11.   (setqreg (car (vlax-safearray->list (vlax-variant-value
  12.                                                           (vla-addregion ms va)
  13.                                       )
  14.                 )
  15.            ) cen (vla-get-centroid reg)
  16.   )
  17.   (vla-delete reg)
  18.   (vlax-safearray->list (vlax-variant-value cen))
  19. )
  20.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-1-12 18:53:08 | 显示全部楼层
谢谢各位的解答
另请教该怎样修改此程序为可以
判断选取的图元是否为 (0 . "REGION") 面域
若不是则加以转换呢?

(defun c:selobj()
(vl-load-com)
(setq en (car (entsel "\nSelect object:")))
(setq xobj (vlax-ename->vla-object en))
(vlax-dump-object xobj)
(setq ptlist (vla-get-Centroid xobj))
(setq ptms (vlax-safearray->list (variant-value ptlist)))
(command "CIRCLE" ptms "10")
(setq a (strcat "X=" (rtos (car ptms) 2 4))
      b (strcat "Y=" (rtos (cadr ptms) 2 4))
)
(setq txt (strcat a "," b))
(command "text" "j" "tl" ptms "15" "0" txt)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-12 19:02:46 | 显示全部楼层
  1. [FONT=courier new](load "xyp_lib.vlx")                        ;版本 V.20051230 (1873)
  2. ;|下载和加载通用函数(可在签名栏直接下载后放到搜索路径下)
  3. 利用以下任何一种方式(首选第一种)即可加载和运行通用函数内的所有子程序:
  4. ★1·在acad.lsp中增加(load"xyp_lib.vlx")
  5. ■2·在每个程序内增加(load"xyp_lib.vlx")
  6. ■3·在command下,输入(load"xyp_lib.vlx")
  7. ■4·在菜单.mnl中增加(load"xyp_lib.vlx")
  8. ■5·将xyp_lib.vlx文件直接拽到cad屏幕
  9. [COLOR=red] ★通用函数下载地址:[/COLOR]
  10. [url]http://www.xdcad.net/forum/attachment.php?s=&postid=1606661[/url]
  11. |;

  12. (defun c:test ()
  13.   (CMDLA0)
  14.   (mkla "形心座标" 3)
  15.   (if (setq pt (zxd))
  16.     (xyp-zb pt)
  17.   )
  18.   (CMDLA1)
  19. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-12 19:23:57 | 显示全部楼层
请教有不带使用自设函数的用法吗
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-12 19:32:35 | 显示全部楼层
命令:xxzb  (形心座标)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-1-12 22:38:57 | 显示全部楼层
谢谢版主的提供
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-13 08:33:07 | 显示全部楼层
最初由 xyz518mm 发布
[B]谢谢各位的解答
另请教该怎样修改此程序为可以
判断选取的图元是否为 (0 . "REGION") 面域
若不是则加以转换呢?

(defun c:selobj()
(vl-load-com)
(setq en (car (entsel "\nSelect object:")))
(setq xobj... [/B]
.

请问有人知道关于
"判断选取的图元是否为 (0 . "REGION") 面域"
这该怎样在程序中撰写呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2006-1-13 08:46:06 | 显示全部楼层
(if (= (cdr(assoc 0 (entget(entsel))) "region")
........
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-13 09:34:26 | 显示全部楼层
XXzb 这个程序对于那种刀把的注记还是不正确,形心选取在了外面,这个问题不知道能不能解决?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-13 10:24:09 | 显示全部楼层
确实楼上所说
还以为这是正常的呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-13 12:05:52 | 显示全部楼层
最初由 tjchkys 发布
[B]XXzb 这个程序对于那种刀把的注记还是不正确,形心选取在了外面,这个问题不知道能不能解决? [/B]

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

使用道具 举报

发表于 2006-1-18 12:39:49 | 显示全部楼层
最初由 taner 发布
[B](if (= (cdr(assoc 0 (entget(entsel))) "region")
........
) [/B]


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

使用道具 举报

 楼主| 发表于 2006-1-19 16:22:43 | 显示全部楼层
(DEFUN C:TEST()
      (VL-LOAD-COM)
      (SETQ ACADOBJECT   (VLAX-GET-ACAD-OBJECT)
    ACADDOCUMENT (VLA-GET-ACTIVEDOCUMENT ACADOBJECT)
    MSPACE       (VLA-GET-MODELSPACE ACADDOCUMENT)
     )
      (SETQ SS(ENTGET(CAR(ENTSEL))))
      (IF(/= "REGION" (CDR (ASSOC 0 SS)))
    (PROGN
   (SETQ SSVLOBJ(VLAX-SAFEARRAY-FILL (VLAX-MAKE-SAFEARRAY VLAX-VBOBJECT '(0 . 0) )
         (LIST(VLAX-ENAME->VLA-OBJECT (CDAR SS)))))
   (SETQ SS-REG(CAR(SAFEARRAY-VALUE(VARIANT-VALUE(VLA-ADDREGION MSPACE SSVLOBJ)))))
   )
   (SETQ SS-REG(VLAX-ENAME->VLA-OBJECT SS))
  )
      ;;到此变量SS-REG为面域
      )
我看到這可以求出的程序

但另在请问如果现在求出的形心座标点要用line连线到这封闭区间的4各顶点

其4各顶点各为距离形心最远的4段距离顶点

且不可以碰到封闭空间的线段

该怎样处理这程序呢?

烦请各位帮忙解答一下

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-29 01:20 , Processed in 0.301947 second(s), 57 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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