基于Solidworks的产品BOM生成系统开发毕业设计论文.docx

上传人:b****0 文档编号:12749052 上传时间:2023-04-21 格式:DOCX 页数:48 大小:814.30KB
下载 相关 举报
基于Solidworks的产品BOM生成系统开发毕业设计论文.docx_第1页
第1页 / 共48页
基于Solidworks的产品BOM生成系统开发毕业设计论文.docx_第2页
第2页 / 共48页
基于Solidworks的产品BOM生成系统开发毕业设计论文.docx_第3页
第3页 / 共48页
基于Solidworks的产品BOM生成系统开发毕业设计论文.docx_第4页
第4页 / 共48页
基于Solidworks的产品BOM生成系统开发毕业设计论文.docx_第5页
第5页 / 共48页
点击查看更多>>
下载资源
资源描述

基于Solidworks的产品BOM生成系统开发毕业设计论文.docx

《基于Solidworks的产品BOM生成系统开发毕业设计论文.docx》由会员分享,可在线阅读,更多相关《基于Solidworks的产品BOM生成系统开发毕业设计论文.docx(48页珍藏版)》请在冰豆网上搜索。

基于Solidworks的产品BOM生成系统开发毕业设计论文.docx

基于Solidworks的产品BOM生成系统开发毕业设计论文

 

南阳理工学院

本科生毕业设计(论文)

 

学院(系):

机电工程系

专业:

机械设计制造及其自动化

 

南阳理工学院本科生毕业设计(论文)

 

基于Solidworks的产品BOM生成系统开发

DevelopmentofProduct’sBOMGeneratingSystem

BasedonSolidworks

总计:

31页

表格:

2个

插图:

32幅

 

南阳理工学院本科毕业设计(论文)

 

基于Solidworks的产品BOM生成系统开发

DevelopmentofProduct’sBOMGeneratingSystem

BasedonSolidworks

 

学院(系):

机电工程系

专业:

机械设计及其自动化

学生姓名:

xxxxxx

学号:

94107024

指导教师(职称):

陈永辉(讲师)

评阅教师:

王志奎(教授)

完成日期:

2011年5月

南阳理工学院

NanyangInstituteofTechnology

基于Solidworks的产品BOM生成系统开发

机械设计制造及其自动化专业马倩

【摘要】产品物料明细(BOM)整理和生成是产品研发的重要环节之一,是企业物料采购、生产计划和成本核算的基础。

目前,多数企业对图纸BOM的生成仍处于手工操作模式,效率底,容易遗漏出错。

而对于复杂产品BOM的生成通常需要设计人员花费大量的时间和精力才能完成,严重影响了新产品研发的效率。

本课题以VB为开发平台语言,以Access为数据库存储平台,结合ADO数据库接口技术和VBA技术。

针对Solidworks三维设计软件的二次开发技术进行研究,通过配置符合企业标准的工程图图框、标题栏和明细栏格式,通过调用Solidworks支持的API函数,实现对SolidWorks工程图纸信息的快速准确提取,能够自动构建产品装配结构及其明细。

同时也能为企业后期的PDM和ERP系统集成提供数据接口。

软件实现的功能符合设计任务书预期要求,运行结果达到预期目的。

【关键词】Solidworks;数据库;产品明细;应用程序接口

DevelopmentofProduct’sBOMGeneratingSystem

BasedonSolidworks

MechanicalDesign,ManufacturingandAutomationMajorMaQian

Abstract:

CollectingandgeneratingBOMofproductisanimportantpartinproductdevelopment.Atthesametime,itisthebaseofmaterialspurchasing,productplanningandcostaccounting.Atpresent,thegenerationofdrawingsBOMisstillbyhandinmostenterprises,whichnotonlyhaslowefficiency,butalsoiseasytomakeerrors.ForthegenerationofcomplexproductBOM,designersoftenneedtospendalotoftimeandefforttofinishit,whichhasseriouslyaffectedtheefficiencyofnewproductdevelopment.

ThispaperadaptsVBasthedevelopmentplatformlanguage,usesAccessasthedatabasestorageplatform,combinesADOdatabaseinterfacetechnologyandVBAtechnology.BymeansofstudyingthesecondarydevelopmenttechnologyofSolidworks,settingthetemplateofSolidworksdrawingsframe,titlepanelandBOM,andcallingtheAPIfunctionssupportedbySolidworks,thissoftwarecanachieveextractionofSolidWorksdrawinginformationfastlyandaccurateandalsobeabletoautomaticallybuildtheproductassemblyBOM.Instead,ItcanprovidebasicdatafortheintegrationofPDMandERPinfuture.

