Win10 IoT C#开发 4 - UART 串口通信

简介: 原文:Win10 IoT C#开发 4 - UART 串口通信Windows 10 IoT Core 是微软针对物联网市场的一个重要产品,既可以开发设备UI与用户交互式操作,又可以控制GPIO等接口,使得原来嵌入式繁琐的开发变得简单。
原文: Win10 IoT C#开发 4 - UART 串口通信

Windows 10 IoT Core 是微软针对物联网市场的一个重要产品,既可以开发设备UI与用户交互式操作,又可以控制GPIO等接口,使得原来嵌入式繁琐的开发变得简单。通过Remote Debug功能可以进行断点追踪调试。C#语言本身也有很好的用户基础,相信Win10 IoT 不远的将来会火起来。
上个月帮朋友解决了关于Win10 IoT 的一些技术问题,当前也有很多公司在尝试采用Win10 IoT进行开发,可能也会遇到这些问题,相关文档现在还非常少,这里写出来供大家参考。
因为要做一个Java Web与Restful的自宿主框架和其他一大堆事情,这篇文章也拖了半个月,框架刚刚完成,以后可以摆脱Tomcat这些HttpServer了,现在静下来把这篇文章写完。
Win10 IoT的安装部署过程后面我会写文章进行补充,下面直接介绍串口通信的开发过程。
1.连接设备

首先将 Raspberry Pi 2 与传感器连接。GND,5V 对接,TX与RX交叉连接。

Raspberry Pi 2 GPIO 接口

传感器与设备连接

2.启动设备
将Raspberry连接到局域网并启动。打开 Windows IoT Core Watcher 查看设备的工作状态。包含名称,mac地址,ip地址,当前在线等信息。

3.创建项目
打开VS2015创建项目,在C#分类下选择Windows IoT Core 模板。

4.配置权限
Package.appxmanifest文件的节点中加入读取网络与串口通讯的权限,这步很像Android的uses-permission。

<Capabilities>
    <Capability Name="internetClient" />
    <Capability Name="internetClientServer" />
    <Capability Name="privateNetworkClientServer" />
    <DeviceCapability Name="serialcommunication">
      <Device Id="any">
        <Function Type="name:serialPort" />
      </Device>
    </DeviceCapability>
</Capabilities>

5.模块代码
创建UART的串口设备并设置参数。

string aqsFilter = SerialDevice.GetDeviceSelector("UART0");
DeviceInformationCollection dis = await DeviceInformation.FindAllAsync(aqsFilter);
//获取串口设备
_derialPort = await SerialDevice.FromIdAsync(dis[0].Id);
//串口设备是否获取成功
if (null != _derialPort)
{
    _derialPort.ReadTimeout = TimeSpan.FromMilliseconds(1000);//超时
    _derialPort.BaudRate = 9600;//波特率
    _derialPort.Parity = SerialParity.None;//校验检查
    _derialPort.StopBits = SerialStopBitCount.One;//停止位
    _derialPort.DataBits = 8;//数据位
    _derialPort.Handshake = SerialHandshake.None;//握手方式
    //设置读取输入流
    _dataReader = new DataReader(_derialPort.InputStream);
}

读取串口数据

 Task<UInt32> loadAsyncTask;
_dataReader.InputStreamOptions = InputStreamOptions.Partial;
//读取数据
loadAsyncTask = _dataReader.LoadAsync(_readBufferLength).AsTask();
uint bytesRead = await loadAsyncTask;
//判断获取数据长度
if (bytesRead > 0)
{
     //转换十六进制数据
     string res = LoadData(bytesRead);
     SendMsg(res);
}
StringBuilder str_builder = new StringBuilder();
//转换缓冲区数据为16进制
while (_dataReader.UnconsumedBufferLength > 0)
{
    str_builder.Append(_dataReader.ReadByte().ToString("x2"));
}

推送数据

HttpClient httpClient = new HttpClient();
httpClient.GetAsync(new Uri(string.Format("http://192.168.1.9:8099/{0}", res)));

