SerialPort编程(C#)

 

public static string[] GetPortNames()

{

    RegistryKey localMachine = null;

    RegistryKey key2 = null;

string[] textArray = null;

//这里有个断言,判断该注册表项是否存在

    new RegistryPermission(RegistryPermissionAccess.Read, @"HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/SERIALCOMM").Assert();

    try

    {

        localMachine = Registry.LocalMachine;

        key2 = localMachine.OpenSubKey(@"HARDWARE/DEVICEMAP/SERIALCOMM", false);

        if (key2 != null)

        {

            string[] valueNames = key2.GetValueNames();

            textArray = new string[valueNames.Length];

            for (int i = 0; i < valueNames.Length; i++)

            {

                textArray[i] = (string) key2.GetValue(valueNames[i]);

            }

        }

    }

    finally

    {

        if (localMachine != null)

        {

            localMachine.Close();

        }

        if (key2 != null)

        {

            key2.Close();

        }

        CodeAccessPermission.RevertAssert();

    }

    if (textArray == null)

    {

        textArray = new string[0];

    }

    return textArray;

}

 

 

 

 

VS.NET2005中SerialPort控件操作详解(C#)

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Text;

using System.Windows.Forms;

using System.IO.Ports;

namespace SerialPorts

{

    public partial class frm_Main : Form

    {

        #region Public Enumerations

        public enum DataMode { Text, Hex }

        public enum LogMsgType { Incoming, Outgoing, Normal, Warning, Error };

        #endregion

        private Color[] LogMsgTypeColor = { Color.Orange, Color.Green, Color.Black, Color.Blue, Color.Red };

        //禁用和启用程序中各控件的状态

        private void EnableControls()

        {

            // 基于串口的打开与否,设置控件状态

            gbPortSettings.Enabled = !ComPort.IsOpen;

            btns.Enabled = btnstop.Enabled = txtSendData.Enabled = btnSend.Enabled = ComPort.IsOpen;

            if (ComPort.IsOpen) btnOpenPort.Text = "关闭串口";

            else btnOpenPort.Text = "打开串口";

        }

        //初始化组件的数据,为串口提供相关参数

        private void InitializeControlValues()

        {

            cmbParity.Items.Clear(); cmbParity.Items.AddRange(Enum.GetNames(typeof(Parity)));

            cmbStopBits.Items.Clear(); cmbStopBits.Items.AddRange(Enum.GetNames(typeof(StopBits)));

            cmbPortName.Items.Clear();

            foreach (string s in SerialPort.GetPortNames())

                cmbPortName.Items.Add(s);

            cmbPortName.Text = cmbPortName.Items[0].ToString();

            cmbParity.Text = cmbParity.Items[0].ToString();

            cmbStopBits.Text = cmbStopBits.Items[0].ToString();

            cmbDataBits.Text = cmbDataBits.Items[0].ToString();

            cmbParity.Text = cmbParity.Items[0].ToString();

            cmbBaudRate.Text = cmbBaudRate.Items[0].ToString();

            EnableControls();

        }

        //十六进制转换字节数组

        private byte[] HexStringToByteArray(string s)

        {

            s = s.Replace(" ", "");

            byte[] buffer = new byte[s.Length / 2];

            for (int i = 0; i < s.Length; i += 2)

                buffer[i / 2] = (byte)Convert.ToByte(s.Substring(i, 2), 16);

            return buffer;

        }

        //字节数组转换十六进制

        private string ByteArrayToHexString(byte[] data)

        {

            StringBuilder sb = new StringBuilder(data.Length * 3);

            foreach (byte b in data)

                sb.Append(Convert.ToString(b, 16).PadLeft(2, '0').PadRight(3, ' '));

            return sb.ToString().ToUpper();

        }

        //显示数据日志

        private void Log(LogMsgType msgtype, string msg)

        {

            rtfTerminal.Invoke(new EventHandler(delegate

            {

                rtfTerminal.SelectedText = string.Empty;

                rtfTerminal.SelectionFont = new Font(rtfTerminal.SelectionFont, FontStyle.Bold);

                rtfTerminal.SelectionColor = LogMsgTypeColor[(int)msgtype];

                rtfTerminal.AppendText(msg);

                rtfTerminal.ScrollToCaret();

            }));

        }

        //串口发送方式

        #region Local Properties

        private DataMode CurrentDataMode

        {

            get

            {

                if (rbHex.Checked) return DataMode.Hex;

                else return DataMode.Text;

            }

            set

            {

                if (value == DataMode.Text) rbText.Checked = true;

                else rbHex.Checked = true;

            }

        }

        #endregion

        //发送数据

        private void SendData()

        {

            if (CurrentDataMode == DataMode.Text)

            {

                // 发送用户的文本到串口

                ComPort.Write(txtSendData.Text);

                // 将用户的文本显示到数据窗口

                Log(LogMsgType.Outgoing, txtSendData.Text + "/n");

            }

            else

            {

                try

                {

                    // 转换用户十六进制数据到字节数组

                    byte[] data = HexStringToByteArray(txtSendData.Text);

                    // 发送数据到串口

                    ComPort.Write(data, 0, data.Length);

                    // 将用户十六进制数据到数据窗口

                    Log(LogMsgType.Outgoing, ByteArrayToHexString(data) + "/n");

                }

                catch (FormatException)

                {

                    // 转换错误

                    Log(LogMsgType.Error, "十六进制数据有误: " + txtSendData.Text + "/n");

                }

            }

            txtSendData.SelectAll();

        }

        /// <summary>

        /// -------------------------------------------------------------

        /// </summary>

        public frm_Main()

        {

            InitializeComponent();

        }

        private void Form1_Load(object sender, EventArgs e)

        {

            InitializeControlValues();

            ComPort.DataReceived += new SerialDataReceivedEventHandler(port_DataReceived);

        }

        //打开串口

        private void btnOpenPort_Click(object sender, EventArgs e)

        {

            if (ComPort.IsOpen) ComPort.Close();

            else

            {

                //设置串口参数

                ComPort.BaudRate = int.Parse(cmbBaudRate.Text);

                ComPort.DataBits = int.Parse(cmbDataBits.Text);

                ComPort.StopBits = (StopBits)Enum.Parse(typeof(StopBits), cmbStopBits.Text);

                ComPort.Parity = (Parity)Enum.Parse(typeof(Parity), cmbParity.Text);

                ComPort.PortName = cmbPortName.Text;

                // 打开串口

                ComPort.Open();

            }

            // 改变组件状态

            EnableControls();

            // 如果串口打开,将焦点放入txtSendData

            if (ComPort.IsOpen) txtSendData.Focus();

        }

        private void rbHex_CheckedChanged(object sender, EventArgs e)

        {

            if (rbHex.Checked) CurrentDataMode = DataMode.Hex;

        }

        private void rbText_CheckedChanged(object sender, EventArgs e)

        {

            if (rbText.Checked) CurrentDataMode = DataMode.Text;

        }

        //接收数据

        private void port_DataReceived(object sender, SerialDataReceivedEventArgs e)

        {

            

            // 判断用户用的是字节模式还是字符模式

            if (CurrentDataMode == DataMode.Text)

            {

                // 读取缓冲区的数据

                string data = ComPort.ReadExisting();

                // 显示读取的数据到数据窗口

                Log(LogMsgType.Incoming, data + "/n");

            }

            else

            {

                // 获取字节长度

                int bytes = ComPort.BytesToRead;

                // 创建字节数组

                byte[] buffer = new byte[bytes];

                // 读取缓冲区的数据到数组

                ComPort.Read(buffer, 0, bytes);

                // 显示读取的数据到数据窗口

                Log(LogMsgType.Incoming, ByteArrayToHexString(buffer) + "/n");

            }

        }

        //发送数据按键

        private void btnSend_Click(object sender, EventArgs e)

        {

            SendData();

        }

        private void lnkAbout_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)

        {

            (new frmAbout()).ShowDialog(this);

        }

        //时间组件控制发送数据

        private void timer1_Tick(object sender, EventArgs e)

        {

            SendData();

        }

        //连续发送数据

        private void button1_Click(object sender, EventArgs e)

        {

            delay.Enabled = true;

            btns.Enabled = !delay.Enabled;

            btnstop.Enabled = delay.Enabled;

        }

        //停止连续发送数据

        private void button2_Click(object sender, EventArgs e)

        {

            delay.Enabled = false;

            btns.Enabled = !delay.Enabled;

            btnstop.Enabled = delay.Enabled;

        }

    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
书名:《Visual C#.NET串口通信及测控应用典型实例》(电子工业出版社.李江全.邓红涛.刘巧.李伟) PDF格式扫描版,全书分为8章,共369页。2012年5月出版。 全书压缩打包成3部分,这是第3部分 内容简介 本书从工程应用的角度出发,通过8个典型应用实例,包括PC与PC、PC与单片机、PC与PLC、PC与远程I/O模块、PC与智能仪器、PC与无线数传模块、Pc与USB数据采集模块等组成的测控系统,利用SerialPort控件和MSComm控件编写C#.NET串口通信程序,并对计算机测控系统中的4类典型应用((模拟量输入(AI)、模拟量输出(AO)、数字量输入(DI)和数字量输出(DO)的程序设计方法进行了详细的讲解。 目 录 第1章 PC与PC串口通信 1.1 串口通信概述 1.1.1 串口通信的基本概念 1.1.2 RS-232C接口标准 1.1.3 RS-422/485接口标准 1.1.4 串口通信线路连接 1.1.5 PC中的串行端口 1.1.6 虚拟串口的使用 1.2 VC++.NET串行通信控件与API函数 1.2.1 MSComm控件的使用 1.2.2 SerialPort控件的使用 1.2.3 串行通信API函数 1.3 PC与PC串口通信实例 1.3.1 两台PC串口通信 1.3.2 一台PC双串口互通信 第2章 PC与单片机串口通信 2.1 典型单片机开发板简介 2.1.1 单片机测控系统的组成 2.1.2 单片机开发板B的功能 2.1.3 单片机开发板B的主要电路 2.2 PC与单片机串口通信实例 2.2.1 PC与单个单片机串口通信 2.2.2 PC与多个单片机串口通信 2.3 PC与单片机串口通信测控应用实例 2.3.1 模拟量输入 2.3.2 模拟量输出 2.3.3 开关量输入 2.3.4 开关量输出 第3章 PC与西门子PLC串口通信 3.1 西门子PLC模拟量扩展模块与通信协议 3.1.1 西门子PLC模拟量输入模块 3.1.2 西门子PLC PPI通信协议 3.2 PC与西门子PLC串口通信测控应用实例 3.2.1 模拟量输入 3.2.2 模拟量输出 3.2.3 开关量输入 3.2.4 开关量输出 第4章 PC与三菱PLC串口通信 4.1 三菱PLC特殊功能模块与通信协议 4.1.1 FX2N系列PLC的特殊功能模块 4.1.2 三菱PLC编程口通信协议 4.2 PC与三菱PLC串口通信测控应用实例 4.2.1 模拟量输入 4.2.2 模拟量输出 4.2.3 开关量输入 4.2.4 开关量输出 第5章 PC与分布式I/O模块串口通信 5.1 典型分布式I/O模块简介 5.1.1 集散控制系统的结构与特点 5.1.2 ADAM4000远程数据采集控制系统 5.1.3 ADAM4000系列模块简介 5.1.4 ADAM4000系列模块的软件安装 5.2 PC与分布式I/O模块串口通信测控应用实例 5.2.1 模拟量输入 5.2.2 模拟量输出 5.2.3 数字量输入 5.2.4 数字量输出 第6章 PC与智能仪器串口通信 6.1 典型智能仪器简介 6.1.1 智能仪器的结构与特点 6.1.2 XMT-3000A型智能仪器的通信协议 6.2 PC与智能仪器串口通信测控应用实例 6.2.1 PC与单台智能仪器温度测控 6.2.2 PC与多台智能仪器温度测控 第7章 PC与无线数据传输模块串口通信 7.1 典型无线数传模块简介 7.1.1 无线数传技术概述 7.1.2 DTD46X系列无线数传模块 7.2 PC与无线数传模块串口通信测控应用实例 7.2.1 设计任务 7.2.2 线路连接 7.2.3 利用C51语言实现基于DS18B20的单片机温度测控 7.2.4 利用汇编语言实现基于DS18B20的单片机温度测控 7.2.5 利用VC++.NET实现PC与无线数传模块温度测控 第8章 USB串行总线模块测控应用 8.1 USB总线在数据采集系统中的应用 8.1.1 USB总线及其数据采集系统的特点 8.1.2 采用USB传输的数据采集系统 8.1.3 典型USB数据采集模块及应用 8.1.4 VC++.NET数据采集与控制的方式 8.2 PC与USB数据采集模块测控应用实例 8.2.1 模拟量输入 8.2.2 模拟量输出 8.2.3 数字量输入 8.2.4 数字量输出 参考文献
书名:《Visual C#.NET串口通信及测控应用典型实例》(电子工业出版社.李江全.邓红涛.刘巧.李伟) PDF格式扫描版,全书分为8章,共369页。2012年5月出版。 全书压缩打包成3部分,这是第1部分 内容简介 本书从工程应用的角度出发,通过8个典型应用实例,包括PC与PC、PC与单片机、PC与PLC、PC与远程I/O模块、PC与智能仪器、PC与无线数传模块、Pc与USB数据采集模块等组成的测控系统,利用SerialPort控件和MSComm控件编写C#.NET串口通信程序,并对计算机测控系统中的4类典型应用((模拟量输入(AI)、模拟量输出(AO)、数字量输入(DI)和数字量输出(DO)的程序设计方法进行了详细的讲解。 目 录 第1章 PC与PC串口通信 1.1 串口通信概述 1.1.1 串口通信的基本概念 1.1.2 RS-232C接口标准 1.1.3 RS-422/485接口标准 1.1.4 串口通信线路连接 1.1.5 PC中的串行端口 1.1.6 虚拟串口的使用 1.2 VC++.NET串行通信控件与API函数 1.2.1 MSComm控件的使用 1.2.2 SerialPort控件的使用 1.2.3 串行通信API函数 1.3 PC与PC串口通信实例 1.3.1 两台PC串口通信 1.3.2 一台PC双串口互通信 第2章 PC与单片机串口通信 2.1 典型单片机开发板简介 2.1.1 单片机测控系统的组成 2.1.2 单片机开发板B的功能 2.1.3 单片机开发板B的主要电路 2.2 PC与单片机串口通信实例 2.2.1 PC与单个单片机串口通信 2.2.2 PC与多个单片机串口通信 2.3 PC与单片机串口通信测控应用实例 2.3.1 模拟量输入 2.3.2 模拟量输出 2.3.3 开关量输入 2.3.4 开关量输出 第3章 PC与西门子PLC串口通信 3.1 西门子PLC模拟量扩展模块与通信协议 3.1.1 西门子PLC模拟量输入模块 3.1.2 西门子PLC PPI通信协议 3.2 PC与西门子PLC串口通信测控应用实例 3.2.1 模拟量输入 3.2.2 模拟量输出 3.2.3 开关量输入 3.2.4 开关量输出 第4章 PC与三菱PLC串口通信 4.1 三菱PLC特殊功能模块与通信协议 4.1.1 FX2N系列PLC的特殊功能模块 4.1.2 三菱PLC编程口通信协议 4.2 PC与三菱PLC串口通信测控应用实例 4.2.1 模拟量输入 4.2.2 模拟量输出 4.2.3 开关量输入 4.2.4 开关量输出 第5章 PC与分布式I/O模块串口通信 5.1 典型分布式I/O模块简介 5.1.1 集散控制系统的结构与特点 5.1.2 ADAM4000远程数据采集控制系统 5.1.3 ADAM4000系列模块简介 5.1.4 ADAM4000系列模块的软件安装 5.2 PC与分布式I/O模块串口通信测控应用实例 5.2.1 模拟量输入 5.2.2 模拟量输出 5.2.3 数字量输入 5.2.4 数字量输出 第6章 PC与智能仪器串口通信 6.1 典型智能仪器简介 6.1.1 智能仪器的结构与特点 6.1.2 XMT-3000A型智能仪器的通信协议 6.2 PC与智能仪器串口通信测控应用实例 6.2.1 PC与单台智能仪器温度测控 6.2.2 PC与多台智能仪器温度测控 第7章 PC与无线数据传输模块串口通信 7.1 典型无线数传模块简介 7.1.1 无线数传技术概述 7.1.2 DTD46X系列无线数传模块 7.2 PC与无线数传模块串口通信测控应用实例 7.2.1 设计任务 7.2.2 线路连接 7.2.3 利用C51语言实现基于DS18B20的单片机温度测控 7.2.4 利用汇编语言实现基于DS18B20的单片机温度测控 7.2.5 利用VC++.NET实现PC与无线数传模块温度测控 第8章 USB串行总线模块测控应用 8.1 USB总线在数据采集系统中的应用 8.1.1 USB总线及其数据采集系统的特点 8.1.2 采用USB传输的数据采集系统 8.1.3 典型USB数据采集模块及应用 8.1.4 VC++.NET数据采集与控制的方式 8.2 PC与USB数据采集模块测控应用实例 8.2.1 模拟量输入 8.2.2 模拟量输出 8.2.3 数字量输入 8.2.4 数字量输出 参考文献
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值