Solidworks二次开发-05-装配体中插入零部件
发表于:2007-06-30来源:作者:点击数:
标签:
Solidworks二次 开发 --装配体中插入零部件 在往装配体中插入零部件时,我们使用addcomponent 函数。如果需要选定零部件的配置,则需要使用addcomponent4。 先学习下语法: addcomponent4: retval = AssemblyDoc.AddComponent4 ( compName, configName, x, y
Solidworks二次
开发--装配体中插入零部件
在往装配体中插入零部件时,我们使用addcomponent 函数。如果需要选定零部件的配置,则需要使用addcomponent4。
先学习下语法:
addcomponent4:
retval = AssemblyDoc.AddComponent4 ( compName, configName, x, y, z)
Input: (BSTR) compName Path name of a loaded part or assembly to add as a component
Input: (BSTR) configName Name of the configuration from which to load the component
Input: (double) x X coordinate of the component center
Input: (double) y Y coordinate of the component center
Input: (double) z Z coordinate of the component center
Output: (LPCOMPONENT2) retval Pointer to the Component2 object
需要注意的是:参数1为文件的全名(包括路径);参数2为文件的配置名称;当函数执行成功购返回一个指向该零件的指针。
于是我们可以如下写一个小程序,用来给装配体中插零件:
‘filename:insertPart.swp
‘write by
arden
2005-4-4
‘this function add a part called “零件1.SLDPRT” in CurrentWorkingDirectory
‘precondition is there has a part document called “零件1.SLDPRT” in CurrentWorkingDirectory
‘and it has a configuration called “配置1”
Dim swApp As SldWorks.SldWorks
Dim Model As ModelDoc2
Dim pth As String
Dim strpath As String
Sub insertPart()
Set swApp = Application.SldWorks
strpath = swApp.GetCurrentWorkingDirectory ‘当前工作路径
Set Model = swApp.ActiveDoc
pth = strpath & "零件1.SLDPRT" ‘得到文件的FULLPATH全名
Model.AddComponent4 pth, "配置1", 0, 0, 0 ‘添加零部件
End Sub
然而,这个程序比不是想象中那么好用。为什么呢??回头看addcomponent4的remark,上面这样写:
The specified file must be loaded in memory. A file is loaded into memory when you load the file in your
SolidWorks session (SldWorks::OpenDoc6) or open an assembly that a
lready contains the file.
就是说你想指定的插入的文件必须在调用函数之前已经在内存中加载了。
不习惯,你就不能直接打开多简单,没办法,我还没有找到好的方法,只能按人家的来:
看看下面的函数Opendoc6,它打开一个文档:
Opendoc6:
retval = SldWorks.OpenDoc6 ( filename, type, options, configuration, &Errors, &Warnings )
Input: (BSTR) Filename Document name or full path if not in current directory, including extension
Input: (long) Type Document type as defined in swDocumentTypes_e
Input: (long) Options Mode in which to open the document as defined in swOpenDocOptions_e
Input: (BSTR) Configuration Model configuration in which to open this document:
Applies to parts and assemblies, not drawings
If this argument is empty or the specified configuration is not present in the model,
the model is opened in the last-used configuration.
Output: (long) Errors Load errors as defined in swFileLoadError_e
Output: (long) Warnings Warnings or extra information generated during the open operation as defined in swFileLoadWarning_e
Return: (LPDISPATCH) retval Pointer to a Dispatch object, the newly loaded ModelDoc2, or NULL if failed to open
这个函数参数1就是文档的全名,参数2是要插入的类型描述,其中0123分别表示:
0 swDocNONE:不是sw文件
1 swDocPART:零件
2 swDocASSEMBLY:装配体
3 swDocDRAWING:工程图
如果想使用swDocNONE,需要定义:
Public Enum swDocumentTypes_e
}--> }-->swDocNONE = 0
}--> }-->swDocPART= 1
}--> }-->swDocASSEMBLY = 2
swDocDRAWING=3
End Enum
参数3是打开文档的模式,一般我们就选择swOpenDocOptions_Silent 用0 表示,当然还有只读、只看等选项
参数4是打开选项,一般置空
后面是两个OutPut,用来显示错误打开时的提示
函数返回一个指向打开文件的指针。
按照上面的要求我们在向装配体中插入一个零部件时,需要这样步骤:
1、得到装配体
2、使用opendoc6打开需要插入的零件
3、使用addcomponent4插入零件到装配体
我们上面的程序需要这样来修改一下,添加了一个打开文档的函数:
@# ******************************************************************************
@# insertpart 03/21/05 by
arden
@#插入零件1
@#前提条件:在装配体所在文件夹中有零件“零件1”存在,并且零件1有配置“配置1”
@# ******************************************************************************
Dim swApp As SldWorks.SldWorks
Dim Model As ModelDoc2
Dim YSBmodel As ModelDoc2
Dim pth As String
Dim strpath As String
Dim nErrors As Long
Dim nWarnings As Long
Sub insertpart()
Set swApp = Application.SldWorks
strpath = swApp.GetCurrentWorkingDirectory
Set Model = swApp.ActiveDoc
pth = strpath & "零件1.SLDPRT"
openYSB (pth) ‘在添加零部件之前,先打开它
Model.AddComponent4 pth, "配置1", 0, 0, 0
End Sub
@#这个函数打开零件1
Sub openpart(ByVal pth As String)
Dim path As String
Dim newswapp As SldWorks.SldWorks
Set newswapp = Application.SldWorks
path = pth
Set YSBmodel = newswapp.OpenDoc6(path, 1, swOpenDocOPtions_Silent, "", nErrors, nWarnings)
YSBmodel.Visible = False ‘我不想看到零件1
End Sub
这样的做法我感觉比较笨~为了赶工程进度我没有再去寻找好的方法,如果您知道有好的方法请告知我,万分感谢。
原文转自:http://www.ltesting.net