谁能帮我编一段用VB对CAD进行二次开发的程序代码啊

作者&投稿:超刘 (若有异议请与网页底部的电邮联系)
求一段vb二次开发cad的代码~

((-1 . ) (0 . "LWPOLYLINE") (330 . ) (5 .
"F1") (100 . "AcDbEntity") (67 . 0) (410 . "Model") (8 . "0") (100 .
"AcDbPolyline") (90 . 5) (70 . 1) (43 . 0.0) (38 . 0.0) (39 . 0.0) (10 558.344
515.854) (40 . 0.0) (41 . 0.0) (42 . 0.0) (10 1019.94 765.048) (40 . 0.0) (41 .
0.0) (42 . 0.0) (10 1253.07 499.552) (40 . 0.0) (41 . 0.0) (42 . 0.0) (10
817.118 194.464) (40 . 0.0) (41 . 0.0) (42 . 0.0) (10 434.786 268.99) (40 .
0.0) (41 . 0.0) (42 . 0.0) (210 0.0 0.0 1.0))



LWPOLYLINE 的DXF组码值为:
100
子类标记 (AcDbPolyline)


90
顶点数

70
多段线标志(按位编码);默认值为 0:
1 = 关闭;128 = Plinegen

43
固定宽度(可选;默认值 = 0)。如果设置为可变宽度(代码 40 和/或 41),则不使用

38
标高(可选;默认值 = 0)

39
厚度(可选;默认值 = 0)

10
顶点坐标(在 OCS 中),多个条目;每个顶点一个条目
DXF:X 值;APP:二维点

20
DXF:顶点坐标的 Y 值(在 OCS 中),多个条目;每个顶点一个条目

40
起点宽度(多个条目;每个顶点一个条目)(可选;默认值 = 0;多个条目)。如果设置为固定宽度(代码 43),则不使用

41
端点宽度(多个条目;每个顶点一个条目)(可选;默认值 = 0;多个条目)。如果设置为固定宽度(代码 43),则不使用

42
凸度(多个条目;每个顶点一个条目)(可选;默认值 = 0)

210
拉伸方向(可选;默认值 = 0, 0, 1)
DXF:X 值;APP:三维矢量

220, 230
DXF:拉伸方向的 Y 值和 Z 值(可选)

最基本的首先你要在vb中加载autocad库,当然你要装了autocad,可以用vb控制建立cad文件,然后向cad文件中写数据。对于在CAD中建立直角坐标系,建议你看一下wcs对应的cad中的对象是哪一个,然后用vb调用建立wcs。下面是一个vb中创建CAD文件并向模型空间画直线的代码。
前提一定要在vb中加载CAD,记得CAD的帮助文件中有vba的帮助,建议你下载cad vba二次开发的书籍,百度文库有。希望能够采纳我的回答!!!!!

Sub AddLineVB()
On Error Resume Next

' 连接至 AutoCAD 应用程序
Dim acadApp As AcadApplication
Set acadApp = GetObject _
(, "AutoCAD.Application.17")
If Err Then
Err.Clear
Set acadApp = CreateObject _
("AutoCAD.Application.17")
If Err Then
MsgBox Err.Description
Exit Sub
End If
End If

' 连接至 AutoCAD 图形
Dim acadDoc As AcadDocument
Set acadDoc = acadApp.ActiveDocument

' 创建直线的端点
Dim lineObj As AcadLine
Dim startPoint(0 To 2) As Double
Dim endPoint(0 To 2) As Double
startPoint(0) = 1
startPoint(1) = 1
startPoint(2) = 0
endPoint(0) = 5
endPoint(1) = 5
endPoint(2) = 0
' 在模型空间中创建 Line 对象
Set lineObj = acadDoc.ModelSpace.AddLine _
(startPoint, endPoint)
ZoomAll
acadApp.visible = True
End Sub

