CAD设计论坛

 找回密码
 立即注册
论坛新手常用操作帮助系统等待验证的用户请看获取社区币方法的说明新注册会员必读(必修)
查看: 4530|回复: 7

[开发] 地板辐射供暖加热管的VBA辅助设计

[复制链接]
发表于 2006-4-19 13:33 | 显示全部楼层 |阅读模式
Sample Text
! q8 L$ ~% V% Q    介绍了一个用VBA编制的程序,用于AutoCAD绘制低温热水地板辐射供暖加热管的布置图时辅助计算加热管的长度。9 Z7 Z, a* r# h
    由于低温热水地板辐射供暖具有卫生、舒适、节省空间、便于分户计量等特点,该供暖方式已在北方逐渐普及起来。暖通设计者在绘制工程图时,也需要绘制加热管的布置图。[低温热水地板辐射供暖应用技术规程]第4.3.3条规定:同一热媒集配装置系统各分支路的加热管长度宜尽量接近,并不宜超过120m。而为了保证加热管的寿命,每一个环路中,不应有接头。这就要求设计者在绘制管道布置图时控制加热管的长度。如供货的盘管为100m/盘,则要求设计者在设计环路将每个环路使用的加热管长度都控制在100m以内。既要避免因加热管太短而造成浪费,有要避免加热管超过100m使环路中有接头,以及由于各分支的加热管长度不同而造成的阻力不平衡。
6 ^% P$ m! A6 p, N1 ]% |   一般利用AutoCAD绘图时,先绘制管道环路图再测量管道长度,这就要求设计者要一边绘图一边估计已采用加热管的总长,一旦估计错误则要重新绘图。利用VBA编程技术可以达到控制管道长度的目的。绘图时,先输入管道长度,每画完一条直管道,在AutoCAD的命令行会自动显示剩余长度,避免了绘图的盲目性。下面介绍该程序的编制和应用。! L! x, S+ Z7 Q
、编制程序0 r# N* o% u5 X( R
1)首先在AutoCAD窗口的“工具”选单中打开“宏/VisualBasic编辑器”进入VBA开发环境。
5 d, Q9 n& v  J  p# h& D8 A6 h% y4 T2)在VBA窗口的“视图”选单中选择“代码窗口”项,打开程序代码窗口。再在VBA窗口的“插入”选单中选择“过程”项,在工程中建立新的过程。在“添加过程”对话框设置新过程的名称、类型和范围,此设置名称为jrg,过程类型选择“子程序”,过程范围选择“公共的”。单击“确定”按钮,在代码窗口创建新 过程jrg如下图所示。过程的第一行和结束行自动产生。
% b' D4 F0 Q4 D6 V  p( _, S; |/ @( p) ]1 k( `7 {

