在两个不同的窗体上使用相同的串行端口
本文关键字:串行端口 窗体 两个 | 更新日期: 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);