第一个程序:画一百个同心圆
第一步:复制下面的红色代码
第二步:在模型空间按快捷键Alt+F8,出现宏窗口
第三步:在宏名称中填写C100,点“创建”、“确定”
第四步:在Sub c100()和End Sub之间粘贴代码
第五步:回到模型空间,再次按Alt+F8,点击“运行”
Sub c100()
Dim cc(0 To 2) As Double '声明坐标变量
cc(0) = 1000 '定义圆心座标
cc(1) = 1000
cc(2) = 0
For i = 1 To 1000 Step 10 '开始循环
Call ThisDrawing.ModelSpace.AddCircle(cc, i * 10) '画圆
Next i
End Sub
也许您还看不懂上面的代码,这没有关系,只要能把同心画出来就可以了,祝您成功。
第二课 编程基础
本课主要任务是对上一课的例程进行详细分析
下面是源码:
Sub c100()
Dim cc(0 To 2) As Double '声明坐标变量
cc(0) = 1000 '定义圆心座标
cc(1) = 1000
cc(2) = 0
For i = 1 To 1000 Step 10 '开始循环
Call ThisDrawing.ModelSpace.AddCircle(cc, i * 10) '画圆
Next i
End Sub
先看第一行和最后一行:
Sub C100()
……
End Sub
C100是宏的名称,也叫过程名称,当用户执行C100时程序将运行sub 和end sub之间的所有指令。
第二行:
Dim cc(0 To 2) As Double '声明坐标变量
后半段“'声明坐标变量”自动变为绿色字体,它是代码语句的注释,它不会影响程序运行,它的作用是告诉阅读者程序员的想法。对于简单的程序,一般不需要写注释,如果要编写非常复杂的程序,最好要多加注释,越详细越好,对于程序员来说,这是一个好习惯。
电脑真正编译执行的是这条语句:Dim cc(0 To 2) As Double
它的作用就是声明变量。
Dim是一条语句,可以理解为计算机指令。
它的语法:Dim变量名 As 数据类型
本例中变量名为CC,而括号中的0 to 2声明这个CC是一个数组,这个数组有三个元素:CC(0)、CC(1)、CC(2),如果改为CC(1 to 3),则三个元素是CC(1)、CC(2)、CC(3),有了这个数组,就可以把坐标数值放到这个变量之中。
Double是数据类型中的一种。ACAD中一般需要定义坐标时就用这个数据类型。在ACAD中数据类型的有很多,下面两个是比较常用的数据类型,初学者要有所理解。
Long(长整型),其范围从 -2,147,483,648 到 2,147,483,647。
Variant 它是那些没被显式声明为其他类型变量的数据类型,可以理解为一种通用的数据类型,这是最常用的。
下面三条语句
cc(0) = 1000 '定义圆心座标
cc(1) = 1000
cc(2) = 0
它们的作用是给CC变量的每一个元素赋,值其顺序是X、Y、Z坐标。