Thefunctionachievedthesystemcanmeetexceptedrequirementofdesignassignmentanditsrunningresultsrealizeintendedpurpose.

Keywords:

Solidworks;database;BOM;API

1研究背景和意义

Solidworks是一套基于Windows的CAD/CAE/CAM/PD桌面集成系统,是由美国Solidworks公司在总结和继承了大型机械CAD软件的基础上,在Windows环境下实现的第一个机械三维CAD软件,于1995年11月研制成功。

它集成了设计、分析、加工和数据管理的整个过程,所获得的分析和加工模拟成果成为产品模型的属性,在Solidworks的特征管理器中清晰地列出了详细的数据信息。

它还可以动态模拟装配过程,进行静态干涉检查、计算质量特征,如质心、惯性矩等。

它将2D绘图与3D造型技术融为一体,能自动地生成零部件尺寸、材料明细表(BOM)、具有指引线的零部件编号等技术资料,从而简化了工程图样的生成过程。

同时有中英文两种界面可供选择,其先进的特征树结构使操作更加简便和直观。

具有较好的开发性接口和功能扩广性。

能轻松实现各种CAD软件之间的数据转换传送。

Solidworks是一种非常优秀的三维机械软件,其易学易用、全中文界面等特点使广大工程技术人员爱不释手。

目前Solidworks是市场分额增长最快、技术发展最快、市场前景最好、性能价格比最优的软件。

在全球的销量已经达20万套,排名处于3DCAD软件销售榜首,遥遥领先于其他同类产品。

但是Solidworks也并不是十全十美的,不可能完全满足特定企业的特殊要求。

例如,由于该软件是外国人写的,不适合中国的国际(如标题栏、明细表、放大图的标注、剖视图的标注、装配图的序号、标题栏等),也没有适合我国国际的标准件库。

因此,为了合适特定企业的特殊需求,形成企业自己的特色,使Solidworks在我国的企业中有效地发挥作用,并使常用的或重复的任务自动化,提高效率,就必须对其进行本体化和专业化的二次开发工作。

为了方便用户进行二次开发,Solidworks提供了几百个API(ApplicationProgramInterfce,应用程序接口)函数,这些API函数是Solidworks的OLE(ObjectLinkingandEmbedding,对象的嵌入与链接)或COM(ComponentObjectModel,组件对象模型)接口,用户可以使用VB\VBA\VC\Delpin等高级语言对Solidworks进行二次开发,建立适合用户需要的,专用的Solidworks功能模块【1】。

目前针对Solidworks软件,国内外企业面临着一个关键的问题,现在企业使用Solidworks软件出完工程图后,编制系统明细表(手工编制)是一项很复杂而麻烦的工作。

因此,研究如何将结构设计人员从该项任务中解脱出来是一项非常有价值的工作。

另外,随着企业信息化工程的实施,如果能够将Solidworks所产生的相关信息自动提取出来,导入到企业信息化系统中,实现无缝集成,将为企业的采购、生产、计划等相关的子系统提供有价值的信息,为实现全部信息无纸化办公铺平道路。

2课题研究内容及要求

采用VisualBasic对SolidWorks进行二次开发,实现了在SolidWorks工程图环境下明细栏的自动添加与调整,并能够将Solidworks所产生的相关信息自动提取出来,导入到企业信息化系统中。

以陆德公司的产品级配斗为实例,对于在参数化驱动之后重新生成的装配模型及工程图中,实现了根据零部件名称及数量等参数自动生成相对应的明细栏,并进行了一系列的优化与调整,解决了添加明细栏时工作繁琐,速度慢,出错多及难以用程序控制的缺点。

添加完明细栏后,生成国家标准工程图。

接着读取工程图中的自定义属性信息,然后采用ADO技术将读取的信息保存到Access数据库中。

具体提取方式主要采用了选择和遍历技术,逐个遍历工程图中零件自定义属性并进行统计后导入到相应的数据表中。

本课题在充分利用Solidworks的API函数基础上,以VB语言为开发平台,以Access为数据库,以excel报表模板,采用基于三层结构的C/S开发模式和ADO数据库访问技术开发出Solidworks明细表生成软件,实现了自动分析并提取由SolidWorks软件所设计的产品结构信息,自动构建正确的产品结构树,并能够导出为符合金蝶/K3ERP导入格式要求的电子表格文件。

