跨届大侠
- 积分
- 9286
- 威望
- 4170
- 贡献
- 2660
- 兑换币
- 2694
- 注册时间
- 2014-2-26
- 在线时间
- 1228 小时
|
6#
楼主 |
发表于 2015-3-19 18:48:18
|
只看该作者
fokki 发表于 2015-3-19 08:22
那个,,我们的进度好像差不多,但是我还不知道怎么用虚拟示波器显示波形,你能告诉我你使怎样使陀螺仪和加 ...
额,讲起来比较复杂。。。就是通过串口将数据发送到上位机,我用的上位机是用下面代码发送的:
unsigned short CRC_CHECK(unsigned char *Buf, unsigned char CRC_CNT)
{
unsigned short CRC_Temp;
unsigned char i,j;
CRC_Temp = 0xffff;
for (i=0;i<CRC_CNT; i++){
CRC_Temp ^= Buf;
for (j=0;j<8;j++) {
if (CRC_Temp & 0x01)
CRC_Temp = (CRC_Temp >>1 ) ^ 0xa001;
else
CRC_Temp = CRC_Temp >> 1;
}
}
return(CRC_Temp);
}
void OutPut_Data(void)
{
int temp[4] = {0};
unsigned int temp1[4] = {0};
unsigned char databuf[10] = {0};
unsigned char i;
unsigned short CRC16 = 0;
for(i=0;i<4;i++)
{
temp = (int)OutData;
temp1 = (unsigned int)temp;
}
for(i=0;i<4;i++)
{
databuf[i*2] = (unsigned char)(temp1%256);
databuf[i*2+1] = (unsigned char)(temp1/256);
}
CRC16 = CRC_CHECK(databuf,8);
databuf[8] = CRC16%256;
databuf[9] = CRC16/256;
for(i=0;i<10;i++)
uart_putchar(UART2,databuf);
}
主函数里写:
OutData[0]=Acc_jiao; // Z轴转的角度
OutData[1]=Gyr_jiao; //加速度计计算得到的角度
OutData[2]=GyrAccCra; //最后融合得到的角度
OutPut_Data();
就ok了。
|
|