For i = 1 To 1000 Step 10 '开始循环
……
Next i '结束循环
这两条语句的作用是循环运行指令,每循环一次,i值要增加10,当i加到 1000时,结束循环。
i也是一个变量,虽然没有声明i变量,程序还是认可的,VB不是C语言,每用一个变量都要声明,不声明就会报错。简单是简单了,这样做也有坏处,如果不小心打错了一个字母,程序不会报错,如果程序很长,那就会出现一些意想不到的错误。
step后面的数值就是每次循环时增加的数值,step后也可以用负值。
例如:For i =1000 To 1 Step -10
很多情况下,后面可以不加step 10
如:For i=1 to 100,它的作用是每循环一次i值就增加1
Next i语句必须出现在需要结束循环的位置,不然程序没法运行。
下面看画圆命令:
Call ThisDrawing.ModelSpace.AddCircle(cc, i * 10)
Call语句的作用是调用其他过程或者方法。
ThisDrawing.ModelSpace是指当前CAD文档的模型空间
AddCircle是画圆方法
Addcicle方法需要两个参数:圆心和半径
CC就是圆心坐标,i*10就是圆的半径,本例中,这些圆的半径分别是10、110、210、310……
本课到此结束,下面请完成一道思考题:
1.以(4,2)为圆心,画5个同心圆,其半径为1-5
第三课 编程基础二
绘制三维多段线时X、Y值在屏幕上用鼠标选取,Z值用键盘输入
本课将讲解这个问题。
为了简化程序,这里用多条直线来代替多段线。以下是源码:
Sub myl()
Dim p1 As Variant '申明端点坐标
Dim p2 As Variant
p1 = ThisDrawing.Utility.GetPoint(, "输入点:") '获取点坐标
z = ThisDrawing.Utility.GetReal("Z坐标:") '用户输入Z坐标值
p1(2) = z '将Z坐标值赋予点坐标中
On Error GoTo Err_Control '出错陷井
Do '开始循环
p2 = ThisDrawing.Utility.GetPoint(p1, vbCr & "输入下一点:") '获取下一个点的坐标
z = ThisDrawing.Utility.GetReal("Z坐标:") '用户输入Z坐标值
p2(2) = z '将Z坐标值赋予点坐标中
Call ThisDrawing.ModelSpace.AddLine(p1, p2) '画直线
p1 = p2 '将第二点的端点保存为下一条直线的第一个端点坐标
Loop
Err_Control:
End Sub
先谈一下本程序的设计思路:
1、获取第一点坐标
2、输入第一点Z坐标
3、获取第二点坐标
4、输入第二点Z坐标
5、以第一、二点为端点,画直线
6、下一条线的第一点=这条线的第二点
7、回到第3步进行循环
如果用户没有输入坐标或Z值,则程序结束。
首先看以下两条语句:
p1 = ThisDrawing.Utility.GetPoint(, "输入点:") ‘获取点坐标
……
p2 = ThisDrawing.Utility.GetPoint(p1, vbCr & "输入下一点:") '获取下一个点的坐标
这两条语句的作用是由用户输入点用鼠标选取点坐标,并把坐标值赋给p1、p2两个变量。ThisDrawing.Utility.GetPoint()在ACAD中这是最常用的方法之一,它需要两个参数,在逗号前面的参数应该是一个点坐标,它的作用是在屏幕上画一条线,前一个端点位于点坐标位置,后一个端点跟随鼠标移动,逗号之前可以什么都不填,这时没有线条会跟随鼠标移动,但逗号必须保留。
逗号后面使用一串字符,程序在命令行显示这串字符,这不难理解。
VbCr通常代表一个回车符,而在这个语句中,它的作用是在命令行不显示“命令:”
&的作用是连接字符。举例:
“爱我中华 ”&”抵制日货 ”&”从我做起”
z = ThisDrawing.Utility.GetReal("Z坐标:") '用户输入Z坐标值
由用户输入一个实数
On Error GoTo Err_Control '出错陷井
……
Err_Control:
On Error是出错陷井语句,在程序出错时将执行On Error 后面的语句
GoTo Err_contorl 是程序跳转语句,它的作用是在程序中寻找Err_control:,并执行这一行后面的语句,本例中Err_Control:后就是结束宏,所以只要出现错误,程序中止。
Do '开始循环
……
Loop ‘结束循环
这个循环就历害了,它会无休止地进行循环,好在本例中已经有了一个出错陷井,当用户输入回车时,由于程序没有得到点或坐标,程序出错,跳出循环,中止程序。如果要人为控制跳出循环,可以在代码中用Exit Do语句跳出循环。在For 变量 和Next 变量之间如果要跳出循环,那么只要在循环体内加一个Exit for 就可以跳出循环,关于这方面的例程以后会讲到。
Call ThisDrawing.ModelSpace.AddLine(p1, p2) '画直线
画直线方法也是很常用的,它的两个参数是点坐标变量
本课到此结束,请做思考题:
连续画圆,每次要求用户输入圆心、半径,当用户不再输入圆心或半径时程序才退出
第四课 程序的调试和保存
人非圣贤,孰能无过,初学者在编写复杂程序时往往会出现一些意想不到的错误,所以程序的调试显得尤为重要,随着学习的深入,以后我们需要经常进行程序调试。事实上,对于那些资深程序员来说,调试程序也是一项不可或缺的重要工作。
首先,在程序输入阶段,应该充分利用VBA编辑器的智能功能。当你在写代码时,输入一些字母后,编辑器可以自动列出合适的语句、对象、函数供你选择,可以用上下键选择,然后按TAB键(它位于“Q”键左边)确认。当输入一个回车符后程序会自动对这条语句进行分析,如果出现错误就会提示。
我们经常碰到的麻烦是程序的运行结果和预计的不一样,一般我会这样做:首先要想一想可能是哪一个变量有问题,然后去监视这个变量(或表达式),在程序合适的位置设置断点,这样可以使程序停下来看一看这个变量有没有按照我的设想在变化。下面我举一个简单的例子,先看源代码:
sub test()
for i=2 to 4 step 0.6
next i
end sub
这是一个非常简单的循环,每一次循环i便会增加0.6,当循环3次后i值就变为4.4,但问题是每一次循环时i值变为多少?
第一步:在菜单中选“调试”—“添加监视”,在表达试中填“i”,点击确定,这时你会看到临视窗口中会多一行。
第二步:把光标移到代码窗口中的“next i”行,按一下“F9”,于是每当程序运行到这里时就会暂停了。
好,一切就绪,请按F5执行程序,在监视窗口中C值立刻变为2,再按F5继续,C值为2.6,再按几次F5,直到程序结束,这样我们就成功监视了C值的变化。
第三步:在next i行再按一次F9,清除断点。监视的表达式的右键菜单选择“删除监视”。
另外,还可以用“逐语句”、“逐过程”、“运行到光标处”等方法进行调试,这些都在调试菜单中,操作比较简单,请读者自行领悟。
到目前为止,我们所做的工程都是“嵌入式工程”,它只是嵌入在当前的Autocad图形文件中, 以后打开这个文件时代码才会加载,如果别的dwg文件也要使用,那就需要把代码导出为.bas文件,供其他dwg文件导入。在VBA编辑器的“文件”菜单中有这两个功能,一试便知。
ACAD VBA还有一种工程叫“通用式工程”,只要进入ACAD就可以运行,程序可以在不同用户、不同的图形文件中共享,但是由于VBA功能太强,有时候会出现一些意想不到的事情,所以在学习阶段请暂时不要这样做。
本课结束,请做思考题;监视下列代码中的i和j的值,注意,此题虽然要监视2个变量,但是在代窗口中只要设置1个断点就足够了。
sub test()
for i=2 to 4 step 0.6
for j=-5 to 2 step 5.5
next j
next i
end sub
第五课 画函数曲线
先画一组下图抛物线。