软件实现功能:

1.自动读取SolidWorks设计信息并生成产品BOM;

2.自动分析SolidWorks零部件装配关系;

3.能够导出产品综合明细和分类明细;

4.导出符合企业格式要求的Excel文件。

3课题研究关键技术

3.1Solidworks的API接口

编制明细表所需要的信息全部存储于Solidworks三维图及相关的工程图中,如果利用开发工具能够调用Solidworks的API函数,直接就能够获得Solidworks明细表全部原始信息。

Solidworks本身也为用户进行二次开发提供全方位的接口函数。

为了方便用户进行二次开发,Solidworks提供了几百个API(ApplicationProgramInterfce,应用程序接口)函数,这些API函数是Solidworks的OLE(ObjectLinkingandEmbedding,对象的嵌入与链接)或COM(ComponentObjectModel,组件对象模型)接口。

接口是一个COM的术语,它包含了Solidworks中使用到的类。

Solidworks是使用面向对象技术设计的,在Solidworks之下是表示软件各个方面的对象模型。

为了将API暴露给使用其他编程语言的开发者,COM编程允许Solidworks将实际的Solidworks对象的函数功能暴露给外部世界。

COM编程已经超出了本书的涵盖范围,但是读者应该理解API是由一组接口组成的,这些接口被组织为接口对象模型(interfaceobjectmodel)。

一般来说将接口看作一个对象(object),这些词语意思相同[2]。

Solidworks支持OLE标准,完全实现了OLE自动化。

作为一个OLE服务器,Solidworks提供了大量的OLE对象,以及这些对象所拥有的方法、属性和事件,用户通过在应用程序中对这些OLE对象及其方法和属性的操作,可以在自己开发的应用软件中实现诸如生成直线、构造实体、检查曲面表面参数等几乎所有的Solidworks软件的功能。

SolidworksAPI对象模型如图3-1所示。

图3-1SolidworksAPI对象模型

使用SolidworksAPI进行开发时,每个对象中必须包含Solidworks2009Constanttypelibrary。

这个类型库包含了SolidworksAPI方法使用的所有常量定义。

实际运行中,传递给方法的是常量定义而不是他们所代表的实际数值。

这能保证程序在安装了新版本的Solidworks之后仍然能正常运行。

实际使用的数值可能因为版本不同而不同,但是常量定义是相同的,不会改变,只会添加。

使用VBA在Solidworks中录制宏时,会自动添加这个库。

要验证这一点,编辑任何一个在Solidworks2009中录制的宏,并从菜单中选择【工具】/【引用】。

弹出的【引用】对话框中显示了课题中已包含的类型库,如图3-2所示。

图3-2Solidworks2009ConstantTypeLibrary

用户可以使用VB\VBA\VC\Delpin等高级语言对Solidworks进行二次开发,建立适合用户需要的,专用的Solidworks功能模块。

3.2课题采用VisualBasic为开发语言

任何支持OLE和COM的编程语言都可以作为Solidworks的开发工具。

Solidworks二次开发有两种,一种是基于自动化技术的,另一种开发方式是基于COM的。

COM技术可以使用更多的SolidworksAPI,并可控制Solidworks运行的方式,生成*.dll格式的文件,也就是Solidworks的插件[3]。

现在开发工具比较多,比如VB、VC、C++、C#、Delphi等。

最最简单的二次开发工具是VBA,在涉及Excel时用VBA最为方便。

VBA常用于录制宏,得到基本程序框架。

易学易用的高级开发语言是VB,但功能有限。

功能强大的语言是VC,但是入门难。

Delphi集中了VB和VC两者的优点,学习过程中很容易上手,而且功能也非常强大,尤其在界面设计、数据库编程和网络编程方面更是独到之处。

遗憾的是Solidworks常常不支持Delphi+OLE[4]。

开发工具的选择主要考虑以下几个因素:

(1)对API函数接口的集成支持[5]。

(2)利用数据库存储因素。

(3)报表的实现。

综合考虑以上因素,选择VB语言作为开发工具,它在以上因素上都占有优势,尤其是充分发挥它在开发数据库的专长和完全控制Excel报表的灵活性上,是其他工具无法比拟的。

VisualBasic6.0是美国微软公司推出的Windows应用程序开发平台家族中的一员,它沿用了早期Basic语言的一些语法格式,是一个功能强大的应用程序开发工具[6]。

