明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: liuyang4740

求助:块插入点问题

  [复制链接]
发表于 2007-10-18 14:05:00 | 显示全部楼层
你要通过拾取圆来得到坐标呢还是其它什么方法,也可以上张图。
 楼主| 发表于 2007-10-18 17:48:00 | 显示全部楼层

不是!我想通过for each 命令自动搜索所有的块参照,然后自动获取圆心

发表于 2007-10-18 21:59:00 | 显示全部楼层
对于二维的情况,可以试用下面的代码,只要把块名haha更换
  1. 'Option Explicit
  2. Sub test()
  3. Dim blkDef As AcadBlock
  4. Dim objEnt As AcadEntity
  5. Dim center As Variant
  6. Dim InsPnt As Variant
  7. Set blkDef = ThisDrawing.Blocks("haha")
  8. For Each objEnt In blkDef
  9.     If objEnt.ObjectName = "AcDbCircle" Then
  10.       center = objEnt.center
  11.       xc = center(0): yc = center(1)
  12.     End If
  13. Next
  14. For Each objEnt In ThisDrawing.ModelSpace
  15.    If objEnt.ObjectName = "AcDbBlockReference" Then
  16.      If objEnt.Name = "haha" Then
  17.        InsPnt = objEnt.InsertionPoint
  18.        rot = objEnt.Rotation
  19.        x_scale = objEnt.XScaleFactor
  20.        y_scale = objEnt.YScaleFactor
  21.        new_x = Cos(rot) * x_scale * xc - Sin(rot) * y_scale * yc + InsPnt(0)
  22.        new_y = Sin(rot) * x_scale * xc + Cos(rot) * y_scale * yc + InsPnt(1)
  23.        MsgBox new_x & ", " & new_y
  24.     End If
  25.     End If
  26. Next
 楼主| 发表于 2007-10-19 09:32:00 | 显示全部楼层
非常感谢版主!问题解决了!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-26 12:49 , Processed in 0.159279 second(s), 16 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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