下面是源码:
Sub myl()
Dim p(0 To 49) As Double '定义点坐标
Dim myl As Object '定义引用曲线对象变量
co = 15 '定义颜色
For a = 0.01 To 1 Step 0.02 '开始循环画抛物线
For i = -24 To 24 Step 2 '开始画多段线
j = i + 24 '确定数组元素
p(j) = i '横坐标
p(j + 1) = a * p(j) * p(j) / 10 '纵坐标
Next i '至此p(0)-p(40)所有元素已定义,结束循环
Set myl = ThisDrawing.ModelSpace.AddLightWeightPolyline(p) '画多段线
myl.Color = co '设置颜色属性
co = co + 1 '改变颜色,供下次定义曲线颜色
Next a
End sub
为了鼓励大家积极思考,从本课开始,我不再解释每一条语句的作用,只对以前没有提过的语句进行一些解释,也许你一时很难明白,建议用上一课提到的跟踪变量、添加断点的办法领悟每一条语句的作用。
在跟踪变量p时请在跟踪窗口中单击变量p前的+号,这样可以看清数组p中每一个元素的变化。
ACAD没有现成的画抛物线命令,我们只能用程序编写多段线画近似抛物线。理论上,抛物线的X值可以是无限小、无限大,这里取值范围在正负24之间。
程序第二行:Dim myl As Object '定义引用曲线对象变量
Object也是一种变量类型,它可以把变量定义为对象,本例中myl变量将引用多段线,所以要定义为Objet类型。
看画多段线命令:
Set myl = ThisDrawing.ModelSpace.AddLightWeightPolyline(p) '画多段线
其中括号中的p是一个数组,这个数组的元素数必须是偶数,每两个元数作为一个点坐标。
等号前面部分“Set myl”的作用就将myl变量去引用画好的多段线。
myl.Color = co '设置颜色属性。在ACAD中,颜色可以用数字表示,本例中co会增值,这样就会有五彩缤纷的效果。
本课第二张图:正弦曲线,下面是源码:
Sub sinl()
Dim p(0 To 719) As Double '定义点坐标
For i = 0 To 718 Step 2 '开始画多段线
p(i) = i * 2 * 3.1415926535897 / 360 '横坐标
p(i + 1) = 2 * Sin(p(i)) '纵坐标
Next i
ThisDrawing.ModelSpace.AddLightWeightPolyline (p) '画多段线
ZoomExtents '显示整个图形
End Sub