VisualBasic6.0是一种面向对象(ObjectOrientedProgramming,OOP)的程序设计方法,它强调直接以问题域(即现实世界)中的事物为中心来考虑和认识问题,并按照这些事物的本质特征把它们抽象为对象,作为软件系统的基础。

在OOP方法中,将对象作为系统中最基本的运行实体,对象中封装了描述该对象的特殊属性(数据)和行为方式(方法)。

整个程序即由各种不同类型的对象组成,各对象既是一个独立的实体,又可通过一定的方式相互作用[7]。

VisualBasic6.0易学易用、功能强大的特点使其得到了广泛的应用。

其强大的可视化用户界面设计,是程序员从复杂的界面设计中解脱出来,是编程成为一种享受。

VisualBasic6.0不但可以开发小型单机数据库管理系统,而且也可以开发集多种应用程序于一体的网络数据库系统。

因此使得它成为目前使用最广泛的编程语言之一。

3.3系统采用ADO数据库连接技术

当计算机从早期的计算工具逐步变化成现在的信息处理和管理工具时,它就和数据库建立了密切的关系。

在当今信息爆炸的时代,只有通过数据库并结合计算机的高速计算能力才可能实现对大量信息的及时处理和分析。

数据库技术作为当前一项衡量国家信息化程度的标准被大力推行,尤其在我国信息化刚刚起步的阶段,数据库更是被大力发展。

目前在我国从事信息事业的人员中有70%的人员从事着与数据库相关的工作。

由此可见数据库在我国的发展前景。

数据库系统主要有三大部分组成:

数据库管理系统(DBMS,专门负责组织和管理数据信息的程序)、数据库应用程序(它使我们能够获取、显示和更新由DBMS存储的数据)、数据库(按一定结构组织在一起的相关数据的集合)[8]。

随着DBMS技术的发展,目前的数据库系统正向着客户机/服务器模式发展。

客户机/服务器数据库将DBMS和数据库应用程序分开,从而提高了数据库系统的处理能力。

数据库应用程序运行在一个或多个用户工作站(客户机)上,并通过网络与运行在其它计算机上(服务器)的一个或多个DBMS进行通信。

常见的访问数据库的方法有使用ADO、DAO、RDO控件等。

目前,由于ADO具有灵活而又有效的访问数据库的方式,故成为比较常用的访问数据库的方法和手段[9]。

ADO(ActiveDataObject,活动数据对象)是一种基于COM(组件对象模型)的自动化接口(Idispatch)技术,是一个与编程语言无关的COM组件系统。

并以OLEDB(对象联接和镶入的数据库)为基础,经过OLEDB精心包装后的数据库访问技术,是数据访问对象DAO、远程数据对象RDO和开放数据库互联ODBC三种方式的扩展,利用它可以快速地创建数据应用程序。

ADO提供了一组非常简单并将一般通用的数据访问细节进行封装的对象,主要有三个对象成员:

Connection、Command和Recordset,以及几个集合对象:

parameters、Fields和Errors等,ADO对象模型如图3-3所示[10]。

图3-3ADO的对象模型

3.4产品BOM导出采用Excel格式

明细表有相应的国家标准,其报表的选择非常重要,所得到的报表结果将直接关系到软件最后使用的成败,所以选择得到广泛使用的Excel作为信息输出的格式。

采用Excel作为报表的输出工具,用户可以在已经定义好的模板基础上,使系统能直接在相关的地方插入信息。

这样的好处是:

Excel是最常用的办公软件,一般是装机必备工具;用户可以自定义模板;可以充分利用Excel强大的表格处理功能;可以允许用户调整输出的报表信息;以后可随时调出所生成的报表直接使用。

以陆德公司的产品级配斗为实例,通过使用Excel电子表格能够将Solidworks所产生的相关信息(各零部件之间相互关系及其代号(标准件号)、名称、数量、材料等属性信息)自动提取出来,导入到企业信息化系统中,实现无缝集成,将为企业的采购、生产、计划等相关的子系统提供有价值的信息,为实现全部信息无纸化办公铺平道路。

同时为企业的工作人员带来了快捷、高效的解决方案,解决了添加明细栏时工作繁琐,速度慢,出错多及难以用程序控制的缺点。

为此,对于本课题,我们设计了一个电子表格,此表格清晰地反映了零件的相关属性,如序号、代号、名称、材料、数量、单重、总重等信息。

电子表格界面如图3-4所示。

图3-4电子表格界面

4系统需求分析与总体设计

4.1需求分析

需求分析是指通过详细调查现实世界要处理的对象,明确用户的各种需求,达到确定新系统的功能的目的。