6.调试代码
在另外一台电脑(ip:192.168.1.9)上先用Nodejs创建了一个http的监听服务模拟服务器,监听8099端口上设备发送过来的串口数据,并打印到Console里。

在VS2015的工具栏中选择Remote Machine进行调试,IP地址输入设备对应地址,可以在Windows IoT Core Watcher中查看到。点击运行后会自动部署到设备上。

 

7.运行结果
代码部署完成后开始执行任务,Output窗口打印获取到的串口数据。

Nodejs模拟的服务器打印接收到的推送数据。从打印结果上可以看到发送和接收到的数据一致。

与传感器的数据协议约定一致。

完整代码:

using System;
using System.Diagnostics;
using System.Text;
using System.Threading.Tasks;
using Windows.ApplicationModel.Background;
using Windows.Devices.Enumeration;
using Windows.Devices.SerialCommunication;
using Windows.Storage.Streams;
using Windows.Web.Http;

namespace CloudTechIot3
{
    //http://www.cnblogs.com/cloudtech
    //librastarwing@hotmail.com
    public sealed class StartupTask : IBackgroundTask
    {
        #region Fileds

        private DataReader _dataReader;
        private SerialDevice _derialPort;
        //缓冲区大小
        private uint _readBufferLength = 10;

        #endregion

        #region Main Method

        public async void Run(IBackgroundTaskInstance taskInstance)
        {

            await Listen();
            Close();
        }

        #endregion

        #region Private Methods

        //监听串口
        private async Task Listen()
        {
            try
            {
                string aqsFilter = SerialDevice.GetDeviceSelector("UART0");
                DeviceInformationCollection dis = await DeviceInformation.FindAllAsync(aqsFilter);
                //获取串口设备
                _derialPort = await SerialDevice.FromIdAsync(dis[0].Id);
                //串口设备是否获取成功
                if (null != _derialPort)
                {
                    _derialPort.ReadTimeout = TimeSpan.FromMilliseconds(1000);//超时
                    _derialPort.BaudRate = 9600;//波特率
                    _derialPort.Parity = SerialParity.None;//校验检查
                    _derialPort.StopBits = SerialStopBitCount.One;//停止位
                    _derialPort.DataBits = 8;//数据位
                    _derialPort.Handshake = SerialHandshake.None;//握手方式
                    //设置读取输入流
                    _dataReader = new DataReader(_derialPort.InputStream);
                    //循环读取数据
                    while (true)
                    {
                        await ReadAsync();
                    }
                }
                else
                {
                    //TODO
                }
            }
            catch (Exception ex)
            {
                //TODO
            }
            finally
            {
                Close();
            }
        }

        //异步读取数据
        private async Task ReadAsync()
        {
            Task<UInt32> loadAsyncTask;
            _dataReader.InputStreamOptions = InputStreamOptions.Partial;
            //读取数据
            loadAsyncTask = _dataReader.LoadAsync(_readBufferLength).AsTask();
            Task.Delay(TimeSpan.FromSeconds(2.1)).Wait();
            uint bytesRead = await loadAsyncTask;
            //判断获取数据长度
            if (bytesRead > 0)
            {
                //转换十六进制数据
                string res = LoadData(bytesRead);
                SendMsg(res);
            }
            else
            {
                //TODO
            }
        }

        //输出结果
        private void SendMsg(string res)
        {
            //打印
            Debug.WriteLine(res);
            //推送到服务器
            HttpClient httpClient = new HttpClient();
            httpClient.GetAsync(new Uri(string.Format("http://192.168.1.9:8099/{0}", res)));
        }

        //转换数据
        private string LoadData(uint bytesRead)
        {
            StringBuilder str_builder = new StringBuilder();
            //转换缓冲区数据为16进制
            while (_dataReader.UnconsumedBufferLength > 0)
            {
                str_builder.Append(_dataReader.ReadByte().ToString("x2"));
            }
            return str_builder.ToString().ToUpper();
        }

        //释放资源
        private void Close()
        {
            if (null != _dataReader)
            {
                _dataReader.DetachStream();
            }
            if (null != _derialPort)
            {
                _derialPort.Dispose();
            }
        }