p(i) = i * 2 * 3.1415926535897 / 360 '横坐标
横坐标表示角度,后面表达式的作用是把角度转化弧度
ZoomExtents语句是缩放命令,它的作用是显示整个图形,消除图形以外的区域
本课思考题:画一条抛物线:y=0.5*x*x+3,其中X取值范围在正负50之间
第六课 数据类型的转换
上一节课我们用一个简单的公式把角度转化为弧度,这样做便于大家理解。不过VBA中有现成的方法可以转换数据类型。
我们举例说明:
jd = ThisDrawing.Utility.AngleToReal(30, 0)
这个表达式把角度30度转化为弧度,结果是.523598775598299。
AngleToReal需要两个参数,前面是表示要转换角度的数字,而后面一个参数可以取值为0-4之间的整数,有如下意义:
0:十进制角度;1:度分秒格式;2:梯度;3:弧度;4:测地单位
例:id= ThisDrawing.Utility.AngleToReal("62d30' 10""", 1)
这个表达式计算62度30分10秒的弧度
再看将字符串转换为实数的方法:DistanceToReal
需要两个参数,前一个参数是表示数值的字符串,后面可以取值1-5,表示数据格式,有如下意义:
1:科学计数;2:十进制;3:工程计数——英尺加英寸;4:建筑计数——英尺加分数英寸;5:分数格式。
例:以下表达式得到一个12.5的实数
temp1 = ThisDrawing.Utility.DistanceToReal("1.25E+01", 1)
temp2 = ThisDrawing.Utility.DistanceToReal("12.5", 2)
temp3 = ThisDrawing.Utility.DistanceToReal("12 1/2", 5)
而realtostring方法正好相反,它把一个实数转换为字符串。它需要3个参数
第一个参数是一个实数,第二个参数表示数据格式,含义同上,最后一个参数表示精确到几位小数。
temp1= ThisDrawing.Utility.RealToString(12.5, 1, 3)
得到这个字符串:“1.250E+01”,
下面介绍一些数型转换函数:
Cint,获得一个整数,例:Cint(3.14159) ,得到3
Cvar,获得一个Variant类型的数值,例:Cvar("123" & "00"),得到”12300”
Cdate,转换为date数据类型,例:MyShortTime = CDate("11:13:14 AM")
下面的代码可以写出一串数字,从000-099。
Sub test()
Dim add0 As String
Dim text As String
Dim p(0 To 2) As Double
p(1) = 0 'Y坐标为0
p(2) = 0 'Z坐标为0
For i = 0 To 99 '开始循环
If i < 10 Then '如果小于10
add0 = "00" '需要加00
Else '否则
add0 = "0" '需要加0
End If
text = add0 & CStr(i) '加零,并转换数据
p(0) = i * 100 'X坐标
Call ThisDrawing.ModelSpace.AddText(text, p, 4) '写字
Next i

End Sub

