几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » SolidWorks二次开发
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


 
 
主题工具 搜索本主题 显示模式
旧 2009-04-12, 10:34 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】sw2009 api sldworks.activatedoc290 causes background sw to become visible

sw2009 api sldworks.activatedoc2() causes background sw to become visible
hello,
my vb.net program is running sw in the background, no problem initially, as sw stay invisible while it opens some files and outputs .dxf, .pdf versions ,etc.
...but then when the activatedoc2(....) method is called on an assembly, all of a sudden sw becomes visible in the backgound.
i have used
sldworks.usercontrol = false
sldworks.visible = false
...right at the beginning of my code, and sw does stay invisible for quite a good portion of the processing, but when the activatedoc2 () method is called to activate an assembly, sw suddenly makes itself visible?
code below:
imports solidworks.interop.sldworks
imports solidworks.interop.swconst
imports solidworks.interop.swpublished
imports solidworks.interop.swconst.swuserpreferenceintegervalue_e
imports solidworks.interop.swconst.swdocumenttypes_e
imports solidworks.interop.swconst.swopendocoptions_e
imports solidworks.interop.swconst.swsaveasoptions_e
imports solidworks.interop.swconst.swloadexternalreferences_e
imports solidworks.interop.swconst.swpromptalwaysnever_e
imports solidworks.interop.swconst.swuserpreferencetoggle_e
imports system
imports system.io
module module1
dim app as sldworks
dim log as streamwriter
sub main(byval cmdargs() as string)
dim model as modeldoc2
dim filename as string
dim topmodel as modeldoc2
dim errs as long
dim warns as long
dim retval as long
dim argnum as integer
dim logname as string = "c:\swexport.log"
if file.exists(logname) then
file.delete(logname)
end if
log = file.createtext(logname)
if cmdargs.length < 1 then
console.writeline("usage: swexport filename")
log.writeline("swexportfailure")
log.close()
exit sub
end if
' app = new sldworks
app = createobject("sldworks.application")
dim ret as boolean
' set user preferences.
ret = app.setuserpreferenceintegervalue(swloadexternalreferences, swloadexternalreferences_none)
ret = app.setuserpreferenceintegervalue(swperformanceassemrebuildonload, swresponsenever)
ret = app.setuserpreferenceintegervalue(swlargeasmmodeautoactivate, swresponsenever)
app.setuserpreferencetoggle(swedrawingsokaytomeasure, true)
'app = createobject("sldworks.application", "dbremne0d10eng.eng.emc.com")
'app = getobject("sldworks.application")
app.usercontrol = false
app.visible = false
app.loadaddin("c:\program files\bluebeam software\pushbutton pdf\solidworkslt\bbsldwkspdflt.dll")
'console.writeline("attempted to load pdf addin. status " + retval.tostring)
filename = cmdargs(0)
dim blankstring as string = string.empty
' determine document type based on file extension.
dim fileext as string
dim doctype as long
fileext = right(filename, 6)
select case fileext
case "sldprt"
doctype = swdocpart
case "sldasm"
doctype = swdocassembly
case "slddrw"
doctype = swdocdrawing
end select
' open document.
log.writeline("opening " + filename)
log.flush()
console.writeline("opening " + filename)
model = app.opendoc6( _
filename, _
doctype, _
swopendocoptions_silent, _
blankstring, _
errs, _
warns _
)
if model is nothing then
log.writeline("unable to open " + filename)
log.flush()
console.writeline("unable to open " + filename)
log.writeline("swexportfailure")
log.close()
cleanup()
exit sub
end if
log.writeline("opened " + filename)
log.flush()
topmodel = model
' export the document to the appropriate format.
exportdoc(model)
' if the document is a drawing, export the models associated with each
' view of each sheet.
if doctype = swdocdrawing then
exportdrwrefs(model)
end if
log.writeline("swexportsuccess")
log.close()
' release memory.
' app.quitdoc(topmodel.gettitle)
app.closealldocuments(true)
topmodel = nothing
cleanup()
end sub
sub exportdoc(byval model as modeldoc2)
dim doctype as long = model.gettype
dim errs as long
app.usercontrol = false
app.visible = false
app.activatedoc2(model.gettitle, true, errs) ' activate model
app.usercontrol = false
app.visible = false
' export appropriate files.
select case doctype
case swdocpart
exportmodel(model, "step")
'exportmodel(model, "igs")
exportmodel(model, "stl")
exportmodel(model, "eprt")
case swdocassembly
exportmodel(model, "step")
exportmodel(model, "easm")
'exportmodel(model, "igs")
case swdocdrawing
exportmodel(model, "pdf")
exportmodel(model, "dxf")
exportmodel(model, "edrw")
end select
end sub
sub exportmodel(byval model as modeldoc2, byval format as string)
dim spathroot as string
dim spathname as string
dim retval as boolean
dim errs as long
dim warns as long
spathroot = model.getpathname ' get path and file name
spathroot = left(spathroot, len(spathroot) - 6) ' strip file extension
spathname = spathroot + format ' add new file extension
log.writeline("writing " + spathname)
log.flush()
console.writeline("writing " + spathname)
' export model.
retval = model.saveas4( _
spathname, _
0, _
swsaveasoptions_silent, _
errs, _
warns _
)
log.writeline("status " + retval.tostring)
log.flush()
console.writeline("status " + retval.tostring)
end sub
sub exportdrwrefs(byval model as modeldoc2)
model.visible = false
' collect the models referenced by this drawing.
dim drwrefs as new hashtable
dim drawing as drawingdoc = model
dim sheetnames as object = drawing.getsheetnames
dim i as integer
for i = 0 to ubound(sheetnames) ' traverse drawing sheets
drawing.activatesheet(sheetnames(i))
dim view as solidworks.interop.sldworks.view
view = drawing.getfirstview
while not view is nothing ' traverse sheet views
model = view.referenceddocument ' get model referenced by view
if not model is nothing then
console.writeline("found drawing model " + model.gettitle + _
" in " + view.name)
' add models to hash to get unique file names.
if not drwrefs.containskey(model.gettitle) then
drwrefs.add(model.gettitle, model)
end if
end if
view = view.getnextview
end while
next
' export drawing references.
dim enumerator as idictionaryenumerator = drwrefs.getenumerator()
while enumerator.movenext()
exportdoc(enumerator.value)
end while
end sub
sub cleanup()
app.exitapp()
app = nothing
gc.collect()
end sub
end module
quick
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
 


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭

相似的主题
主题 主题发起者 论坛 回复 最后发表
【转帖】newbee question on adding components w sw api yang686526 SolidWorks二次开发 0 2009-04-12 09:54 PM
【转帖】外挂开发中的封包技术 huangyhg vc编程 0 2007-12-03 04:41 PM
there are three terrible questions on SW translator as below huangyhg SolidWorks二次开发 3 2007-09-04 01:38 PM
How to start SW 2007 or SW 20006 via SW API? If I have two different versions of SW yogy SolidWorks二次开发 1 2007-05-21 09:19 AM
【转帖】对于hook函数的一点认识 huangyhg vc编程 0 2007-03-27 11:53 AM


所有的时间均为北京时间。 现在的时间是 12:42 PM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多