乐筑天下

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

求不规则多边形面域的程序。

[复制链接]

1

主题

3

帖子

1

银币

初来乍到

Rank: 1

铜币
7
发表于 2014-10-25 16:32:00 | 显示全部楼层 |阅读模式
Public Function Updateregon()
   Dim p(7) As Double
   Dim lwpolyObj As AcadLWPolyline
   p(0) = 0.8: p(1) = 0
   p(2) = 1.3: p(3) = 1.1
   p(4) = 0.5:   p(5) = 1.1
   p(6) = 0.5: p(7) = 0
   Set lwpolyObj = ThisDrawing.ModelSpace.AddLightWeightPolyline(p)
   lwpolyObj.Closed = True
'余下如下把lwpolyObj生成一个面域?请教
End Function
回复

使用道具 举报

23

主题

561

帖子

13

银币

中流砥柱

Rank: 25

铜币
653
发表于 2014-10-25 17:32:00 | 显示全部楼层
  1. Public Function Updateregon()
  2.    Dim p(7) As Double
  3.    Dim lwpolyObj As AcadLWPolyline
  4.    p(0) = 0.8: p(1) = 0
  5.    p(2) = 1.3: p(3) = 1.1
  6.    p(4) = 0.5:   p(5) = 1.1
  7.    p(6) = 0.5: p(7) = 0
  8.    Set lwpolyObj = ThisDrawing.ModelSpace.AddLightWeightPolyline(p)
  9.    lwpolyObj.Closed = True
  10.     '余下如下把lwpolyObj生成一个面域?请教
  11.     Dim curves(0) As AcadEntity
  12.     Set curves(0) = lwpolyObj
  13.    
  14.       
  15.     ' 创建面域
  16.     Dim regionObj As Variant
  17.     regionObj = ThisDrawing.ModelSpace.AddRegion(curves)
  18.     ZoomAll
  19. End Function
回复

使用道具 举报

1

主题

3

帖子

1

银币

初来乍到

Rank: 1

铜币
7
发表于 2014-10-26 11:08:00 | 显示全部楼层

多谢高手,请继续赐教。
实现这个,我的问题就解决了。下一步把这几个数据搞到窗体中去折腾一下。
Sub bb()
   Dim p(7) As Double
   Dim lwpolyObj As AcadLWPolyline
   p(0) = 0.8: p(1) = 0
   p(2) = 1.3: p(3) = 2.1
   p(4) = 0.5:   p(5) = 2.1
   p(6) = 0#: p(7) = 0.3
   Set lwpolyObj = ThisDrawing.ModelSpace.AddLightWeightPolyline(p)
   lwpolyObj.Closed = True
    Dim curves(0) As AcadEntity
    Set curves(0) = lwpolyObj
    Dim regionObj(0) As Variant
    regionObj(0) = ThisDrawing.ModelSpace.AddRegion(curves)
    '改变其图层及颜色,并求x质心
    Dim reg As AcadRegion
    Set reg = regionObj(0)  '为何转化不成功?或者直接用
    reg.Layer = "MMM"
    reg.color = acRed
    msbox "x质心为:" & reg.Centroid(0)
  End Sub
回复

使用道具 举报

23

主题

561

帖子

13

银币

中流砥柱

Rank: 25

铜币
653
发表于 2014-10-26 15:15:00 | 显示全部楼层
ThisDrawing.ModelSpace.AddRegion(curves) 返回数组!
Set reg = regionObj(0)(0)'试
回复

使用道具 举报

1

主题

3

帖子

1

银币

初来乍到

Rank: 1

铜币
7
发表于 2014-10-26 15:50:00 | 显示全部楼层
谢谢了。大致明白意思了。
个数组,还以为Variant是任一。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-4-20 18:05 , Processed in 1.492519 second(s), 63 queries .

© 2020-2025 乐筑天下

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