明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4336|回复: 17

如何用VBA求面积?

  [复制链接]
发表于 2003-7-20 22:59:00 | 显示全部楼层 |阅读模式
帮忙,,
在用CAD命令求面积时太麻烦,能不能这样,我在一个封闭的区域内单击鼠标,
让电脑算出该封闭的区域的面积。
发表于 2003-7-20 23:32:00 | 显示全部楼层
编程申请里面有原代码!
发表于 2003-7-21 21:07:00 | 显示全部楼层
2楼的能不能说得详细一点儿?
我对这个也比较关心,想借鉴一下,谢了
发表于 2003-7-21 23:30:00 | 显示全部楼层

我帖了原代码在"编程申请"里面!

你们去看看就知道了!不过我的程序你们可能需要改一下,因为是涉及比例尺的!
 楼主| 发表于 2003-12-16 17:10:00 | 显示全部楼层
大虾,我在编程申请里下载了源代码,但不行呀,老是提示说比例尺不对,不知何故,
我对代码看得不是很懂呀
发表于 2003-12-16 18:17:00 | 显示全部楼层
把userr1参数改为1000,就是设置图纸比例为1000,设为500就是500比例,如果你算的是实地面积用1000比例尺的就可以了!
 楼主| 发表于 2004-1-3 15:22:00 | 显示全部楼层
刚才我试了一下,那个程序很有帮助,但对我还是不够实用,
我是想像填充一下可以点击,然后可以判断出一个封闭区域,
再来计算这个封闭区域的面积,当然这个区域不一定要是多段线组成,
是直线也应该能行呀,大家帮忙呀
发表于 2004-1-3 15:25:00 | 显示全部楼层
如果不封闭的话可能比较麻烦!
 楼主| 发表于 2004-1-3 16:19:00 | 显示全部楼层
如果封闭的话怎么写代码呢
能不能说一点建议?
发表于 2004-1-3 17:01:00 | 显示全部楼层
呵呵,这个也可以求面积。在封闭区域内选择一点,然后生成它的边界,这个边界就是封闭的多段线,直接使用它的属性就行了。


  1. Sub test()
  2.    
  3.     ' 当前图纸的实体数目
  4.     Dim n As Long
  5.     n = ThisDrawing.ModelSpace.Count
  6.    
  7.     ' 调用BOUNDARY命令获取某一点处的边界
  8.     Dim Pt As Variant
  9.     Pt = ThisDrawing.Utility.GetPoint(, "指定内部点: ")
  10.     ThisDrawing.SendCommand "_-Boundary" & vbCr & Pt(0) & "," & Pt(1) & vbCr & vbCr
  11.    
  12.     ' 如果存在边界,则会生成新的实体
  13.     Dim lwpLineObj As AcadLWPolyline
  14.     If ThisDrawing.ModelSpace.Count > n Then
  15.         Set lwpLineObj = ThisDrawing.ModelSpace.Item(ThisDrawing.ModelSpace.Count - 1)
  16.         MsgBox lwpLineObj.Area
  17.         lwpLineObj.Delete
  18.     Else
  19.         MsgBox "未发现有效的边界。"
  20.     End If
  21. End Sub
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 18:41 , Processed in 0.200365 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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