unity 串口读取 g4 激光雷达数据

本文介绍了一个串口数据接收与解析的C#实现案例,重点在于从雷达设备接收并解析特定格式的二进制数据,然后将这些数据转换为角度和距离信息进行实时的图形化显示。

主要参考了 https://blog.youkuaiyun.com/weixin_44345862/article/details/86500349 此篇文章,在此表示感谢。

先是把数据读出来,后面还有很多工作要做

    private void DataReceiveFunction()
    {
        print("数据监测中···");
        byte[] dataBytes = new byte[255];//存储数据
        int bytesToRead = 0;//记录获取的数据长度
        while (isAlive)
        {

            if (sp != null && sp.IsOpen)
            {
                try
                {

                    bytesToRead = sp.Read(dataBytes, 0, dataBytes.Length);
                    for (int i = 0; i < bytesToRead; i++)
                    {
                        list.Add(dataBytes[i]);

                    }

                }
                catch (Exception ex)
                {
					print("DataReceiveFunction " + ex.Message);
                }
            }
			Thread.Sleep(1);//50     
        }
    }

 

void Update()
    {
        interval += Time.deltaTime;
        if (interval >= 1f)// iniconfig.instance.getfloat("sys", "aipatrol"))
        {
             interval = 0;
             ClearAllItem("Panel");
            list.Clear();
        }
        if (list.Count > 20)
        {
            for (int i = 0; i < list.Count; i++)
            {
                if (i < list.Count - 4)
                {
                    // 发现数据开头
                    if (list[i] == Convert.ToByte("AA", 16) &&
                        list[i + 1] == Convert.ToByte("55", 16) &&
                        list[i + 2] == Convert.ToByte("00", 16))
                    {
                        // 采集数据数量
                        int count = list[i + 3];
                        if (count > 1)
                        {
                            //判断是否接收完了全部数据
                            if (list.Count - i > count * 2 + 10)
                            {
                                recvStr = "";
                                List<byte> getdata = list.GetRange(i, count * 2 + 10);
                                for (int j = 0; j < getdata.Count; j++)
                                    recvStr += getdata[j].ToString("X2") + " ";
                                float fsa = (ByteToInt(getdata[4], getdata[5]) >> 1) / 64;
                                float lsa = (ByteToInt(getdata[6], getdata[7]) >> 1) / 64;
                                for (int j = 0; j < count * 2; j += 2)
                                {
                                    // 距离毫米
                                    int dis = ByteToInt(getdata[j + 10], getdata[j + 11]) / 4;
                                    if (dis > 1)
                                    {
                                        // 计算角度 顺时针计算 所以结束减开始
                                        float diff = lsa - fsa;
                                        if (diff < 0)
                                        {
                                            diff = lsa + (360 - fsa);
                                            //print(lsa + " ; " + fsa);
                                        }
                                        float angle = diff / (count - 1) * (j / 2) + fsa;
                                        //print(fsa + " ; " + lsa + " ; " + angle + " ; " + dis);
                                        RawImage img = (RawImage)Instantiate(rimg, new Vector3(dis * 4.0f, 0, 0), Quaternion.identity);
                                        img.transform.SetParent(rpanel.transform, true);
                                        img.transform.RotateAround(rpanel.transform.position, new Vector3(0,0,1), -angle);

                                    }
                                }
                                list.RemoveRange(i, count * 2 + 10);
                                
                                break;
                            }
                        }
                    }
                }
            }
        }
        reText.text = recvStr;
    }

源码公开了 ,手头没有G4雷达了,不知道还能不能运行了。 

链接:https://pan.baidu.com/s/189MI81WIpqZMLZKnieQKFw 
提取码:43p6 
复制这段内容后打开百度网盘手机App,操作更方便哦 

 

评论 6
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值