在两个不同的窗体上使用相同的串行端口

本文关键字:串行端口 窗体 两个 | 更新日期: 2023-09-27 17:59:06

我有两种形式=Form1.CS和SMS.CS在第一个表单(Form1)上,我已经配置并准备好使用serialport1。我有一个叫发送信息的按钮。此按钮打开名为SMS.cs.的新表单

private void SMS_Click(object sender, EventArgs e)
    {
        SMS settings = new SMS();
        settings.ShowDialog();
    }

我想在Form1和FormSMS.cs上使用我配置的serialport1。也可以从Form1上接收SMS数据,并使用Form1上的serialport 1发送,例如:

 private void SMS_Click(object sender, EventArgs e)
    {
        SMS settings = new SMS();
        settings.ShowDialog();
        SerialPort1.Writeln(Data from form SMS)
    }

但我不知道怎么做。在我看来,最好的主意是直接从短信表单发送数据。

编辑:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO.Ports;
namespace WindowsFormsApplication1
{
    public partial class SMSForm : Form
    {
        SerialPort SerialP;
        public SMSForm(Object SerialP)
        {
            InitializeComponent();
        }
        private void button1_Click(object sender, EventArgs e) 
        {
            SerialP.WriteLine("ATI");
        }
    }
}

在两个不同的窗体上使用相同的串行端口

要在两个表单中使用相同的SerialPort,需要将对SerialPort的引用发送到第二个表单。

最简单的方法是在接受SerialPort的SMS表单中添加一个新的构造函数,将其存储在成员变量中并使用它

在哪里

SMS settings = new SMS();

你需要实际做到这一点:

SMS settings = new SMS(SerialPort1);

Form1是SerialPort控制器,也就是说,Form1配置SerialPort。如果有影响SerialPort的事件,例如"SerialPort1.Writeln",则应将方法引用传递给对话框构造函数。这将在逻辑上保持类的独立性,同时共享方法。

您可以创建一个自定义EventArgs对象,将字符串传回SerialPort:

public class WriteToSerialPortEventArgs : EventArgs
{
    public WriteToSerialPortEventArgs (string Write)
    { WriteBytes = Encoding.GetBytes(write); }  // simplified - see MSDN for more options 
    public byte[] WriteBytes
    { get; private set; }   
}

传递到SMS对话框的Form1示例事件委托:

void OnWriteToSerialPort(object sender, WriteToSerialPortEventArgs e )
{
    SerialPort1.WriteLine(e.WriteBytes);
}

编写您的SMS构造函数:

// field
Action<object, WriteToSerialPortEventArgs> writeDelegate;
public SMS (Action<object, WriteToSerialPortEventArgs> writeDelegate)
{
    this.writeDelegate = writeDelegate;
    this.button1.Click += new EventHandler(button1_Click);
}

SMS事件代理:

void button1_Click(object sender, EventArgs e)
{
    writeDelegate.Invoke(sender, new WriteToSerialPortEventArgs (txtBox.Text);
}

从技术上讲,您不需要完整的Invoke(...)方法签名。为了完整性,我包含了它,可以写成:

writeDelegate(sender, new WriteToSerialPortEventArgs (txtBox.Text);