武汉理工大学c课程设计报告书_第1页
武汉理工大学c课程设计报告书_第2页
武汉理工大学c课程设计报告书_第3页
武汉理工大学c课程设计报告书_第4页
武汉理工大学c课程设计报告书_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、武汉理工大学测控系统应用软件实训课程设计说明书课程设计任务书学生姓名: 李文瑶 专业班级: 测控1103班 指导教师: 胡剑 韩雪 工作单位: 机电学院测控系 题 目: 测控系统应用软件实训产品质量监测系统设计 初始条件:日光灯试验台是用来检测点亮日光灯的整流器或逆变器是否合格的装置,通过多次测量灯管两端的电压和电流,再通过分析,来验证整流器或逆变器工作是否正常。单个整流器或逆变器有不同功率之分,也有可以同时点亮日光灯个数多少之分。检测一个整流器或逆变器,下位机大概会产生30组左右的电压和电流数据。本实训的目标是设计一个产品质量监测系统,保存日光灯试验台下位机产生的数据信息,并时行产品合格检查

2、、产品质量查询、分类统计和报表打印操作,以期使产品的质量管理工作系统化、规范化、自动化,从而提高生产效率。设计功能要求:1、仪器检测结果的输入,包括记录号、检修日期、仪器编号、仪器类型、仪器功率、仪器点亮日光灯个数、检测人员、检测记录。除检测人员和检测记录由工作人员在计算机上直接输入外,其他项都通过串口读入。2、仪器检测数据的输入,包括记录号、仪器编号、检测电压、检测电流。一条仪器检测结果对应多条检测数据。3、仪器检测数据以图形方式显示变化趋势。4、仪器检测信息的查询、修改和删除。5、仪器类型和功率代码管理。6、仪器检测信息的报表和打印处理。(选做)7、密码和权限管理,不同权限用户具有不同的操

3、作权力。(选做)系统功能模块设计:对上述各项功能进行集中分块,按结构化程序设计的要求,得到如图1所示的系统功能模块图。要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)1.合理进行数据库设计,数据项和数据结构包括以下部分: 1)仪器检测结果信息表,保存检测结果记录,包括:记录号、检测日期、仪器编号、仪器类型、仪器功率、仪器额定点亮日光灯个数、仪器温升、检测时间间隔、检测人员、检测记录。 2)仪器检测数据信息表,保存检测数据记录,包括:记录号、仪器编号、检测电压、检测电流。 3)仪器类型信息表:记录号、仪器类型。 4)仪器功率信息表:记录号、仪器功率。 5)记录号

4、计数数据表,用于保存其他表格所需的记录号,包括:记录号名称、记录号计数值。 6) 用户信息表:工号、用户名、密码、权限。(选用)图1 系统功能模块图2.进行相应的功能模块设计,包括: 1)串口通信设计;(学习) 2)数据模块设计; 3)系统主窗体设计; 4)检测数据分析设计; 5)检测结果查询设计; 6)报表打印设计;(选做) 7) 安全管理设计。(选做)3.设计并绘制各个模块与函数的软件流程图,流程图要模块化并具有可读性(根据流程图知道程序功能实现过程);编制模块化源程序; 4.编写并调试完整的程序代码 (所有自定义的单元文件名、控件名、函数名、变量名不能与示例程序同名); 5. 按学校课程

5、设计说明书撰写规范提交一份课程设计说明书(6000字左右),设计说明书应详细说明设计思路、工作流程和软件设计与实现界面。时间安排: 序 号 内 容所 用 时 间1布置课程设计任务,查阅资料,总体方案设计1天2设计软件流程图1天3数据库设计1天4软件编写4天5撰写设计说明书2天6答辩1天 合 计10天指导教师签名: 年 月 日系主任(或责任教师)签名: 年 月 日目录1. 绪论 42. 整体模块设计 4 3. 代码管理模块 53.1类型代码管理 53.2功率代码管理 54. 检测模块 65. 4.1开始检测 64.2停止检测 85.查询模块 95.1结果查询 9 5.2工位查询 196.数据表浏

