xbee 값 설정기능 추가
This commit is contained in:
@@ -7,7 +7,8 @@ using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using System.Windows.Forms;
|
||||
|
||||
using AR;
|
||||
using COMM;
|
||||
namespace Project.Dialog
|
||||
{
|
||||
public partial class fXbeeSetting : Form
|
||||
@@ -15,7 +16,9 @@ namespace Project.Dialog
|
||||
public fXbeeSetting()
|
||||
{
|
||||
InitializeComponent();
|
||||
PUB.logxbee.RaiseMsg += Log_RaiseMsgcal;
|
||||
VAR.BOOL[eVarBool.DISABLE_AUTOCONN_XBEE] = true;
|
||||
PUB.XBE.Close();
|
||||
this.serialPort1.DataReceived += SerialPort1_DataReceived;
|
||||
}
|
||||
private void fXbeeSetting_Load(object sender, EventArgs e)
|
||||
{
|
||||
@@ -27,11 +30,16 @@ namespace Project.Dialog
|
||||
|
||||
this.tbPortName.Text = PUB.setting.Port_XBE;
|
||||
this.tbBaud.Text = PUB.setting.Baud_XBE.ToString();
|
||||
|
||||
}
|
||||
private void Log_RaiseMsgcal(DateTime LogTime, string TypeStr, string Message)
|
||||
void showlog(string Message)
|
||||
{
|
||||
showlog(rtXbee, LogTime, TypeStr, Message);
|
||||
if (rtXbee.Visible)
|
||||
{
|
||||
rtXbee.AddMsg(DateTime.Now, "NORMAL", Message);
|
||||
}
|
||||
}
|
||||
|
||||
void showlog(arCtl.LogTextBox rtRx, DateTime LogTime, string TypeStr, string Message)
|
||||
{
|
||||
if (rtRx.Visible)
|
||||
@@ -41,27 +49,96 @@ namespace Project.Dialog
|
||||
}
|
||||
private void button1_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (PUB.XBE.IsOpen)
|
||||
PUB.XBE.Close();
|
||||
if (this.serialPort1.IsOpen)
|
||||
{
|
||||
serialPort1.Close();
|
||||
showlog("closed");
|
||||
}
|
||||
else
|
||||
{
|
||||
PUB.XBE.PortName = tbPortName.Text;
|
||||
PUB.XBE.Open();
|
||||
serialPort1.PortName = tbPortName.Text;
|
||||
serialPort1.BaudRate = int.Parse(tbBaud.Text);
|
||||
serialPort1.Open();
|
||||
showlog("open");
|
||||
}
|
||||
}
|
||||
|
||||
private void fXbeeSetting_FormClosed(object sender, FormClosedEventArgs e)
|
||||
{
|
||||
PUB.logxbee.RaiseMsg -= Log_RaiseMsgcal;
|
||||
VAR.BOOL[eVarBool.DISABLE_AUTOCONN_XBEE] = false;
|
||||
}
|
||||
|
||||
private volatile bool isCommandExecuting = false;
|
||||
|
||||
private void SerialPort1_DataReceived(object sender, System.IO.Ports.SerialDataReceivedEventArgs e)
|
||||
{
|
||||
if (isCommandExecuting) return;
|
||||
|
||||
try
|
||||
{
|
||||
string data = serialPort1.ReadExisting();
|
||||
var hexdata = System.Text.Encoding.Default.GetBytes(data);
|
||||
var hexstr = string.Join(" ", hexdata.Select(t => t.ToString("X2")));
|
||||
if (!string.IsNullOrEmpty(data))
|
||||
{
|
||||
this.BeginInvoke(new Action(() =>
|
||||
{
|
||||
showlog($"RxAsync: {hexstr}");
|
||||
}));
|
||||
}
|
||||
}
|
||||
catch { }
|
||||
}
|
||||
|
||||
private string Cmd(string cmd, int timeout = 1000)
|
||||
{
|
||||
isCommandExecuting = true;
|
||||
try
|
||||
{
|
||||
if (!serialPort1.IsOpen) return "Error: Port Closed";
|
||||
|
||||
serialPort1.DiscardInBuffer();
|
||||
serialPort1.Write(cmd);
|
||||
|
||||
System.Threading.Thread.Sleep(20);
|
||||
serialPort1.ReadTimeout = timeout;
|
||||
string res = serialPort1.ReadTo("\r");
|
||||
System.Threading.Thread.Sleep(20);
|
||||
showlog($"Tx:{cmd.Trim()}, Rx:{res}");
|
||||
|
||||
//명령수신호 10ms 대기후 다음 명령을 전송
|
||||
System.Threading.Thread.Sleep(20);
|
||||
|
||||
return res;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
showlog($"Err: {ex.Message}");
|
||||
return "Error";
|
||||
}
|
||||
finally
|
||||
{
|
||||
isCommandExecuting = false;
|
||||
}
|
||||
}
|
||||
private void btpand_Click(object sender, EventArgs e)
|
||||
{
|
||||
//각명령마다 회신을 확인하고 다음명령을 실행해야함
|
||||
//명령수신호 10ms 대기후 다음 명령을 전송
|
||||
//명령을 설정하면 응답은 OK\d 형태로 입력된다.
|
||||
var cmds = new string[] {
|
||||
"+++",
|
||||
$"ATID{tbpanid.Text}\r" ,
|
||||
$"ATCN"};
|
||||
$"ATCN\r"};
|
||||
|
||||
foreach (var cmd in cmds)
|
||||
{
|
||||
if(!Cmd(cmd).Contains("OK"))
|
||||
{
|
||||
showlog("FAIL");
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void btch_Click(object sender, EventArgs e)
|
||||
@@ -69,7 +146,15 @@ namespace Project.Dialog
|
||||
var cmds = new string[] {
|
||||
"+++",
|
||||
$"ATCH{tbch.Text}\r" ,
|
||||
$"ATCN"};
|
||||
$"ATCN\r"};
|
||||
foreach (var cmd in cmds)
|
||||
{
|
||||
if (!Cmd(cmd).Contains("OK"))
|
||||
{
|
||||
showlog("FAIL");
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void btmy_Click(object sender, EventArgs e)
|
||||
@@ -77,13 +162,32 @@ namespace Project.Dialog
|
||||
var cmds = new string[] {
|
||||
"+++",
|
||||
$"ATMY{tbmy.Text}\r" ,
|
||||
$"ATCN"};
|
||||
$"ATCN\r"};
|
||||
foreach (var cmd in cmds)
|
||||
{
|
||||
if (!Cmd(cmd).Contains("OK"))
|
||||
{
|
||||
showlog("FAIL");
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void button2_Click(object sender, EventArgs e)
|
||||
{
|
||||
//read all(id,ch,my)
|
||||
|
||||
if (Cmd("+++").Contains("OK"))
|
||||
{
|
||||
var id = Cmd("ATID\r");
|
||||
var ch = Cmd("ATCH\r");
|
||||
var my = Cmd("ATMY\r");
|
||||
Cmd("ATCN\r");
|
||||
this.BeginInvoke(new Action(() => {
|
||||
this.tbpanid.Text = id;
|
||||
this.tbch.Text = ch;
|
||||
this.tbmy.Text = my;
|
||||
}));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user