QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

全站
6天前
查看: 6064|回复: 3
收起左侧

[已解决] VBA:如何填充不规则区域?

[复制链接]
发表于 2011-5-16 10:36:12 | 显示全部楼层 |阅读模式 来自: 中国浙江杭州

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

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

x
本帖最后由 157787698 于 2011-5-16 10:50 编辑
7 i1 z4 K; ?& X: G4 n) J/ g( ^: z+ Q3 s* x8 G
如何填充不规则区域呢?比如下面的代码创建了一个封闭区域,如何填充呢?
& _" t; P+ l5 i7 _1 r- F$ H9 I; u- U1 R4 |# @
  
  1. Dim splineObj As AcadSpline# Z. r+ L: Q; Z/ k( F, \" d
  2.     Dim startTan(0 To 2) As Double# U; R, X8 S0 p0 h8 R3 D0 j9 O
  3.     Dim endTan(0 To 2) As Double* A7 n0 T! {- e+ F
  4.     Dim fitPoints(0 To 17) As Double
    : }$ m& @4 o0 U7 S0 ^& ~
  5.     dim p2(0 to 3 )  as double
    . {. x3 Z  l* K4 S6 ^7 E) T
  6. ) h. e( f' N9 W, u) u- }$ }
  7.     P2(0) = 1: P2(1) = 1
    # k1 X9 W, @4 O% e3 l+ b
  8.     P2(2) = 10: P2(3) = 1/ c# R& I- r) H
  9.     Set PLINEOBJ = ThisDrawing.ModelSpace.AddLightWeightPolyline(P2)
    7 V3 G3 D0 J/ r4 s% Q3 H4 J

  10. , t9 G  ?9 D* e/ C
  11.     startTan(0) = 0.5: startTan(1) = 0.5
    8 @, P8 d6 t0 a! ?7 ]
  12.     endTan(0) = 0: endTan(1) = 0
    ) d# r6 z4 x& y5 I, v! O# b
  13.     fitPoints(0) = 1: fitPoints(1) = 1( p/ k% S8 ^& W4 E3 s! L
  14.     fitPoints(3) = 3: fitPoints(4) = 9
    , s2 ^- e0 e9 [) y  z1 q& H
  15.     fitPoints(6) = -1: fitPoints(7) = 17* w3 \: h& u4 q- i
  16.     fitPoints(9) = 1: fitPoints(10) = 25) Y. n2 L- T8 ^( ^
  17.     fitPoints(12) = 10: fitPoints(13) = 10# j2 m6 Y, i- P2 z
  18.     fitPoints(15) = 10: fitPoints(16) = 1
    ! ^( i# _# P, x' T: o) L  i
  19.     $ c% l% ]1 x8 @7 _$ C+ [
  20.     Set splineObj = ThisDrawing.ModelSpace.AddSpline(fitPoints, startTan, endTan)
    * |. {3 f% @$ F% H7 N
  21.     ZoomAll; D! n) `* ^& i( [9 a9 g

  22. ' N, h2 ?5 p. @8 [' J  P( T* N
复制代码
  I+ f! t5 P, l; n. Z
如何使用取点填充?
发表于 2011-5-16 14:23:57 | 显示全部楼层 来自: 中国辽宁铁岭
  1.     Dim splineObj As AcadSpline
    ' T7 n* g, X" {* {3 o1 T
  2.     Dim startTan(0 To 2) As Double
    7 n5 i, E# y* n  P5 c, t; _2 h
  3.     Dim endTan(0 To 2) As Double) T, L+ ?! Z  k
  4.     Dim fitPoints(0 To 17) As Double
    : d. b, O( e8 e6 h$ i2 {: n
  5.     Dim p2(0 To 3)   As Double" Q& y- M5 ]/ m
  6.     Dim PLINEOBJ As AcadLWPolyline4 }7 l2 H3 t* c
  7.     '声明一个对象数组,用于定义填充的外边界" n# C9 V% T/ X2 f* g
  8.     '边界必须是由同一平面内首尾相连的若干条线封闭构成
    + |# x6 H' g% ?( B2 d
  9.     '本例的填充边界由一条二维多段线和一条二维样条曲线共两条线构成,所以数组元素数为2,最大下标为1
    ) j  S$ m" a, s9 M
  10.     '根据需要,还可以声明若干个对象数组用于定义填充对象的内边界; G- j' m2 O' a! w3 m! A6 \
  11.     Dim Obj(1) As Object9 z# W9 s  u( u$ }( h3 y
  12.     '声明一个填充对象" x: t, m- h$ p
  13.     Dim H As AcadHatch
    7 D- G! x, Q" _% ^9 _
  14.     + s: l$ Y" O  V, n- {
  15.     p2(0) = 1: p2(1) = 1
    $ ~. Q4 l; r4 o! K
  16.     p2(2) = 10: p2(3) = 1* O$ I+ {' }' q  d5 {# z3 N
  17.     Set PLINEOBJ = ThisDrawing.ModelSpace.AddLightWeightPolyline(p2). c' @' |  b& Q% R
  18. 7 t6 N9 k' \" T/ f/ ]9 m8 G: r  L
  19.     startTan(0) = 0.5: startTan(1) = 0.5
    8 w: x% Q6 S/ B
  20.     endTan(0) = 0: endTan(1) = 0
    - C  h6 z7 f) g5 D0 v/ _. \
  21.     fitPoints(0) = 1: fitPoints(1) = 19 v$ p( W, L  \/ V6 Y! C! ]
  22.     fitPoints(3) = 3: fitPoints(4) = 9
    % m2 b- N3 y" f! B" o2 R
  23.     fitPoints(6) = -1: fitPoints(7) = 17
    0 I" j) Y* c! ?1 y# B
  24.     fitPoints(9) = 1: fitPoints(10) = 25
    . ?7 O1 l. ]7 |7 \8 D& s& D3 x
  25.     fitPoints(12) = 10: fitPoints(13) = 10
    + y4 a% s3 d9 N' n4 [, F: F% h+ O
  26.     fitPoints(15) = 10: fitPoints(16) = 1
    % U; Z4 z$ [: a
  27.     - D2 P( U& g! f1 C1 O7 @! a: L; }# s. o
  28.     Set splineObj = ThisDrawing.ModelSpace.AddSpline(fitPoints, startTan, endTan)
    4 b1 `& _: p& r2 A4 W
  29.     '对构成边界的数组赋值. l- z0 \1 F0 p  q# ]  h- v+ N" A
  30.     Set Obj(0) = splineObj
    - ^$ b# N& L( G+ L; r; y: N: |
  31.     Set Obj(1) = PLINEOBJ
    % p' P$ {( }  t3 a  a
  32.     '创建填充对象
    / f4 D! a( Y/ U" J; j2 q
  33.     'cad2004及以上版本的AddHatch方法既可以创建图案填充,也可以创建渐变色填充
    - f$ J. h/ K- M" z4 q: ~
  34.     '所以2002及以前版本的AddHatch方法有三个参数,而2004及以上版本增加了第四个参数"填充对象类型"(AcHatchObjectType)  c- c2 y9 ?& H1 B) f( s- ?
  35.         '该参数有两个命名常量,一个是acHatchObject = 0(图案填充),另一个是acGradientObject = 1(渐变色填充). ]5 J* s$ I* r4 R9 r
  36.         '该参数是可选的,默认是0(即图案填充)
    : t# o' Y5 ?& _2 }
  37.         '下面的代码没有写这个参数,用的是默认值图案填充' u6 G7 \6 {* b$ R5 L, W
  38.     '前面三个参数:
    $ q& w0 I. q  s5 u: ?3 I* o/ O$ X
  39.         '当填充类型为图案填充时
    : x& Z" ?, ?+ @+ Y  P# {
  40.             '第一个参数是"图案类型"(AcPatternType)8 C7 K* n( w: {2 \
  41.                 '该参数有三个命名常量
    # L' D3 b6 j" L9 z/ X
  42.                     '一个是acHatchPatternTypeUserDefined = 0,对应于图形界面填充对话框中"类型"下拉列表框中的"用户定义"5 @1 t1 Q7 f- \$ h+ P6 a  z; i/ I
  43.                     '再一个acHatchPatternTypePreDefined = 1,对应于图形界面填充对话框中"类型"下拉列表框中的"预定义"" L% T4 h0 @$ n! V/ T% A
  44.                     '第三个acHatchPatternTypeCustomDefined = 2,对应于图形界面填充对话框中"类型"下拉列表框中的"自定义"
    : j9 A& w( p/ @6 C" Y. {
  45.                     '下面的代码用的是"预定义"
    7 l- t/ i: ~: ]( S6 S1 e  b9 C% y
  46.             '第二个参数是"图案名称",在图形界面的填充对话框中都可以看到
    0 P6 s3 S- N# l
  47.         '当填充类型为渐变色填充时
    3 b- E3 w4 l2 ~& k7 m
  48.             '第一个参数是"渐变类型"(AcGradientPatternType)# u( F% ~! ~5 d  q  f7 e
  49.                 '该参数有两个命名常量
    + M+ f* p* }" J; `1 ~& g/ L
  50.                     '一个是acPreDefinedGradient = 0(预定义)# M5 x& V6 d% W1 `* e  p
  51.                     '另一个是acUserDefinedGradient = 1(用户定义)3 |6 N* _- [2 Q! f% D
  52.                     '第二个可能是为以后版本升级备用的,现在不能用,只能用第一个* b" T$ `: K  J$ K4 `$ X# C" a
  53.             '第二个参数是"渐变填充名称",预定义的有以下这些
    0 e1 Q" C/ s! ]6 E+ p" U% ?7 q
  54.             'LINEAR, CYLINDER, INVCYLINDER, SPHERICAL HEMISPHERICAL, CURVED, INVSPHERICAL, INVHEMISPHERICAL 或 INVCURVED
    ; [, R) D* w1 o( {6 ]$ M5 ~
  55.         '第三个参数是"关联",布尔型
    , y& m& S2 \1 i
  56.     Set H = ThisDrawing.ModelSpace.AddHatch(acHatchPatternTypePreDefined, "ansi31", True)
    ) S& b& I" I+ w: t6 ^8 v. Z
  57.     '创建填充后的第一件事就是为它指定外边界
    . T% D0 m! r5 R2 V) i+ N3 x
  58.     '填充对象的其它属性可以在后面慢慢弄,这里就不写了
    1 w8 J$ o& U/ u! }8 }
  59.     H.AppendOuterLoop Obj' F+ B; [0 z9 n. ?# k) B
  60.    
    + k6 r6 R6 q4 d: @* t! |9 E* S" a
  61.     ZoomAll
复制代码
 楼主| 发表于 2011-5-16 14:56:30 | 显示全部楼层 来自: 中国浙江杭州
谢谢
9 {( k, S2 n! j9 {2 j
1 t) [. F/ F$ l1 H- n/ k+ H我爱谁家,你太强了
 楼主| 发表于 2011-5-16 16:06:11 | 显示全部楼层 来自: 中国浙江杭州
需要补充说明一点:
% ^; R- N2 _& \: k1 }4 O, ]4 M2 ]绘制样条曲线时最好用三维坐标,即z坐标即使为0也写出来
: k% k8 I' Q7 Y7 W) ~5 I
6 N6 H: {+ f- G  @我遇到了这样一个问题:我在填充由样条曲线和多线段围成的区域时,经常跳出来提示输入无效,但有时候又是正常的。  @8 f& D$ @. N: B
! P7 _$ m0 u" e# F7 s, j
我查找了很长时间,我觉得这没有道理。
' E. b& r- F1 k2 y% B' Q
7 s1 q8 P. E6 g4 c9 g  w" `1 [) F最后发现是因为我在绘制多线段时使用了绘制样条曲线时的同一个数组导致的,而在那里使用该数组的时候我是当做二位坐标来赋值的,而在对样条曲线点赋值的时候我直接忽略了z坐标,导致样条曲线不在xy平面上,最终形成的区域不是二维面域,也就无法填充。
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则


Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

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