Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/284.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 在C中按串行通信键时消除延迟#_C#_Keyboard_Servo - Fatal编程技术网

C# 在C中按串行通信键时消除延迟#

C# 在C中按串行通信键时消除延迟#,c#,keyboard,servo,C#,Keyboard,Servo,我是C#的新手,目前正在构建一个windows窗体应用程序,通过按键盘上的一个键来控制2个伺服电机 通过串口进行通信,目前一切正常。问题出现在发动机控制中 当我按下键将电机移动到所需方向并保持按下时,伺服最初有一个小输入,然后大约一秒钟后,它开始连续转动 要使用密钥拦截,我使用以下代码: protected override bool ProcessCmdKey(ref Message msg, Keys keyData) { if (keyData == Keys.L

我是C#的新手,目前正在构建一个windows窗体应用程序,通过按键盘上的一个键来控制2个伺服电机

通过串口进行通信,目前一切正常。问题出现在发动机控制中

当我按下键将电机移动到所需方向并保持按下时,伺服最初有一个小输入,然后大约一秒钟后,它开始连续转动

要使用密钥拦截,我使用以下代码:

protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
 {
            if (keyData == Keys.Left)
            {
                SerialPort01.Write("L");
            }
            if (keyData == Keys.Right)
            {
                SerialPort01.Write("R");
            }
            if (keyData == Keys.Up)
            {
                SerialPort01.Write("U");
            }
            if (keyData == Keys.Down)
            {
                SerialPort01.Write("D");
            }
            return base.ProcessCmdKey(ref msg, keyData);
 }

你能帮我吗?谢谢这是完整的代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.IO.Ports;

namespace ControlloMotori_v01
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            PorteDisponibili();
        }
        //Definisco una funzione che ricerca le porte disponibili
        void PorteDisponibili()
        {
            string[] porte = SerialPort.GetPortNames();
            CmBox_PortaSeriale.Items.AddRange(porte);
        }

        private void btn_Connetti_Click(object sender, EventArgs e)
        {
            try
            {
                if (CmBox_BaudRate.Text == "" || CmBox_PortaSeriale.Text == "")
                {
                    MessageBox.Show("Selezionare impostazioni per la porta seriale");
                }
                else
                {
                    SerialPort01.PortName = CmBox_PortaSeriale.Text;
                    SerialPort01.BaudRate = Convert.ToInt32(CmBox_BaudRate.Text);
                    SerialPort01.Open();
                    GroupBox1.Enabled = true;
                    btn_Disconnetti.Enabled = true;
                    btn_Connetti.Enabled = false;
                    CmBox_BaudRate.Enabled = false;
                    CmBox_PortaSeriale.Enabled = false;
                }
            }
            catch (UnauthorizedAccessException)
            {
                MessageBox.Show("Unauthorized Access Exception");
            }
        }

        private void btn_Disconnetti_Click(object sender, EventArgs e)
        {
            SerialPort01.Close();
            GroupBox1.Enabled = false;
            btn_Disconnetti.Enabled = false;
            btn_Connetti.Enabled = true;
            CmBox_PortaSeriale.Enabled = true;
            CmBox_BaudRate.Enabled = true;
        }

        protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
        {
            if (keyData == Keys.Left)
            {
                SerialPort01.Write("L");
            }
            if (keyData == Keys.Right)
            {
                SerialPort01.Write("R");
            }
            if (keyData == Keys.Up)
            {
                SerialPort01.Write("U");
            }
            if (keyData == Keys.Down)
            {
                SerialPort01.Write("D");
            }
            return base.ProcessCmdKey(ref msg, keyData);
        }
    }
}

如何检测按键?这段代码太差了,无法帮助您……请看:这里还有一个非常古老的答案,建议使用计时器&检测按键向下/向上事件-您将如何做到这一点取决于您的平台-Winforms/WPF/等等