重力加速度传感器角度输出

#define PI 3.14159265

//返回角度

float MPU6050_Get_Angle(float x,float y,float z,u8 dir) 
{
        float temp;
        float res=0;
 
        switch(dir)
        {
                case 0://计算Z轴与自然Z轴的夹角
                        temp=z/sqrt((x*x+y*y));
                        res=atan(temp);
                     break;
                case 1://计算X轴与自然X轴的夹角
                        temp=x/sqrt((y*y+z*z));
                        res=atan(temp);
                        break;
                case 2://计算Y轴与自然Y轴的夹角
                        temp=y/sqrt((x*x+z*z));
                        res=atan(temp);
                        break;
        }


        return res*180/PI;

}

main()

{


while(1)

{

       //GetData(ACCEL_XOUT_H) ==>读取X加速度

       //GetData(ACCEL_YOUT_H) ==>读取Y加速度

       //GetData(ACCEL_ZOUT_H) ==>读取Z加速度

printf(" Z轴角度",MPU6050_Get_Angle((float)GetData(ACCEL_XOUT_H),(float)GetData(ACCEL_YOUT_H),(float)GetData(ACCEL_ZOUT_H),0));

        printf(" X轴角度",MPU6050_Get_Angle((float)GetData(ACCEL_XOUT_H),(float)GetData(ACCEL_YOUT_H),(float)GetData(ACCEL_ZOUT_H),1));

        printf(" Y轴角度",MPU6050_Get_Angle((float)GetData(ACCEL_XOUT_H),(float)GetData(ACCEL_YOUT_H),(float)GetData(ACCEL_ZOUT_H),2));

}

}

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值