6、览模块 207.数据修改模块 228.打印报表模块 249.帮助模块 2510.总结与体会 2711.参考文献 281.绪论 自工业革命以来,人类已经越来越意识到机器性工作的可代替性是多么的重要。也正是由于这一点,自动化制造业得到了飞速的发展,到如今已经达到一个非常成熟的形态。而作为当代一名当代的中国大学生,尤其是像我们这样的与制造业有关的工科专业学生,在这样的时代大潮中自然不能落于人后。在自身专业知识学习过程中要全力以赴,抓住任何机会充实自己。而恰好学校安排了测控系统软件设计这一课程让我们学习和锻炼,更要珍惜这样的机会。主题是制作一个质量检测软件,利用日光灯试验台来检测点亮日光灯的整流器或逆

7、变器是否合格,并且通过多次测量灯管两端的电压和电流,再通过分析,来验证整流器或逆变器工作是否正常。单个整流器或逆变器有不同功率之分,也有可以同时点亮日光灯个数多少之分。检测一个整流器或逆变器,下位机大概会产生30组左右的电压和电流数据。总结之,本实训的目标是设计一个产品质量监测系统,保存日光灯试验台下位机产生的数据信息,并时行产品合格检查、产品质量查询、分类统计和报表打印操作,以期使产品的质量管理工作系统化、规范化、自动化,从而体现自动化制造业带来的高效率和收益。产品质量监测系统安全管理模块 代码管理模块检测模块查询模块打印预览模块密码与权限管理退出系统类型代码功率代码开始检测停止检测结果查询

8、工位查询数据表浏览模块数据修改模块2.整体模块设计图1 程序总体设计结构图3. 代码管理模块3.1类型代码管理(1)程序代码void _fastcall tf_main:m_typeclick(tobject *sender) /类型代码编辑 f_assist->adot_count->first();/设定记录号计数数据表当前活动记录是第一条记录 f_assist->adot_count->moveby(2);/下移两条记录至计数表中的仪器类型 f_assist->dblookuplistbox1->listfield=""/先赋空值以

9、免系统抛出异常 f_assist->dblookuplistbox1->keyfield=""/先赋空值以免系统抛出异常 f_assist->dblookuplistbox1->listsource=datamodule1->ds_type;/赋仪器类型表 f_assist->dblookuplistbox1->keyfield="type_id"/赋类型记录号字段 f_assist->dblookuplistbox1->listfield="type_name"/赋类型名称字段

10、f_assist->label2->caption="仪器类型代码表" f_assist->showmodal(); /打开辅助资料窗体 (2)运行结果图2 仪器类型代码界面3.2功率代码管理(1)程序代码void _fastcall ttcw:m_powerclick(tobject *sender) x=2; f_assist->adot_count->tablename="industry_power"/功率代码编辑 f_assist->adot_count->open(); f_assist->ad

11、ot_count->edit(); datamodule1->at_power->open(); datamodule1->at_power->edit(); f_assist->adot_count->first();/设定记录号计数数据表当前活动记录是第一条记录 f_assist->adot_count->moveby(2);/下移两条记录至计数表中的仪器功率 f_assist->dblookuplistbox1->listfield=""/先赋空值以免系统抛出异常 f_assist->dblook

12、uplistbox1->keyfield=""/先赋空值以免系统抛出异常 f_assist->dblookuplistbox1->listsource=datamodule1->ds_power;/赋仪器功率代码表 f_assist->dblookuplistbox1->keyfield="power_id"/赋功率记录号字段 f_assist->dblookuplistbox1->listfield="power_name"/赋功率名称字段 f_assist->label2-&g

13、t;caption="仪器功率代码表" f_assist->show(); /打开辅助资料窗体(2)运行结果图3 仪器功率代码界面4.检测模块4.1开始检测(1)流程图图4 流程图(2)程序代码void _fastcall ttcw:m_startclick(tobject *sender) /打开串口,开启judgetimer定时器定时测控串口 mainmenu->items->items2->enabled=false;/使开始检测菜单项非能 mainmenu->items->items3->enabled=true;/停止检测

14、菜单项使能 if(com1->portopen=true)/如果串口已打开,则关闭之 com1->portopen=false; com1->portopen=true; /打开串口 com1->inbuffercount=0;/消除输入缓冲区的内容 com1->outbuffercount=0;/消除输出缓冲区的内容 if(!com1->portopen) /判断串口初始化是否失败并显示 showmessage("串口初始化失败"); judgetimer->enabled=true; /开启串口监听定时器 re_mess->

