我想将两个号码从C#发送到串行监视器。但是当我顺序发送数字时,端口不起作用我的C#代码:
if (serialPort1.IsOpen)
{
int MyInt = Convert.ToInt32(textBox1.Text);
byte[] b = BitConverter.GetBytes(MyInt);
serialPort1.Write(b, 0, 4);
if (MyInt == 3)
{
int MyInt2 = Convert.ToInt32(textBox2.Text);
byte[] s = BitConverter.GetBytes(MyInt2);
serialPort1.Write(s, 0, 4);
}
else
{
MessageBox.Show("Continue");
}
}
else
{
MessageBox.Show("Please check your connction maybe serial port is not connected");
}
和arduino代码:
int LedPin = 12;
int k, s;
void setup()
{
Serial.begin(9600);
pinMode(LedPin, OUTPUT);
}
void loop()
{
if (Serial.available())
{
k = Serial.read();
switch (k)
{
case 1:
openCloseThree();
break;
case 2:
openCloseTwice();
break;
case 3:
s = Serial.read();
if (s !=0)
{
openCloseIwanted();
}
break;
default:
openCloseIwanted();
break;
}
}
}
void openClose()
{
for (int i = 0; i < 1; i++)
{
delay(500);
digitalWrite(LedPin, HIGH);
delay(500);
digitalWrite(LedPin, LOW);
}
}
void openCloseTwice()
{
for (int i = 0; i < 2; i++)
{
delay(500);
digitalWrite(LedPin, HIGH);
delay(500);
digitalWrite(LedPin, LOW);
}
}
void openCloseThree()
{
for (int i = 0; i < 3; i++)
{
delay(500);
digitalWrite(LedPin, HIGH);
delay(500);
digitalWrite(LedPin, LOW);
}
}
void openCloseIwanted()
{
s = Serial.read();
for (int i = 0; i < s ; i++)
{
delay(500);
digitalWrite(LedPin, HIGH);
delay(500);
digitalWrite(LedPin, LOW);
}
}
我的临界数字是3。例如,当我发送3和5时,我想看到LED闭嘴,LED必须是五次开放闭合。请帮助我!
我解决了我的问题,并想在这里分享。我的arduino部分:
int number[3];
int n;
int i = 0;
int led = 12;
int led2=7;
void setup() {
// put your setup code here, to run once:
Serial.begin(9600);
pinMode(led, OUTPUT);
}
void loop() {
// put your main code here, to run repeatedly:
if (Serial.available() > 0) {
// read the incoming byte:
n = Serial.read();
if (i < 3)
{
number[i] = n;
switch (number[0])
{
case 1:
openClose();
break;
case 2:
openCloseTwice();
break;
case 3:
if (i == 2)
{
for (int j = 0; j < number[1]; j++)
{
delay(500);
digitalWrite(led, HIGH);
delay(500);
digitalWrite(led, LOW);
}
delay(500);
for (int k = 0; k < number[2]; k++)
{
delay(500);
digitalWrite(led2, HIGH);
delay(500);
digitalWrite(led2, LOW);
}
}
break;
default:
break;
}
i++;
}
else
{
i = 0;
}
}
}
void openClose()
{
for (int i = 0; i < 1; i++)
{
delay(500);
digitalWrite(led, HIGH);
delay(500);
digitalWrite(led, LOW);
}
}
void openCloseTwice()
{
for (int i = 0; i < 2; i++)
{
delay(500);
digitalWrite(led, HIGH);
delay(500);
digitalWrite(led, LOW);
}
}
和我的C#部分:
if (serialPort1.IsOpen)
{
int MyInt = Convert.ToInt32(textBox1.Text);
byte[] b = BitConverter.GetBytes(MyInt);
serialPort1.Write(b, 0, 1);
int MyInt2 = Convert.ToInt32(textBox2.Text);
byte[] z = BitConverter.GetBytes(MyInt2);
serialPort1.Write(z, 0, 1);
int MyInt3 = Convert.ToInt32(textBox3.Text);
byte[] p = BitConverter.GetBytes(MyInt3);
serialPort1.Write(p, 0, 1);
}
else
{
MessageBox.Show("Please control your connection");
}
感谢您的帮助。
您的代码中有3个问题。
-
您在这里致电
Serial.read()
:case 3: s = Serial.read(); if (s !=0) { openCloseIwanted(); }
但是您实际上不知道
byte
是否已经在Serial
上可用。 -
您呼叫再次
Serial.read()
这里:void openCloseIwanted() { s = Serial.read(); for (int i = 0; i < s ; i++) { delay(500); digitalWrite(LedPin, HIGH); delay(500); digitalWrite(LedPin, LOW); } }
未检查
byte
是否可在Serial
上可用。 -
您在
C#
源代码中发送4 bytes
,而不是1
:if (MyInt == 3) { int MyInt2 = Convert.ToInt32(textBox2.Text); byte[] s = BitConverter.GetBytes(MyInt2); serialPort1.Write(s, 0, 4); }
根据
write()
的文档。如果您发送4 bytes
,则不应仅阅读1
,甚至不应以独立/无关的方式读取CC_12。
如果您发送4 bytes
,则应:
-
在输入上至少等待
4 bytes
可用:while (Serial.available() < 4) { };
-
然后将这些字节存储到
long
变量中:unsigned long lvar = 0; for (byte i = 0; i < 3; ++i) { lvar = (lvar << 8) + (byte) Serial.read(); }
您需要
unsigned long
,因为 arduino 上的int
只有2
字节。 -
然后将
lval
作为参数传递给您的功能void openCloseIwanted(unsigned long lval)
也许一个更好的解决方案是仅在C#
代码中发送1 byte
,我认为您不需要255
眨眼,对吗?
请注意,在case 3:
中修复代码可能不够,因为您也是第一次发送1, 2, 3
的4 bytes
。根据您体系结构的字节eNdianess ,可以在读取包含1, 2, 3
的byte
之前或之后对C#
中原始int
的领先0
s进行解析。这意味着您可能会通过Serial
获得可能未对准数据的。
为什么不在其 ascii 表示中发送/接收值,而不是尝试执行 binary 输入/输出?那应该更容易处理。