重点解释条件判断语句:
If 条件表达式 Then
……
Else
……
End if
如果满足条件那么程序往下执行,到else时不再往下执行,直接跳到End if后面
如果不满足条件,程序跳到else后往下运行。
Call ThisDrawing.ModelSpace.AddText(text, p, 4) '写字
这是写单行文本,需要三个参数,分别是:写的内容、位置、字高
第七课 写文字
客观地说,ACAD写字功能不够历害,而用VBA可以使写字效率更高。比较正规的做法是把定义文字样式,用样式来控制文字的特性。我们还是用实例来学习,先看下面一段代码,它的作用是先创建一个文字样式,然后用这个文字样式写一段多行文本。
Sub txt()
Dim mytxt As AcadTextStyle '定义mytxt变量为文本样式
Dim p(0 To 2) As Double '定义坐标变量
p(0) = 100: p(1) = 100: p(2) = 0 '坐标赋值
Set mytxt = ThisDrawing.TextStyles.Add("mytxt") '添加mytxt样式
mytxt.fontFile = "c:\windows\fonts\simfang.ttf" '设置字体文件为仿宋体
mytxt.Height = 100 '字高
mytxt.Width = 0.8 '宽高比
mytxt.ObliqueAngle = ThisDrawing.Utility.AngleToReal(3, 0) '倾斜角度(需转为弧度)

ThisDrawing.ActiveTextStyle = mytxt '将当前文字样式设置为mytxt
Set txtobj = ThisDrawing.ModelSpace.AddMText(p, 1400, "{做到老,学到老}\P" & "此心自光明正大,过人远矣")
txtobj.LineSpacingFactor = 2 '指定行间距
txtobj.AttachmentPoint = 3 '右对齐(1为左对齐,2为居中)
End Sub
我们看这条语句
Set mytxt = ThisDrawing.TextStyles.Add("mytxt")
添加文本样式并赋值给mytxt变量,只需要一个参数:文本样式名
fontfile、height、width、ObliqueAngle是文本样式最常用的属性
Call ThisDrawing.ModelSpace.AddMText(p, 1400, "{做到老,学到老}\P" & "此心自光明正大,过人远矣")
这条语句是写文本,需要三个参数。第一个参数p是坐标,1400是宽度,最后一个参数是文本内容,其中\p是一个回车符
扩大字符间距用\T数字,例:\T3abc,使文字abc的间距扩大3 部,n取值范围是0.75-3
在论坛中有一个经常被同好提及的问题:如何使用文字叠加。举例说明:123\S+0.12^-0.34
\S是格式字符,^是分隔符,前面的数字在上,后面的数字在下。
\C是颜色格式字符,C后面跟一个数字表示颜色
\A是对齐方式,\A0,\A1,\A2分别表示底部对齐、中间对齐和顶部对齐

够不够,不够的话给个邮箱,我再发给你一个pdf文件!

这个我可以给你。。
Dim acadApp As AcadApplication ’定义CAD
On Error Resume Next‘防出错
Set acadApp = GetObject(, "autocad.application")
If Err Then
Err.Clear
Set acadApp = CreateObject("autocad.application")
If Err Then
MsgBox ("不能运行CAD,请检查是否安装")
Exit Sub
End If
End If
acadApp.WindowState = acMax '最大化
Dim acadDoc As AcadDocument
acadApp.Documents.Open App.Path & "\dutou\dutou.dwg" ’打开一个图
Dim textlayer As AcadLayer '图层
Set textlayer = acadApp.ActiveDocument.Layers.Add("hanzhi")
textlayer.Color = acYellow
acadApp.ActiveDocument.ActiveLayer = textlayer

Dim styobj2 As AcadTextStyle ‘定义图层和字体
Set styobj2 = acadApp.ActiveDocument.TextStyles.Add("仿宋")
styobj2.fontFile = "C:\WINDOWS\FONTS\simfang.ttf"
acadApp.ActiveDocument.ActiveTextStyle = acadApp.ActiveDocument.TextStyles.Add("仿宋")

Dim drawn As AcadText '设计,这是插入文字
Dim drawnpoint(0 To 2) As Double
drawnpoint(0) = 134.7
drawnpoint(1) = 12.68
drawnpoint(2) = 0
Set drawn = acadApp.ActiveDocument.ModelSpace.AddText(txtsheji, drawnpoint, 1.5)

Dim dtk1 As AcadBlock '放入框头,这是插入一个块
Dim dtk1point(0 To 2) As Double
dtk1point(0) = 61
dtk1point(1) = 155
dtk1point(2) = 0
Set dtk1 = acadApp.ActiveDocument.ModelSpace.InsertBlock(dtk1point, App.Path & "\dutou\dutou_k1.dwg", 1, 1, 1, 0)