* I1 N% m9 j% u: }1 }4 Y$ M
& N5 ~1 q$ ~) e2 r- O' e% ^1 b( s# }2 r$ N8 j/ A9 N3 O( n3 A

) R( X7 }/ @/ C% V  h* U3)在程序代码窗口中,Pubilc Sub jrg()和End Sub之间输入程序代码并将其保存到指定位置。控制加热管长度的程序如下:, Z$ t- O1 ?8 {7 {0 ?" k
$ H; Q, m2 R. U2 e- T0 k8 k# R
Public Sub jrg()
/ l$ ^2 B& k( {( j* `Dim startPnt As Variant7 l8 a1 y! G: l7 h* m5 W
  Dim endPnt As Variant
, Q& I! B" u. ^  Dim aa(0 To 5) As Double
4 r, N  G8 r3 P/ g  Dim prompt1 As String
4 z$ ]! O  E9 f# I8 L2 S  Dim prompt2 As String
/ z( m7 F8 e. i& k; }  Dim line1 As AcadPolyline8 F6 C2 m. l8 z
  Dim distance As Double
0 J  [. r9 d, K& @8 w" f8 t# g  Dim a As String
( L0 J& q% i; Z  Dim b As String) S3 @* o2 n7 u0 }/ a& h
  Dim keyWord As String+ {  K6 V/ C9 ?7 H/ K# t
  Dim pd As Boolean( Q% [( u9 x$ ~+ \+ C6 V. m
  prompt1 = vbCrLf & "Enter the start point of the line:"# ]7 J  a6 Z* }- A2 ?/ ?
  prompt2 = vbCrLf & "Enter the end point of the line:"
3 ~4 J* p3 ]  Z# A1 d  distance = ThisDrawing.Utility.GetReal(vbCrLf & "Enter an length/mm")
& S/ k9 t5 p1 y  scale1 = ThisDrawing.Utility.GetReal(vbCrLf & "Enter an scale:"); E: \# |- G; V% B, q5 H  l
  startPnt = ThisDrawing.Utility.GetPoint(, prompt1)
( A. o1 k; f( C) z" [) b; x$ S  endPnt = ThisDrawing.Utility.GetPoint(startPnt, prompt2)
4 T! U5 k4 U1 i/ `$ ~0 J  For i = 1 To 100000
4 p8 y4 V( I6 B1 h6 i  aa(0) = startPnt(0)
: h. d' O2 ~$ F# p7 q  aa(1) = startPnt(1)
$ n! B* ?! i( m3 {- X1 @) r* o  aa(2) = startPnt(2)2 _* T4 l$ L: a- \1 n7 o
  aa(3) = endPnt(0)) o# j3 D+ b; F. n5 d  j
  aa(4) = endPnt(1)7 ?: {( A% g4 \: t5 W
  aa(5) = endPnt(2)
  T/ {9 Q  `& R; ^9 {  Set line1 = ThisDrawing.ModelSpace.AddPolyline(aa)
. \1 q8 n8 T8 Z. n! x& M  Length = Sqr((aa(0) - aa(3)) * (aa(0) - aa(3)) + (aa(1) - aa(4)) * (aa(1) - aa(4)) + (aa(2) - aa(5)) * (aa(2) - aa(5)))( g# n) i# z" b. o, F9 i
  distance = distance - Length * scale13 y: ^7 ~5 A1 M. w  n
  If distance < 0 And (Not pd) Then6 X) e+ Y$ I8 I. R+ F/ |# f
  h = MsgBox("剩余长度小于0,是否退出?", vbYesNo, "警告")0 Y1 @: E- b1 ~% K! v
  If h = vbYes Then
+ z6 ~: K3 O- Z9 G; K# ~/ u  GoTo 100$ J: G' m. h- k8 V3 F. ]: [2 {
  Else
# Q7 z+ i$ T3 \9 |2 V  pd = True6 q* X: X- A2 P7 [) i
  End If
: X4 ]1 e  x- M  End If6 V4 c* p! B* L) ~  Y2 f
  startPnt = endPnt
# N# f! r; x, T' u& @# N( m6 ~  a = distance / 10003 S; L, \+ F7 l
  On Error GoTo 100' t, J4 V2 D" U5 {4 e: @6 o& r' x9 N# Z9 `, q
  endPnt = ThisDrawing.Utility.GetPoint(endPnt, "剩余长度" + a + "输入如下一点"): H) x* ?1 Y' r; M
  On Error GoTo 100# k/ x% w9 r8 a% i' ~
  Next i
9 X% _9 [! R" I' `+ M2 f5 a100
  i: y) a+ a: y7 _* [& dEnd Sub* f, }  _/ h+ N$ y# ^
2 使用程序! x! I* d6 j0 Q* U2 Y. O7 X
  在AutoCAD窗口的“工具”选单中打开“宏/宏”对话框,单击“运行”按钮。则在AutoCAD的命令行出现命令”Enter an Length/mm:“这是程序设计中要求每个环路使用的命令(要求以mm为单位)。如果要求每个环路使用的加热管长度都在100m以下,则输入100000,回车后出现”Enter an scale:“0 o6 o" K: u( Y2 k: j! U
即输入100,回车后出现”Enter the start point of the line:“便可以绘制加热管线。3 \: q/ S8 @% @4 S% s* `) U

* B: ^) w3 ?9 n0 [/ G; m  N8 i, Q[ 本帖最后由 summerfly2008 于 2006-4-21 19:30 编辑 ]
发表于 2006-4-19 16:54 | 显示全部楼层
继续坚持下去
发表于 2006-4-21 15:06 | 显示全部楼层
楼主怎么没下文了啊我需要编个统计图中所有线段长度的程序
发表于 2008-10-16 14:41 | 显示全部楼层
学习     学习
发表于 2008-10-26 17:53 | 显示全部楼层
谢谢!只可惜!我不会呀!
发表于 2008-10-26 23:08 | 显示全部楼层
不要说会了,我看都看不懂
发表于 2008-10-27 09:21 | 显示全部楼层
这东西对我很有用,尽管已经很古老了,但还谢了!
发表于 2008-11-10 18:48 | 显示全部楼层
楼主此程序里面好像缺点什么东西,
( {& ?% x: ~, M/ N达不到我们设计地暖管时能够知道剩余管的长度,5 I+ W( D" z$ }3 T$ d
可不可以帮忙再找些这方面的东西。
/ p) |0 J2 P% S2 {( i( G谢谢!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于|免责|隐私|版权|广告|联系|手机版|CAD设计论坛

GMT+8, 2024-11-28 10:56

CAD设计论坛,为工程师增加动力。

© 2005-2024 askcad.com. All rights reserved.

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