欢迎来到沃文网! | 帮助中心 分享知识,传播智慧!
沃文网
全部分类
  • 教学课件>
  • 医学资料>
  • 技术资料>
  • 学术论文>
  • 资格考试>
  • 建筑施工>
  • 实用文档>
  • 其他资料>
  • ImageVerifierCode 换一换
    首页 沃文网 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

    测控系统应用软件实训——产品质量监测系统设计.doc

    • 资源ID:837109       资源大小:1.26MB        全文页数:26页
    • 资源格式: DOC        下载积分:20积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: QQ登录 微博登录
    二维码
    微信扫一扫登录
    下载资源需要20积分
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,下载更划算!
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    测控系统应用软件实训——产品质量监测系统设计.doc

    1、武汉理工大学测控系统应用软件实训课程设计说明书目录1. 绪论 42. 整体模块设计 4 3. 代码管理模块 53.1类型代码管理 53.2功率代码管理 54. 检测模块 65. 4.1开始检测 64.2停止检测 85.查询模块 95.1结果查询 9 5.2工位查询 196.数据表浏览模块 207.数据修改模块 228.打印报表模块 249.帮助模块 2510.总结与体会 2711.参考文献 281.绪论 自工业革命以来,人类已经越来越意识到机器性工作的可代替性是多么的重要。也正是由于这一点,自动化制造业得到了飞速的发展,到如今已经达到一个非常成熟的形态。而作为当代一名当代的中国大学生,尤其是像

    2、我们这样的与制造业有关的工科专业学生,在这样的时代大潮中自然不能落于人后。在自身专业知识学习过程中要全力以赴,抓住任何机会充实自己。而恰好学校安排了测控系统软件设计这一课程让我们学习和锻炼,更要珍惜这样的机会。主题是制作一个质量检测软件,利用日光灯试验台来检测点亮日光灯的整流器或逆变器是否合格,并且通过多次测量灯管两端的电压和电流,再通过分析,来验证整流器或逆变器工作是否正常。单个整流器或逆变器有不同功率之分,也有可以同时点亮日光灯个数多少之分。检测一个整流器或逆变器,下位机大概会产生30组左右的电压和电流数据。总结之,本实训的目标是设计一个产品质量监测系统,保存日光灯试验台下位机产生的数据信

    3、息,并时行产品合格检查、产品质量查询、分类统计和报表打印操作,以期使产品的质量管理工作系统化、规范化、自动化,从而体现自动化制造业带来的高效率和收益。产品质量监测系统安全管理模块 代码管理模块检测模块查询模块打印预览模块密码与权限管理退出系统类型代码功率代码开始检测停止检测结果查询工位查询数据表浏览模块数据修改模块2.整体模块设计图1 程序总体设计结构图3. 代码管理模块3.1类型代码管理(1)程序代码void _fastcall TF_Main:M_TypeClick(TObject *Sender) /类型代码编辑 F_Assist-ADOT_Count-First();/设定记录号计数数

    4、据表当前活动记录是第一条记录 F_Assist-ADOT_Count-MoveBy(2);/下移两条记录至计数表中的仪器类型 F_Assist-DBLookupListBox1-ListField=;/先赋空值以免系统抛出异常 F_Assist-DBLookupListBox1-KeyField=;/先赋空值以免系统抛出异常 F_Assist-DBLookupListBox1-ListSource=DataModule1-DS_Type;/赋仪器类型表 F_Assist-DBLookupListBox1-KeyField=Type_ID;/赋类型记录号字段 F_Assist-DBLookupL

    5、istBox1-ListField=Type_Name;/赋类型名称字段 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-ADOT_Count-Edit();

    6、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-DBLookupListBox1-KeyField=;/先赋空值以免系统抛出异常 F_Assist-DBLookupListBox1-ListSource=Data

    7、Module1-DS_Power;/赋仪器功率代码表 F_Assist-DBLookupListBox1-KeyField=Power_ID;/赋功率记录号字段 F_Assist-DBLookupListBox1-ListField=Power_Name;/赋功率名称字段 F_Assist-Label2-Caption=仪器功率代码表; F_Assist-Show(); /打开辅助资料窗体(2)运行结果图3 仪器功率代码界面4.检测模块4.1开始检测(1)流程图图4 流程图(2)程序代码void _fastcall Ttcw:M_StartClick(TObject *Sender) /打开串

    8、口,开启JudgeTimer定时器定时测控串口 MainMenu-Items-Items2-Enabled=false;/使开始检测菜单项非能 MainMenu-Items-Items3-Enabled=True;/停止检测菜单项使能 if(Com1-PortOpen=True)/如果串口已打开,则关闭之 Com1-PortOpen=false; Com1-PortOpen=True; /打开串口 Com1-InBufferCount=0;/消除输入缓冲区的内容 Com1-OutBufferCount=0;/消除输出缓冲区的内容 if(!Com1-PortOpen) /判断串口初始化是否失败并

    9、显示 ShowMessage(串口初始化失败); JudgeTimer-Enabled=true; /开启串口监听定时器 RE_Mess-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;/开始检测菜单项使能 Main

    10、Menu-Items-Items3-Enabled=false;/停止检测菜单项非能 JudgeTimer-Enabled=false; /关闭串口监听定时器 Com1-PortOpen=false; /关闭串口 RE_Mess-Lines-Add(串口已关闭,与下位机通信中断);/在RichEdit控件显示串口状态(2)运行结果图6 停止检测后界面5.查询模块5.1结果查询(1)程序代码以及对应程序结果#include #pragma hdrstop#include Query.h#include DM.h/-#pragma package(smart_init)#pragma resour

    11、ce *.dfmTF_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-Enabled= true ; / RadioButton2-Enabled= true ; / RadioButton3-Enabled= true

    12、 ; / else /否则,各单选按钮处于失效状态 RadioButton1-Enabled= false ; / RadioButton2-Enabled= false ; / RadioButton3-Enabled= false; / /-void _fastcall TF_Query:CB_CodeClick(TObject *Sender)/判断编号查询复选框是否被选中 if(CB_Code-Checked) M_Code-Enabled=true ;/memo控件被激活 Label2-Enabled=true;/标签控件被激活 else /memo与标签控件失效 M_Code-En

    13、abled=false; Label2-Enabled=false; /-图7 时间设定查询界面图8时间设定查询结果/-void _fastcall TF_Query:CB_TypeClick(TObject *Sender) /判断类型查询是否选中 if(CB_Type-Checked) E_Type-Enabled=true; else E_Type-Enabled=false;图9按类型查询界面图10类型查询结果void _fastcall TF_Query:CB_PowerClick(TObject *Sender)/判断功率查询是否选中 if(CB_Power-Checked) E_

    14、Power-Enabled=true; else E_Power-Enabled=false;/-图11按功率查询界面图12功率查询结果void _fastcall TF_Query:CB_NumClick(TObject *Sender) /判断管数查询是否选中 if(CB_Num-Checked) E_Num-Enabled=true; UpDown-Enabled=true; else E_Num-Enabled=false; UpDown-Enabled=false; 图13 按管数查询界面图14 按管数查询结果void _fastcall TF_Query:B_CancelClick

    15、(TObject *Sender) DataModule1-AQ_Record-Close();/关闭检测记录数据源 DataModule1-AQ_Record-SQL-Clear();/清除SQL语句 DataModule1-AQ_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_Recor

    16、d,Industry_Data); DataModule1-AQ_Record-Open();/执行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_Code-Checked) /若没有查询条件

    17、Application-MessageBoxA(没有查询条件,请选择或输入,查询出错,MB_OKCANCEL); return; String str1=Industry_Record.Record_Type= + E_Type-Text + , str2=Record_Type= + E_Type-Text + , str3=Industry_Record.Record_Power= + E_Power-Text + , str4=Record_Power= + E_Power-Text + ; DataModule1-AQ_Record-Close();/关闭检测记录数据源 DataMod

    18、ule1-AQ_Record-SQL-Clear();/清除SQL语句 DataModule1-AQ_Record-SQL-Add(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_Rec

    19、ord.Record_SNumber=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); /timel1、2,timer1、2是在SQL语句中自定义的变量 if(RadioButto

    20、n1-Checked) /当天查询 DataModule1-AQ_Record-Parameters-ParamByName(timel1)-Value= StrToDateTime(DateToStr(Now()+ 00:00:00); DataModule1-AQ_Record-Parameters-ParamByName(timel2)-Value= StrToDateTime(DateToStr(Now()+ 23:59:59); DataModule1-AQ_Data-Parameters-ParamByName(timer1)-Value= StrToDateTime(DateTo

    21、Str(Now()+ 00:00:00); DataModule1-AQ_Data-Parameters-ParamByName(timer2)-Value= StrToDateTime(DateToStr(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(

    22、)取得今天是一周内的第几天,再进行当前星期一的日期推算 DataModule1-AQ_Record-Parameters-ParamByName(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(timer1)-Value= StrToDat

    23、eTime(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,&j,&k);/提取当前的年月日,分别存入变量i,j,k DataModule1-AQ_Record-Parameters-ParamByName(timel1)-Value= St

    24、rToDateTime(IntToStr(i)+-+IntToStr(j)+-01 00:00:00); DataModule1-AQ_Record-Parameters-ParamByName(timel2)-Value= StrToDateTime(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-P

    25、aramByName(timer2)-Value= StrToDateTime(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); DataModule1-AQ_Data-SQL-Add(str2); /功率查询 if

    26、(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_Record-SQL-Add(str3); DataModule1-AQ_Data-SQL-Add(str4); /编号查询 if(CB_Code-Checked) if(M_Code-Text.IsEmpty() /如果无编号 Appl

    27、ication-MessageBoxA(请输入编号,查询出错,MB_OK); M_Code-SetFocus();/焦点至编号输入框 return; if(CB_Time-Checked|CB_Type-Checked|CB_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(); /可

    28、能包含多个编号,需用括号括起来 for(int i=0;iLines-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-AQ_Data-SQL-Add(Format(Data_SNumber=%s%s%s, ARRAYOFCONST(,M_Code-Lines-Stringsi,);

    29、 /利用format函数进行参数赋值 if(i!=M_Code-Lines-Count-1) DataModule1-AQ_Record-SQL-Add( OR ); DataModule1-AQ_Data-SQL-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-C

    30、hecked) /如果前面已经添加了其他查询,则需要加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)-Value=E_Num-Text; DataModule1-AQ_Data-SQL-Add( Record_LNumber=:lightr1); Da

    31、taModule1-AQ_Data-Parameters-ParamByName(lightr1)-Value=E_Num-Text; DataModule1-AQ_Record-Open();/执行SQL语句,打开检测记录表 DataModule1-AQ_Data-Open();/执行SQL语句,打开检测数据表 Close();/关闭查询窗口 DataModule1-AQ_RecordRecord_Date-DisplayFormat=yyyy-mm-dd; /定义检测记录表中检测日期显示格式 (TDateTimeField *)(DataModule1-AQ_Data-FieldByNam

    32、e(Record_Date)-DisplayFormat=yyyy-mm-dd; /定义检测数据表中检测日期显示格式(2) 运行结果分析:经过实际操作发现各个功能均正常,并且各函数对应的功能划分比较清晰。5.2工位查询(1)程序代码void _fastcall TF_Main:M_LabNumberClick(TObject *Sender) /对指定工位的检测装置进行数据获取 F_LabNo-ShowModal();/打开工位号输入窗口? if(F_LabNo-ModalResult=mrOk) /如果窗体操作结果是用户确定按钮 /通过串口发送用户所要获取的指定工位的请求数据 char bu

    33、ff4; buff0=0x02; buff1=0x70+F_LabNo-E_Num-Text.ToInt(); buff2=0x03; buff3=0x31; SendData(StrPas(buff); /在状态栏显示 RE_Mess-Lines-Add(F_LabNo-E_Num-Text+号工位查询请求已发送); (2)运行结果图17 程序工位查询界面图18 工位号查询结果6.数据表浏览模块(1)程序代码#include #pragma hdrstop#include Data.h#include DM.h#include Print.h/-#pragma package(smart_i

    34、nit)#pragma resource *.dfmTF_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_Data:BB_ConfirmClick(TObjec

    35、t *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 _fastcall TF_Data:BB_QuitClick(TObject *Sender) F_

    36、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 TF_Data:BitBtn3Click(TObject *Sender) DataModule1-AT_Data-Append() ;/追加检测数据表的数据?void _fastcall TF_Data:BitBtn4Cli


    注意事项

    本文(测控系统应用软件实训——产品质量监测系统设计.doc)为本站会员(精***)主动上传,沃文网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知沃文网(点击联系客服),我们立即给予删除!




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服点击这里,给沃文网发消息,QQ:2622162128 - 联系我们

    版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

    Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1

    陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922