15、;lines->add("串口初始化成功,正在监听");/在richedit控件显示串口状态 re_mess->lines->add("用户可以开始检测数据");(3)运行结果图5 开始检测后界面4.2停止检测(1)程序代码void _fastcall ttcw:m_pauseclick(tobject *sender)/关闭串口,关闭judgetimer定时器定时测控串口 mainmenu->items->items2->enabled=true;/开始检测菜单项使能 mainmenu->items->i

16、tems3->enabled=false;/停止检测菜单项非能 judgetimer->enabled=false; /关闭串口监听定时器 com1->portopen=false; /关闭串口 re_mess->lines->add("串口已关闭,与下位机通信中断");/在richedit控件显示串口状态(2)运行结果图6 停止检测后界面5.查询模块5.1结果查询(1)程序代码以及对应程序结果#include <vcl.h>#pragma hdrstop#include "query.h"#include &q

17、uot;dm.h"/-#pragma package(smart_init)#pragma resource "*.dfm"tf_query *f_query;/-_fastcall tf_query:tf_query(tcomponent* owner) : tform(owner)/-void _fastcall tf_query:cb_timeclick(tobject *sender) /判断时间查询复选框是否选中,以决定各单选按钮是否能使用 if(cb_time->checked) /若时间框选中,则各单选按钮被激活 radiobutton1-&g

18、t;enabled= true ; / radiobutton2->enabled= true ; / radiobutton3->enabled= true ; / else /否则,各单选按钮处于失效状态 radiobutton1->enabled= false ; / radiobutton2->enabled= false ; / radiobutton3->enabled= false; / /-void _fastcall tf_query:cb_codeclick(tobject *sender)/判断编号查询复选框是否被选中 if(cb_code-

19、>checked) m_code->enabled=true ;/memo控件被激活 label2->enabled=true;/标签控件被激活 else /memo与标签控件失效 m_code->enabled=false; label2->enabled=false; /-图7 时间设定查询界面图8时间设定查询结果/-void _fastcall tf_query:cb_typeclick(tobject *sender) /判断类型查询是否选中 if(cb_type->checked) e_type->enabled=true; else e_t

20、ype->enabled=false;图9按类型查询界面图10类型查询结果void _fastcall tf_query:cb_powerclick(tobject *sender)/判断功率查询是否选中 if(cb_power->checked) e_power->enabled=true; else e_power->enabled=false;/-图11按功率查询界面图12功率查询结果void _fastcall tf_query:cb_numclick(tobject *sender) /判断管数查询是否选中 if(cb_num->checked) e_n

21、um->enabled=true; updown->enabled=true; else e_num->enabled=false; updown->enabled=false; 图13 按管数查询界面图14 按管数查询结果void _fastcall tf_query:b_cancelclick(tobject *sender) datamodule1->aq_record->close();/关闭检测记录数据源 datamodule1->aq_record->sql->clear();/清除sql语句 datamodule1->a

22、q_record->sql->add("select * from industry_record"); datamodule1->aq_data->close();/关闭检测数据数据源 datamodule1->aq_data->sql->clear();/清除sql语句 datamodule1->aq_data->sql->add("select * from industry_record,industry_data"); datamodule1->aq_record->ope

23、n();/执行sql语句,打开检测记录表 datamodule1->aq_data->open();/执行sql语句,打开检测数据表 f_query->close();/关闭检测数据查看窗口/- void _fastcall tf_query:b_queryclick(tobject *sender)/查询按钮单击事件 if(!cb_time->checked&&!cb_type->checked&&!cb_power->checked &&!cb_num->checked&&!cb_co

24、de->checked) /若没有查询条件 application->messageboxa("没有查询条件,请选择或输入","查询出错",mb_okcancel); return; string str1="industry_record.record_type='" + e_type->text + "'", str2="record_type='" + e_type->text + "'", str3="

25、industry_record.record_power='" + e_power->text + "'", str4="record_power='" + e_power->text + "'" datamodule1->aq_record->close();/关闭检测记录数据源 datamodule1->aq_record->sql->clear();/清除sql语句 datamodule1->aq_record->sql->ad