        #endregion
    }
}

到这里整个数据读取发送的过程就完成了,如果对代码有优化的建议,欢迎留言或发邮件给我(librastarwing@hotmail.com)。
也可以加我的微信号查看以前的文章。

项目源码 GitHub https://github.com/CloudTechx/CloudTechIot 的 CloudTechIot3 目录下。

目录
相关文章
|
28天前
|
前端开发 JavaScript 安全
C#一分钟浅谈:Blazor WebAssembly 开发
Blazor WebAssembly 是一个客户端框架,允许开发者使用C#和Razor语法构建Web应用。本文介绍了Blazor WebAssembly的基本概念、常见问题及解决方案,包括路由配置、数据绑定、异步操作、状态管理和性能优化等方面的内容,并分享了一些易错点及如何避免的方法。希望这些内容能帮助你在Blazor WebAssembly开发中少走弯路,提高开发效率。
94 51
|
13天前
|
传感器 存储 物联网
在物联网(IoT)快速发展的今天,C语言作为物联网开发中的关键工具,以其高效、灵活、可移植的特点
在物联网(IoT)快速发展的今天,C语言作为物联网开发中的关键工具,以其高效、灵活、可移植的特点,广泛应用于嵌入式系统开发、通信协议实现及后端服务构建等领域,成为推动物联网技术进步的重要力量。
22 1
|
26天前
|
开发框架 缓存 .NET
C# 一分钟浅谈:Blazor Server 端开发
Blazor Server 是基于 ASP.NET Core 的框架,允许使用 C# 和 Razor 语法构建交互式 Web 应用。本文介绍 Blazor Server 的基本概念、快速入门、常见问题及解决方案,帮助开发者快速上手。涵盖创建应用、基本组件、数据绑定、状态管理、跨组件通信、错误处理和性能优化等内容。
37 1
|
27天前
|
缓存 C# 开发者
C# 一分钟浅谈:Blazor Server 端开发
本文介绍了 Blazor Server,一种基于 .NET 的 Web 开发模型,允许使用 C# 和 Razor 语法构建交互式 Web 应用。文章从基础概念、创建应用、常见问题及解决方案、易错点及避免方法等方面详细讲解,帮助开发者快速上手并提高开发效率。
47 2
|
1月前
|
测试技术 Go C#
C#一分钟浅谈:ReSharper 插件增强开发效率
【10月更文挑战第25天】ReSharper 是 JetBrains 开发的一款 Visual Studio 插件,旨在提高 .NET 开发者的生产力。它通过代码分析、重构、导航等功能,帮助开发者避免常见错误,提升代码质量和开发效率。本文将通过具体代码案例,详细介绍 ReSharper 的常见功能及其应用。
41 1
|
1月前
|
C# Python
使用wxpython开发跨平台桌面应用,对wxpython控件实现类似C#扩展函数处理的探究
【10月更文挑战第30天】使用 `wxPython` 开发跨平台桌面应用时,可以通过创建辅助类来模拟 C# 扩展函数的功能。具体步骤包括:1. 创建辅助类 `WxWidgetHelpers`;2. 在该类中定义静态方法,如 `set_button_color`;3. 在应用中调用这些方法。这种方法提高了代码的可读性和可维护性,无需修改 `wxPython` 库即可为控件添加自定义功能。但需要注意显式调用方法和避免命名冲突。
|
2月前
|
JSON C# 开发者
C#语言新特性深度剖析:提升你的.NET开发效率
【10月更文挑战第15天】C#语言凭借其强大的功能和易用性深受开发者喜爱。随着.NET平台的演进,C#不断引入新特性,如C# 7.0的模式匹配和C# 8.0的异步流,显著提升了开发效率和代码可维护性。本文将深入探讨这些新特性,助力开发者在.NET开发中更高效地利用它们。
37 1
|
2月前
|
Rust 资源调度 安全
为什么使用 Rust over C++ 进行 IoT 解决方案开发
为什么使用 Rust over C++ 进行 IoT 解决方案开发
77 7
|
2月前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
2月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
80 0