需求分析是数据库结构设计的第一阶段,也是非常重要的一个阶段。

在这个阶段主要是调查、收集与分析用户在数据管理中的信息要求、处理要求、安全性与完整性要求。

信息要求是指用户需要从数据库中获得信息的内容与性质。

由用户的信息要求可以导出数据要求,即在数据库中需要存储哪些数据。

处理要求是指用户要求完成什么处理功能,对处理的响应时间有什么要求,处理方式是批处理还是联机处理,得到系统所要处理数据的流程图。

系统的功能必须能够满足用户的信息要求、处理要求、安全性与完整性要求。

需求分析首先调查清楚用户的实际需求并进行初步分析,与用户达成共识后,再进一步分析与表达这些需求。

需求分析可分为问题分析、需求描述及需求评审三个阶段。

问题分析阶段,分析人员通过对问题及环境的理解、分析和综合,清除用户需求的模糊性、歧义性和不一致性。

需求描述阶段的任务是生成需求规格说明书和初步的用户手册。

需求评审阶段的任务是工作人员在用户和软件设计人员的配合下对生成的需求规格说明和用户手册进行复核,以确保软件需求的全面性、精确性和一致性。

对企业来说,构建产品结构树(明细)、进行图纸审核和生成产品综合明细及分类明细是产品研发的最后一环,也是多数企业信息化最薄弱的环节(均以手工完成),速度慢,效率低,容易出错,极大的影响了新产品研发的效率。

本课题实现了自动分析并提取由SolidWorks软件所设计的产品结构信息,自动构建正确的产品结构树,并能够导出为符合金蝶/K3ERP导入格式要求的电子表格文件。

4.2总体设计

利用SolidWorks出工程图,由于软件本身没有自带符合国标的工程图模板,给我们出工程图带来了不少的麻烦。

而且装配图上的明细栏的信息必须手动才可以输入到工程图中,这样给企业带来很多的麻烦。

我们采用VB程序编程自动生成符合我国标准的工程图。

从图4-1中可以看出,生成国际标准工程图和提取零件工程图自定义属性是整个设计过程的重要组成部分。

在提取BOM之前,需要把装配图中的相关信息转换到工程图中,形成国家标准的工程图。

在工程图中生成明细栏时,每个零件的相关属性都是要能与材料明细栏所对应的列进行自动链接的,目的是能够通过链接自动在明细栏对应位置写入相关属性。

为此,必须在零部件建模时设置其相关属性,其中与明细栏相关的属性包括重量、材料、序号、代号、名称、数量、比例等。

在读取零部件的自定义属性时,具体读取方式主要采用了选择和遍历技术,逐个遍历装配体模型中零件树的种类与个数并进行统计后写人文件。

需要注意的是,装配完成之后应该把装配模型中零件树的顺序按照明细栏的最后要求进行重新排列,目的是能够保证写入文件时记录的数据是按照明细栏的顺序排列的,减少排列出错的可能性。

在生成国际标准工程图的过程中,采用先根据企业的需求建立明细栏模板,再通过程序进行添加的方法来实现工程图中明细栏的添加。

由于它是在新的装配体零部件更名完成后进行这一系列的操作,因此就不会出现明细栏无法识别的情况;同时在模型参数化驱动完成后,通过相关程序统计部件中的零件数目,并存储在专门的文件或程序控件中,这样在通过程序初步添加明细栏以后写人相应零部件的数量、名称、材料、质量等属性,最后就可以在最终工程图中完成符合企业要求的明细栏的添加过程。

图4-1设计系统流程图

4.3结构设计

使用Windows操作系统、开发维护系统即VisualBasic软件系统、一套数据库系统Access2003即可。

它们之间的关系如图所示。

图4-2简单的应用系统

4.4功能模块设计

根据以上对陆德公司的企业现状和基于Solidworks的产品BOM生成系统的需求分析及目标设计,设计好数据库系统,然后开发应用程序可以考虑的窗体的系统,每一个窗体实现不同的功能,可以设计下面的几个模块。

(1)登录模块:

用来实现用户的登录等操作。

(2)用户账号密码修改模块:

用来实现用户密码的修改等操作。

(3)读取BOM模块:

用来读取级配斗工程图中自定义属性的信息等操作。

(4)产品BOM管理模块:

用来实现建立产品结构树,并把零件的信息读取到Listview中,最后导出产品明细,生成明细表等操作。

(5)帮助窗口模块

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 幼儿教育 > 幼儿读物

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1