没做过,因为我没用几次CAD,我想和word,excel一样,看一对象也能明白好多,有自带的VBA部分的看一下。


帮忙编一个VB程序
设,你的成绩都存在一个二维数组里,这个数组的名字就叫“数组”,其第一维是学生,第二维是课程。Private Sub Form_Click()Dim 平均 As Integer Dim 成绩() As Single Dim 人数 As Integer Dim 科目数 As Integer Dim 合格 As Boolean '输入 Do n = Val(InputBox("请输入学生人数"))If n ...

如何使用VB编写一个简单的小程序?
在桌面上,鼠标左键双击程序,在打开的VB6主界面上,左边是工具菜单栏,单击标签按钮,在Form1窗口上,绘制出一Label1,然后在其属性窗口上改个名字,如Caption为第一数,如下图所示。接着,用同样的方法,在Form1窗口上绘制出第二数,并且在左边工具菜单栏,单击文本框按钮,并绘制出来。在文本框属性...

求一段VB 程序
Private Sub Command1_Click()Dim St As String If Command1.Caption = "开始" Then Form1.Cls Command1.Caption = "下一组"ReDim A(1, 1)Command2.Caption = "结束"End If Randomize M = M + 1 N = 1 Print "第"; M; "组";Do St = InputBox("第" + Str(M) + "组 第"...

用VB编写一个程序
Sub Main()Dim A(,) As Integer = {{1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, {1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, {1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, {1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, {1, 2, 3, 4, 5, 6, 7, 8, 9, 0}, {1, ...

VB 一段程序
你的输入是个字符串。而不是一个数值。这样第一个式子算出实际是 25\/2 而不是 7\/2,你用 CInt 函数先把数值转换为整数即可(浮点数用 CDbl)。而第二个式子由于字符串不可能有减法,而实际又是个数字,VB 把它当成数值计算了。注意:“+”可以用来做字符串连接,也可以做数值加法,如果你确定...

VB的一个程序,帮忙编一下,谢谢
Print Space(n - i) + String(2 * i - 1, S)Next i End Sub Private Sub Command2_Click()Dim S As String, i As Integer, n As Integer S = "*"n = InputBox("输入要打印的行数:")For i = n To 1 Step -1 Print Space(n - i) + String(n, S)Next i End Sub Pri...

用VB编写一个简单公式程序
x = Val(Text2.Text)p = x \/ n q = f(n) \/ (f(x) * f((n - x))) * p ^ x * (1 - p) ^ (n - x)Text3.Text = q End If End Sub Function f(n)Dim i As Long f = 1 For i = 1 To n f = f * i Next End Function 如有其它需要,请继续追问~~~...

请帮我编写一下这个vb的代码,谢谢大师了,我会一点点,但是这个对我这个新...
Private Sub Command1_Click()If Val(Text1) >= 120 And Val(Text1) <= 150 Then Text2.Text = "优秀"ElseIf Val(Text1) >= 110 And Val(Text1) <= 119 Then Text2.Text = "良好"ElseIf Val(Text1) >= 100 And Val(Text1) <= 109 Then Text2.Text = "中等"Else...

编一VB应用程序。要求如下:
如图片上所示添加控件 然后把下列代码直接粘过去就行了,其他什么都不用设置 Dim stu(1 To 20) As Integer, n As Integer Private Sub Command1_Click()Dim mx As Integer, mn As Integer Dim sum As Integer, avr As Single mx = 0: mn = 100 For i = 1 To 20 If mx < stu(i) ...

求人写一段vb代码 高分悬赏
t1 = """C:\\123.vbs""" & "78954"t2 = """C:\\123.vbs""" & "1"t3 = """C:\\123.vbs"""Print t1 Print t2 Print t3 X1 = InStr(UCase(t1), "VBS""")t11 = Mid(t1, X1 + 4, Len(t1) - X1)X2 = InStr(UCase(t2), "VBS""")t22 = Mid(t2, X2 + 4, Len(...

雷波县19750681446: 求一段vb二次开发cad的代码 -
征轰甘霖: Option Explicit Sub test() Dim ent As AcadEntity For Each ent In ThisDrawing.ModelSpace MsgBox ent.EntityName '采用循环,输出各个实体的实体名 Next MsgBox "共有" & ThisDrawing.ModelSpace.Count & "个实体!“" End Sub 具体需要什么属性,得你自己把握了.

雷波县19750681446: 怎样用VB对AutoCAD 进行二次开发?急!急!急! -
征轰甘霖: 最基本的首先你要在vb中加载autocad库,当然你要装了autocad,可以用vb控制建立cad文件,然后向cad文件中写数据.对于在CAD中建立直角坐标系,建议你看一下wcs对应的cad中的对象是哪一个,然后用vb调用建立wcs.下面是一个vb中...

雷波县19750681446: 谁能提供一段vb在CAD中绘制多段线的实例代码作参考! -
征轰甘霖: 多线段没画过, 线倒是画过,二话不说直接上代码你参考一下 绘制边框 Private Sub Command4_Click() Set acadDoc = acadApp.ActiveDocument link2 acadDoc.ActiveLayer = acadlay(0) With adoResWhile Not .EOFpt1(0) = !X: pt1(1) = !Y: pt1(...

雷波县19750681446: cad 怎么使用vb进行二次开发? -
征轰甘霖: 开发小插件用VBA,CAD自带. 二次开发大点的软件用VB. 语句都是差不多的,有VB基础学起来很快.

雷波县19750681446: 求vb对cad二次开发类似南方CASS展点和计算多边形面积代码!!!!! -
征轰甘霖: 这个你可以直接在cad中找出来,我用的cad2006以调出添加弧段代码,步骤如下:“帮助”-“其他资源”-“开发人员帮助”-“ActiveX and VBA Reference”-“Object Model”-“Arc”-“AddArc”-“Example”即可打开vba代码,楼主可以根据自己需要自己进行代码修改,我也只懂点皮毛,希望对楼主有帮助,呵呵,共同探讨,一起进步!

雷波县19750681446: cad二次开发(用VB) -
征轰甘霖: 你是要程序代码呢,还是只要一个思路? 其实问题不难,但编程画图不比直接画,会很繁琐,初学者不太熟练的话花上几天时间才能编出来. 建议你还是自己动手,学会基本的函数,按直接画的画法一笔一笔来,学会一个以后的就都简单了.

雷波县19750681446: 怎样通过VB调用并操作AUTOCAD所绘 -
征轰甘霖: CAD直接就支持VBA的在CAD里 按下 ALT+F8建 就可以用VB写程序了你想获得CAD里的图形 很简单Dim Entry For Each Entry In ThisDrawing.ModelSpaceMsgbox TypeName(Entry)Next Entry就会依次显示CAD里所绘制的所有图元的类型,比如(圆啊,直线啊,什么的...)

雷波县19750681446: VB对autocad二次开发工程怎么建 -
征轰甘霖: Dim a As Double a = ThisDrawing.Utility.GetReal(vbCrLf + "输入一个数:")你说的是这个意思吗?随意输入一个参数,然后保存到变量里面.

雷波县19750681446: CAD利用VB编程来解决问题 -
征轰甘霖: 额,慢慢学吧.不过学CAD的二次开发,建议还是起点高些好.一般有几种模式二次开发:1,autolisp,你学VB的,这个就免了把.2,利用cad里面的vba,这个好像比较适合你.3,跨平台开发,利用.NET二次开发,比较酷毙的那种,com托管,大型计算方面慢.4,objectarx,这个语言可以对cad进行深层次的开发.比如添加命令等,而且运行速度快.用VB.NET就可以采用这种模式进行开发.建议你直接从objectarx入手,专心2个月就OK了.

雷波县19750681446: 在vb中二次开发cad画直线后 怎样标注啊,哪位大哥给个代码,谢谢了 -
征轰甘霖: RetVal = object.AddDimAligned(ExtLine1Point, ExtLine2Point, TextPosition) Object ModelSpace Collection, PaperSpace Collection, Block The object or objects this method applies to.ExtLine1Point Variant (three-element array of doubles); input-...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网