26、d("select * from industry_record where "); /增加一条sql语句,从检测记录表中提取数据记录 datamodule1->aq_data->close();/关闭检测数据数据源 datamodule1->aq_data->sql->clear();/清除sql语句 datamodule1->aq_data->sql->add("select * from industry_record,industry_data where industry_record.record_snu

27、mber=industry_data.data_snumber and "); /增加一条sql语句,从检测记录表、检测数据表中提取数据记录 /时间查询 if(cb_time->checked) datamodule1->aq_record->sql->add(" record_date between :timel1 and :timel2"); datamodule1->aq_data->sql->add(" record_date between :timer1 and :timer2"); /t

28、imel1、2,timer1、2是在sql语句中自定义的变量 if(radiobutton1->checked) /当天查询 datamodule1->aq_record->parameters->parambyname("timel1")->value= strtodatetime(datetostr(now()+" 00:00:00"); datamodule1->aq_record->parameters->parambyname("timel2")->value= strt

29、odatetime(datetostr(now()+" 23:59:59"); datamodule1->aq_data->parameters->parambyname("timer1")->value= strtodatetime(datetostr(now()+" 00:00:00"); datamodule1->aq_data->parameters->parambyname("timer2")->value= strtodatetime(datetostr(

30、now()+" 23:59:59"); if(radiobutton2->checked) /本周查询 tdatetime *dt=new tdatetime(); *dt=now(); int convert=0,6,0,1,2,3,4,5;/国内外一周的起止不一样 tdatetime monday=dt->operator-(convertdt->dayofweek(); /dayofweek()取得今天是一周内的第几天,再进行当前星期一的日期推算 datamodule1->aq_record->parameters->paramby

31、name("timel1")->value= strtodatetime(datetostr(monday)+" 00:00:00"); datamodule1->aq_record->parameters->parambyname("timel2")->value= strtodatetime(datetostr(now()+" 23:59:59"); datamodule1->aq_data->parameters->parambyname("timer

32、1")->value= strtodatetime(datetostr(monday)+" 00:00:00"); datamodule1->aq_data->parameters->parambyname("timer2")->value= strtodatetime(datetostr(now()+" 23:59:59"); if(radiobutton3->checked) /本月查询 unsigned short i,j,k; now().decodedate(&i,&am

33、p;j,&k);/提取当前的年月日,分别存入变量i,j,k datamodule1->aq_record->parameters->parambyname("timel1")->value= strtodatetime(inttostr(i)+'-'+inttostr(j)+"-01 00:00:00"); datamodule1->aq_record->parameters->parambyname("timel2")->value= strtodatetime

34、(datetostr(now()+" 23:59:59"); datamodule1->aq_data->parameters->parambyname("timer1")->value= strtodatetime(inttostr(i)+'-'+inttostr(j)+"-01 00:00:00"); datamodule1->aq_data->parameters->parambyname("timer2")->value= strtodatet

35、ime(datetostr(now()+" 23:59:59"); /类型查询 if(cb_type->checked) if(cb_time->checked) /如果前面已经添加了时间查询,则需要加and条件同时成立运算符 datamodule1->aq_record->sql->add(" and "); datamodule1->aq_data->sql->add(" and "); datamodule1->aq_record->sql->add(str1);

36、 datamodule1->aq_data->sql->add(str2); /功率查询 if(cb_power->checked) if(cb_time->checked|cb_type->checked) /如果前面已经添加了时间查询或类型查询,则需要加and条件同时成立运算符 datamodule1->aq_record->sql->add(" and "); datamodule1->aq_data->sql->add(" and "); datamodule1->aq

37、_record->sql->add(str3); datamodule1->aq_data->sql->add(str4); /编号查询 if(cb_code->checked) if(m_code->text.isempty() /如果无编号 application->messageboxa("请输入编号","查询出错",mb_ok); m_code->setfocus();/焦点至编号输入框 return; if(cb_time->checked|cb_type->checked|cb

38、_power->checked) /如果前面已经添加了其他查询,则需要加and条件同时成立运算符 datamodule1->aq_record->sql->add(" and "); datamodule1->aq_data->sql->add(" and "); datamodule1->aq_record->sql->add("("); datamodule1->aq_data->sql->add("("); /可能包含多个编号,需用

39、括号括起来 for(int i=0;i<m_code->lines->count;i+) if(m_code->lines->stringsi.isempty()continue; datamodule1->aq_record->sql->add(format("record_snumber='%s%s%s'", arrayofconst("",m_code->lines->stringsi,""); /利用format函数进行参数赋值 datamodule1

40、->aq_data->sql->add(format("data_snumber='%s%s%s'", arrayofconst("",m_code->lines->stringsi,""); /利用format函数进行参数赋值 if(i!=m_code->lines->count-1) datamodule1->aq_record->sql->add(" or "); datamodule1->aq_data->sql->

41、;add(" or "); else datamodule1->aq_record->sql->add(" )"); datamodule1->aq_data->sql->add(" ) "); 图15多编号查询界面图16 多编号查询结果 /管数查询 if(cb_num->checked) if(cb_time->checked|cb_type->checked|cb_power->checked|cb_code->checked) /如果前面已经添加了其他查询,则需要

42、加and条件同时成立运算符 datamodule1->aq_record->sql->add(" and "); datamodule1->aq_data->sql->add(" and "); datamodule1->aq_record->sql->add(" record_lnumber=:lightl1"); datamodule1->aq_record->parameters->parambyname("lightl1")->v

43、alue=e_num->text; datamodule1->aq_data->sql->add(" record_lnumber=:lightr1"); datamodule1->aq_data->parameters->parambyname("lightr1")->value=e_num->text; datamodule1->aq_record->open();/执行sql语句,打开检测记录表 datamodule1->aq_data->open();/执行sql语句,

44、打开检测数据表 close();/关闭查询窗口 datamodule1->aq_recordrecord_date->displayformat="yyyy-mm-dd" /定义检测记录表中检测日期显示格式 (tdatetimefield *)(datamodule1->aq_data->fieldbyname("record_date")->displayformat="yyyy-mm-dd" /定义检测数据表中检测日期显示格式(2) 运行结果分析:经过实际操作发现各个功能均正常,并且各函数对应的功能划

45、分比较清晰。5.2工位查询(1)程序代码void _fastcall tf_main:m_labnumberclick(tobject *sender) /对指定工位的检测装置进行数据获取 f_labno->showmodal();/打开工位号输入窗口? if(f_labno->modalresult=mrok) /如果窗体操作结果是用户确定按钮 /通过串口发送用户所要获取的指定工位的请求数据 char buff4; buff0=0x02; buff1=0x70+f_labno->e_num->text.toint(); buff2=0x03; buff3=0x31;

46、senddata(strpas(buff); /在状态栏显示 re_mess->lines->add(f_labno->e_num->text+"号工位查询请求已发送"); (2)运行结果图17 程序工位查询界面图18 工位号查询结果6.数据表浏览模块(1)程序代码#include <vcl.h>#pragma hdrstop#include "data.h"#include "dm.h"#include "print.h"/-#pragma package(smart_init

47、)#pragma resource "*.dfm"tf_data *f_data;/-_fastcall tf_data:tf_data(tcomponent* owner) : tform(owner)/-void _fastcall tf_data:formcreate(tobject *sender) /窗体创建事件 datamodule1->ds_data->enabled=true; /检测数据表使能 datamodule1->ds_record->enabled=true;/? /检测记录表使能/-void _fastcall tf_da

48、ta:bb_confirmclick(tobject *sender) datamodule1->aq_record->post();/递交检测记录表数据 ?/-void _fastcall tf_data:bb_cancelclick(tobject *sender) datamodule1->aq_record->cancel();/取消检测记录表数据更新?/-void _fastcall tf_data:bb_printclick(tobject *sender)f_print->quickrep1->preview() ;/显示报表预览?void _

49、fastcall tf_data:bb_quitclick(tobject *sender) f_data->close();/关闭检测数据查看窗体 ?void _fastcall tf_data:bitbtn1click(tobject *sender) datamodule1->at_data->post() ;/递交检测数据表的数据更新?void _fastcall tf_data:bitbtn2click(tobject *sender) datamodule1->at_data->cancel();/取消检测数据表的数据更新?void _fastcall

50、 tf_data:bitbtn3click(tobject *sender) datamodule1->at_data->append() ;/追加检测数据表的数据?void _fastcall tf_data:bitbtn4click(tobject *sender) datamodule1->at_data-> delete();/删除检测数据表中的一条记录 (2)运行结果图19 检测数据查看界面7.数据修改模块(1)程序代码void _fastcall ttcw:bitbtn3click(tobject *sender)/增加检测记录表中的一条记录,数据输入完后,点”提交“增加,点”取消“则不增加 datamodule1->aq_record->append();/使检测记录表进入追加记录状态void _fastcall ttcw:bitbtn4click(tobject *sender)/删除检测记录表中的一条记录,需同时删除检测数据表中的对应的记录 int record_no; datamodule1->at_data->open(); record_no=datamodule1->

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论