欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    基于WSN技术的智能仓储环境监测与智能控制系统设计与实现.docx

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

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

    基于WSN技术的智能仓储环境监测与智能控制系统设计与实现.docx

    1、基于WSN技术的智能仓储环境监测与智能控制系统设计与实现项目十 基于WSN技术的智能仓储环境监测与智能控制系统设计与实现一、教学目标1、 掌握WSN网关通信的相关应用。2、 掌握WSN实现了信息的采集、信息传输和信息处理模式。3、 掌握WSN实现仓储环境监控智能化技术方法。二、教学内容10.1设备简介10.1.1 WSN网关图10-1 WSN网关图 供电电源:DC5V,信号获取接口:USB,上位机通信接口:以太网口,操作系统:Linux。网关通过USB与协调器连接,并通过协调器与各Zigbee节点进行信号通讯。10.1.2协调器图10-2 协调器图供电方式:USB供电。该设备为网关与各传感器节

    2、点的中继,负责转发Zigbee信号。10.1.3温湿度传感器模块图10-3 温湿度传感模块图供电方式:DC5V,通讯协议:Zigbee。集成模块:温湿度传感器。该节点可采集温湿度数据,并通过Zigbee协议传输到网关,上位机通过访问网关获取温湿度数据。10.1.4电磁继电器模块图10-4电磁继电器模块图供电方式:DC5V,继电器控制路数:4路,与网关通信协议:Zigbee。该继电器可控制四路电源,在京胜世纪的实验台中,控制了两路灯光、一路风扇和一路电磁门。10.2类的设计与实现在本部分实训中我们要用到数据库来存储当前各个节点的信息,以面向对象的思想为例,我们需要先编写几对数据库操作的基础类和将

    3、节点信息保存的对象类。10.2.1 DBConnection.cs类这个类文件是要对数据库进行连接操作,登录到本地的数据库。引用命名空间。该命名空间是SQL Server.NET数据提供者,是SQL Server专用的内置.NET提供者,引用该命名空间后就可以获得最好的性能和对基础功能的最直接访问。using System.Data.SqlClient; 添加变量 private string str; private SqlCommand sqlcom; private SqlConnection conn;在构造函数中写入连接数据库方法/ / 连接数据库的方法 / public DBCon

    4、nection() /定义了要连接的数据库的位置,数据库的名称,登录帐号和密码 this.str = Server=localhost;DataBase=SmartShelfD;uid=sa;pwd=123; this.conn = new SqlConnection(str); this.sqlcom = new SqlCommand(); this.sqlcom.Connection = this.conn; this.conn.Open(); 上边定义了两个全局变量,分变是字符型str,变量量为数据库连接字符串内容:Server表示正在访问的数据库服务器名称,其格式是“计算机名实例名”,

    5、如果是本地的数据库服务器并且使用的是SQL Server的默认实例名,则可以使用(Local)或.来表示。DataBase表示数据库名称,即该项目所要连接的数据库名;Uid表示数据库服务器的登录名称;Pwd表示数据库服务器的密码。返回数据连接方法/ / 返回数据连接方法 / / public SqlConnection GetConnection() return this.conn; 10.2.2 DBOperate.cs类该类的作用是对程序中的要用到的对数据库的操作进行统一,涉及到对数据库的操作时,如对数据库的增删改操作,都可以直接调用该类,相应的方法。传入相应的参数即可。添加引用usin

    6、g System.Data.SqlClient;using System.Data;定义变量SqlCommand sqlcom;SqlConnection conn;默认构造方法 / / 构造函数 / / public DBOperate(DBConnection dbc) sqlcom = new SqlCommand(); sqlcom.Connection = dbc.GetConnection(); 编写执行方法/ / 执行sql语句 / / public void ExecuteSQL(string sql) this.sqlcom.CommandText = sql; try th

    7、is.sqlcom.ExecuteNonQuery(); catch / / 获取数据表格的方法 / / / sql语句 public DataTable GetDataTable(string sql) this.sqlcom.CommandText = sql; SqlDataAdapter sda = new SqlDataAdapter(this.sqlcom); DataSet ds = new DataSet(); DataTable dt = new DataTable(); try sda.Fill(ds); dt = ds.Tables0; catch return dt;

    8、/ / 执行SQL语句,获取string类型数据 / / SQL语句 / 获取到的string类型数据 public string GetString(string sql) string resultStr = ; this.sqlcom.CommandText = sql; try resultStr = this.sqlcom.ExecuteScalar().ToString(); catch (SqlException e) finally this.sqlcom.Dispose(); return resultStr; public int GetInt(string sql) in

    9、t resultInt = 0; this.sqlcom.CommandText = sql; try resultInt = Convert.ToInt32(this.sqlcom.ExecuteScalar().ToString(); catch (SqlException e) System.Windows.Forms.MessageBox.Show(e.Message); finally this.sqlcom.Dispose(); return resultInt; 本资源是基于SQL Server开发的,所以可以使用using指令可以引用SQL Server 专用的.NET数据库提

    10、供者:using System.Data.SqlClient;提取数据库中数据的4步:1) 连接数据源2) 打开连接3) 发出一个SQL查询命令4) 执行命令语句SqlConnection是一个用于SQL .NET数据提供者的连接对象名称,表示 SQL Server 数据库的一个打开的连接。SqlConnection 对象表示与 SQL Server 数据源的一个唯一的会话。对于客户端/服务器数据库系统,它等效于到服务器的网络连接。SqlConnection 与 SqlDataAdapter 和 SqlCommand 一起使用,可以在连接 Microsoft SQL Server 数据库时提高

    11、性能。Server=localhost;DataBase=AccessControl;uid=sa;pwd=123Server=localost,表示正在访问的SQL Server名称,其格式是“计算机名实例名”。计算机名(localhost)是一个非常方便的SQL Server简短名称,它表示运行在当前机器上的服务器实例。DataBase=AccessControl,指定数据库的名称。uid=sa;pwd=123,表示登录数据库的用户名和密码,这是SQL Server和Windows的标准内置安全。this.conn.Open();打开数据库的连接。CommandText属性获取或设置要对数

    12、据源执行的 SQL 语句或存储过程。ExecuteNonQuery ()方法,对连接执行 SQL 语句并返回受影响的行数。SqlDataAdapter 类表示用于填充 DataSet 和更新 SQL Server 数据库的一组数据命令和一个数据库连接。SqlDataAdapter 是 DataSet 和 SQL Server 之间的桥接器,用于检索和保存数据。DataSet 是 ADO.NET 结构的主要组件,它是从数据源中检索到的数据在内存中的缓存。DataSet 由一组 DataTable 对象组成。try-catch 语句由一个 try 块后跟一个或多个 catch 子句构成,这些子句指

    13、定不同的异常处理程序。try 块包含可能导致异常的保护代码。该块一直执行到引发异常或成功完成为止。例如,下列强制转换 null 对象的尝试引发 NullReferenceException 异常:object o2 = null;try int i2 = (int)o2; /错误10.2.3 ObjCargoNode.cs类该类是对节点信息与数据库中的进行操作进行的修改。节点加入网络后,段地址会存储到数据库中。对当前节点的识别也需要读取数据库中已输入的节点信息。添加命名空间using System.Data;定义变量private int cargo; private string iEEEA

    14、ddress; private string shortAddress; private int nodeType;构造函数 public ObjCargoNode() public ObjCargoNode(int cargo) this.cargo = cargo; DataTable dtb = Program.dbo.GetDataTable(string.Format(select Cargo,IEEEAddress,ShortAddress,NodeType from CargoNode where Cargo=0 , this.cargo); DataRow row = dtb.

    15、Rows0; this.cargo = Convert.ToInt32(rowCargo.ToString(); this.iEEEAddress = rowIEEEAddress.ToString(); this.shortAddress = rowShortAddress.ToString(); this.nodeType = Convert.ToInt32(rowNodeType.ToString(); 属性public int Cargo get return this.cargo; public string IEEEAddress get return this.iEEEAddre

    16、ss; public string ShortAddress get return this.shortAddress; set this.shortAddress = value; public int NodeType get return this.nodeType; 方法public void Insert() Program.dbo.ExecuteSQL(string.Format(update CargoNode set ShortAddress=0 where IEEEAddress=1, this.shortAddress, this.iEEEAddress); 10.3功能设

    17、计与实现该部分实训内容主要是通过程序和wsn的网关进行通信,这里我们需要学习关于wsn网关通信的相关应用。该模块程序中的代码,在后面会分解出来应用。向窗体中添加一个TabControl控件,在TabPages属性添加6个成员。控件Name属性Text属性UseVisualStyleBackColor属性TabPagetpConnect建立连接TrueTabPagetpPingPing指令TrueTabPagetpConfigReadConfig_Read指令TrueTabPagetpConfigWriteConfig_Write指令TrueTabPagetpSensorReadSensor_R

    18、ead指令TrueTabPagetpSensorWriteSensor_Write指令True10.3.1创建建立连接1、建立连接TabPage窗体属性,窗体如图10-5所示。 图10-5 Zigbee节点连接实验图向窗体添加1个SplitContainer控件,2个GroudBox控件,8个Label控件,9个TextBox控件,4个Button控件。更改窗体和控件属性:2、设置窗体属性窗体StartPosition属性MaximizeBox属性MinimizeBox属性FormBorderStyle属性Text属性frmGoodsOutCenterParentFalseFalseFixed

    19、SingleZigbee节点连接实验3、设置Lable控件属性控件Name属性Text属性T1通道SocketLablelblIPAddressT1IP地址LablelblPortT1端口号LablelblAppIDT1AppIDLablelblPasswordT1PasswordT2通道SocketLablelblIPAddressT2IP地址LablelblPortT2端口号LablelblAppIDT2AppIDLablelblPasswordT2Password4、设置TextBox属性控件Name属性Text属性TextBoxtxtIPAddressT1192.168.1.230Te

    20、xtBoxtxtPortT14000TextBoxtxtAppIDT11001TextBoxtxtPasswordT1KingvczigvineTextBoxtxtIPAddressT2192.168.1.230TextBoxtxtPortT24000TextBoxtxtAppIDT21001TextBoxtxtPasswordT2Kingvczigvine5、设置显示信息内容的TextBox属性控件Name属性Dock属性Multiline属性ReadOnle属性ScorllBars属性TextBoxtxtMessageConnectFillTrueTrueVertical6、设置Group

    21、Box控件属性控件Name属性Text属性GroupBoxgbSocket_T1T1通道SocketGroupBoxgbSocket_T2T2通道Socket7、设置Button按钮事件控件Name属性Text属性UseVisualStyleBackColor属性ButtonbtnConnectSocketT1SocketT1连接TrueButtonbtnConnectT1T1通道连接TrueButtonbtnConnectSocketT2SocketT2连接TrueButtonbtnConnectT2T2通道连接True8、窗体后台代码:1) 定义变量 /定义一个函数结构的委托 privat

    22、e delegate void ShowMessageDel(TextBox txt, string msg); private delegate void ShowMessageDelOfTempLabel(Label lbl, string value); /实例化T1数据包消息类 private GRIP_Message messageT1 = new GRIP_Message(); /实例化T2数据包消息类 private GRIP_Message messageT2 = new GRIP_Message(); /定义T1Socket通讯接口 private Socket socket

    23、T1; /定义T2Socket通讯接口 private Socket socketT2; /定义T1通道流水号 private UInt16 sequenceIDT1; /定义T2通道流水号 private UInt16 sequenceIDT2; private int time; /定义一个线程 private Thread thread; /sessionID为连接后网关随机分配的一个标识ID private string sessionID = ;2) 构造函数/ / 构造函数 / public frmZigBee() InitializeComponent(); 3) 编写方法Soc

    24、ket发送消息方法 / / Socket发送消息方法 / / 要发送的字节数组 / Socket实例 / 已发送的长度 private void SendMsg(byte msgSend, Socket socket, int lenSend) /需对发送的字节长度有明确认识,发送一段字节后需要加上该段字节的长度 while (lenSend msgSend.Length) lenSend += socket.Send(msgSend, lenSend, msgSend.Length - lenSend, SocketFlags.None); Socket接收信息的方法 / / Socket接

    25、收消息方法 / / 要接收的字节数组 / Socket实例 / 已接收的长度 private void RecvMsg(byte msgRecv, Socket socket, int lenRecv) while (lenRecv msgRecv.Length) lenRecv += socket.Receive(msgRecv, lenRecv, msgRecv.Length - lenRecv, SocketFlags.None); 在控件中显示信息的方法/ / 在控件中显示消息的方法 / / / private void ShowMessage(TextBox txt, string

    26、msg) if (txt.InvokeRequired) ShowMessageDel smd = new ShowMessageDel(ShowMessage); txt.Invoke(smd, txt, msg); else txt.Text += rn【 + DateTime.Now.ToString(yyyy-MM-dd hh-mm-ss) + 】 + msg; 在Label控件中显示消息的方法 / / 在Label控件中显示消息的方法 / / 控件名称 / 要显示的值 private void ShowTempValue(Label lbl, string value) if (lbl.InvokeRequired) ShowMessageDelOfTempLabel smd = new ShowMessageDelOfTempLabel(ShowTempValue); lbl.Invoke(smd, lbl, value); else lbl.Text = value; 线程方法/ /


    注意事项

    本文(基于WSN技术的智能仓储环境监测与智能控制系统设计与实现.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开