MMA7455加速度传感器測量角度
使用加速度传感器应该注意几点:
第一:确保你的IIC是正确的;
第二,首先必须校准系统,校准方法,例如以下:将7455平放,保证z轴向下,这是假设系统是Ok的,那么x轴输出为0,y轴输出为0,z轴输出为63左右,假设不为以上參数,应该做例如以下调整:測量值比实际值小的情况下,往校准寄存器里面写入一个2*误差值;假设測量值假设大于实际值,应该写入一个值为相应误差的负值的ASCII码,比方假设測出值为70,那么应该写入-16,即(0xf0);
下面就是我调试mma7455的代码:
#include "msp430f5438.h"
#include "public.h"
#include "simulate_iic.h"
#include <stdbool.h> #include "init.h" #include "mma7455.h"
#include "lcd1602.h"
#include<math.h>
typedef unsigned int uint;
typedef unsigned char uchar;
char mma7455write_byte(unsigned char reg,unsigned char data)//寄存器地址,数据
{
char flag;
// WDTCTL = WDTPW + WDTHOLD; // 禁止看门狗定时器
iic_start();//起始信号
write_byte(0x3a);//数据发送
flag=get_ack();//接受应答位,即数据成功发送后,接受到的应答
if(flag)
{
flag=0;
write_byte(reg);//数据发送
} flag=get_ack();//接受应答位,即数据成功发送后,接受到的应答
if(flag)
{
flag=0;
write_byte(data);
} flag=get_ack();
if(flag)
{
flag=0;
iic_stop();
return 0;
} return 1; } char readMMA7455Byte(unsigned char regadd)
{
char flag;
char z;
z=0;
iic_start();
write_byte(0x3a);//先写入器件地址
flag=get_ack();
if(flag)
{
write_byte(regadd);//有应答之后再写寄存器地址
flag=0;
} flag=get_ack();
if(flag)
{
flag=0;
iic_start();//继续等应答之后写入该地址和读命令,但是认为这不必要这么做
write_byte(0x3b);//但是时间的原因,仅仅有找着实例的操作先写着,以后再改动
} flag=get_ack();
if(flag)
{
flag=0;
z=read_byte();
} send_ack(); iic_stop(); return z; }
// X:255 1.65V -1.00g
// 012345678901234567
void Cvt_Str(char zifu[], char V1)
{
char characters[17]="0123456789ABCDEF";
char tv=0; tv=V1/100;
zifu[2] = characters[tv];
tv=(V1%100)/10;
zifu[3] = characters[tv];
tv=V1%10;
zifu[4] = characters[tv]; zifu[5] = ' '; zifu[6] = '0';
zifu[7] = 'x';
tv=V1/16;
zifu[8] = characters[tv];
tv=V1%16;
zifu[9] = characters[tv]; zifu[10] = ' '; if(V1>127)
{
zifu[11] = '-';
tv=255-V1;
zifu[12] = characters[tv/63];
zifu[13] = '.';
zifu[14] = characters[((tv*100/63)%100)/10];
zifu[15] = characters[(tv*100/63)%10];
}
else
{
zifu[11] = '+';
tv=V1;
zifu[12] = characters[tv/63];
zifu[13] = '.';
zifu[14] = characters[((tv*100/63)%100)/10];
zifu[15] = characters[(tv*100/63)%10];
}
zifu[16] = 'g';
}
uint arc_tan2(uchar Ax,uchar Ay)
{
int diat_t;
float m;
m=atan2(Ay,Ax);
diat_t=(int)(m*1800/3.14);
return diat_t;
}
uint measure()
{
uchar x;
uchar y;
uint x1,y1;
uchar xsign,ysign;
uint angle;
angle=0;
x=readMMA7455Byte(0x06);
y=readMMA7455Byte(0x07);
x=x+0x2C;
y=y+0x25;
if(x>127)
{
x=255-x;
x1=((float)x*100)/63.0;
xsign=0x2b;
}
else
{
x1=((float)x*100)/63.0;
xsign=0x2d;
}
if(y>127)
{
y=255-y;
y1=((float)y*100)/63.0;
ysign=0x2b;
}
else
{
y1=((float)y*100)/63.0;
ysign=0x2d;
}
angle = arc_tan2(x1,y1);
/*if(xsign==0x2b&&ysign==0x2b)
{
angle = arc_tan2(x1,y1);
}
else if(xsign==0x2b&&ysign==0x2d)
{
angle = 900+arc_tan2(y1,x1);;
}
else if(xsign==0x2d&&ysign==0x2d)
{
angle = 2700-angle;
}
else if(xsign==0x2d&&ysign==0x2b)
{
angle = 2700+angle;
}*/
return angle;
}
void main()
{
char txtbuf[16]="X:255 -1.00g";
//uchar x,y,x2,y2;
//volatile uint x1,y1;
// uchar j,k;
clk_init();
lcd1602_pin_init();
lcd_init();
delay_ms(50);
while(mma7455write_byte(0x16,0x005));
while(mma7455write_byte(0x10,0xff));//校正X值
while(mma7455write_byte(0x11,0x07));
while(mma7455write_byte(0x12,0x18));//校正Y值
while(mma7455write_byte(0x14,0xDC));//校正Z值
while(mma7455write_byte(0x15,0xFF));
while(1)
{
/*lcd_pos(0,0);
lcd_wdat('a');
lcd_wdat('n');
lcd_wdat('g');
lcd_wdat('l');
lcd_wdat('e');
lcd_wdat(':'); lcd_printf(measure());//x
//delay_ms(1000);
//lcd_wcmd(0x01); */ //显示清屏 /*x=readMMA7455Byte(0x06);
y=readMMA7455Byte(0x07);
x2=x+0x2C;
y2=y+0x25;
x=x+0x2C;
y=y+0x25;
if(x>0x7f)
{
x=255-x;
j=1;
x1=((float)x*100)/63.0;
}
else
{
x1=((float)x*100)/63.0;
j=0;
}
if(y>0x7f)
{
y=255-y;
y1=((float)y*100)/63.0;
k=1;
}
else
{
y1=((float)y*100)/63.0;
k=0;
}
lcd_pos(0,0);
if(j==1) lcd_wdat('-');
else lcd_wdat('+');
lcd_char(x1);
lcd_pos(0,1);
if(k==1) lcd_wdat('-');
else lcd_wdat('+');
lcd_char(y1);
delay_ms(1000);
lcd_wcmd(0x01); lcd_pos(0,0);
Cvt_Str(txtbuf,x2);
txtbuf[0]='X';
lcd_string(txtbuf);
lcd_pos(0,1);
Cvt_Str(txtbuf,y2);
txtbuf[0]='Y';
lcd_string(txtbuf);
delay_ms(1000);
lcd_wcmd(0x01);*/ //显示清屏
lcd_pos(0,0);
Cvt_Str(txtbuf,readMMA7455Byte(0x08));
txtbuf[0]='Z';
lcd_string(txtbuf);
lcd_pos(0,1);
lcd_printf(arc_tan2(readMMA7455Byte(0x08),readMMA7455Byte(0x06)));
delay_ms(1000);
lcd_wcmd(0x01); //显示清屏 lcd_pos(0,1);
Cvt_Str(txtbuf,readMMA7455Byte(0x06));
txtbuf[0]='X';
lcd_string(txtbuf);
lcd_pos(0,0);
Cvt_Str(txtbuf,readMMA7455Byte(0x07));
txtbuf[0]='Y';
lcd_string(txtbuf);
delay_ms(1000);
lcd_wcmd(0x01); //显示清屏
}
}
MMA7455加速度传感器測量角度的更多相关文章
- ADXL3xx: 读取 ADXL3xx 加速度传感器
原文链接:https://www.arduino.cc/en/Tutorial/ADXL3xx ADXL3xx加速度传感器 本教程将为你展示如何读取Analog Devices的ADXL3xx系列加速 ...
- Android的重力传感器(3轴加速度传感器)简单实例
重力感应主要是依靠手机的加速度传感器(accelerometer)来实现 在Android的开发中一共有八种传感器但是不一定每一款真机都支持这些传感器.因为很多功能用户根本不care的所以可能开发商会 ...
- 与众不同 windows phone (18) - Device(设备)之加速度传感器, 数字罗盘传感器
原文:与众不同 windows phone (18) - Device(设备)之加速度传感器, 数字罗盘传感器 [索引页][源码下载] 与众不同 windows phone (18) - Device ...
- 【Espruino】NO.12 加速度传感器演示
http://blog.csdn.net/qwert1213131/article/details/31035403 本文属于个人理解,能力有限,纰漏在所难免.还望指正! [小鱼有点电] [Espru ...
- OneNET麒麟座应用开发之五:获取加速度传感器ADXL345数据
由于数据采集站基本都安装在野外或者楼顶,安装位置以及震动对检测数据的准确性有一定影响.所以想要有一个位置状态数据,正好发现麒麟作上有ADXL345,这样一个数字输出的加速度传感器.如图中红框所示: 1 ...
- [原创]cocos2d-x研习录-第三阶 特性之加速度传感器
智能手机的游戏与应用中,也经常会用到加速传感器事件来丰富用户的体验,比如飞翔的企鹅(英文AirPenguin)游戏就是通过加速度传感器来控制角色的移动和跳跃方向.下面学习Cocos2D-x中如何使用加 ...
- 六轴加速度传感器MPU6050官方DMP库到瑞萨RL78/G13的移植
2015年的电赛已经结束了.赛前接到器件清单的时候,看到带防护圈的多旋翼飞行器赫然在列,又给了一个瑞萨RL78/G13的MCU,于是自然联想到13年的电赛,觉得多半是拿RL78/G13做四旋翼的主控, ...
- Android--保持加速度传感器在屏幕关闭后运行
由于写论文需要,需要用手机加速度采集数据,关于android加速度传感器的介绍网上一抓一大把,但大多都是大同小异,跟官网文档差不多.自己写了个取加速度传感器的APK,发现数据有点不对劲,原理屏幕一关后 ...
- Android加速度传感器实现“摇一摇”,带手机振动
由于代码有点多,所以就分开写了,注释还算详细,方便学习 Activity package com.lmw.android.test; import android.app.Activity; im ...
随机推荐
- ASP.NET过滤器的应用
在J2EE Web开发中有过滤器filter,该filter可以对指定的URL访问进行拦截,并执行过滤器的方法,根据实际应用情况,在过滤器中修改请求的代码.判断会话信息,也可以做权限控制,总之这个过滤 ...
- iOS开发中xib和Storyboard中需要注意的事项
使用xib注意事项: 1.只有自带view的控件才可以使用xib,因为它本身就是一个view 2.在使用可视化控件添加属性(代码)时候,如果删除了属性代码,一定要在xib上解除关联(不然会崩溃) 3. ...
- VS2013配置opencv3.0.0 (win8.1)
今天下载了最新版本的opencv3.0.0,之前一直是opencv2.4.8 点击.exe文件,我将解压后的文件夹放在D:\盘,取名opencv30,D:\opencv30 添加环境变量:D:\ope ...
- arm:c语言和汇编混合编程
仅作演示. 1.C和汇编可相互调用,汇编子函数格式参考 汇编:普通的函数调用的汇编代码解析 http://www.cnblogs.com/mylinux/p/4139972.html 本文演示了 : ...
- arm:启动代码判断是从nand启动还是从norflash启动,拷贝程序到内存的过程
一.nand启动和nor启动:[1] CPU从0x00000000位置开始运行程序. 1.nand启动: 如果将S3C2440配置成从NANDFLASH启动(将开发板的启动开关拔到nand端,此时OM ...
- Orleans-Hello World
Orleans-Hello World http://www.rm5u.com/orleans/orleans-intro.html 什么是Orleans? Orleans(奥尔良) ...
- Qt调用DLL
声明: 事先我已经自己动手写了一个简单的dll文件(myDLL.dll),C版接口的.并且用我前两篇有关DLL文章里面的方法,从dll中导出了导入库(.lib)文件,dll中有两个函数,原型如下: ...
- git gitk命令
通过gitk命令,在单独的界面上查看项目源码在各个时间点上的代码提交情况. 各个commit 各个tag ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~` 更多详细的介绍 ...
- Java正则表达式基本应用
一.概述 正则表达式因为其强大的字符串处理能力,刚开始被被广泛地应用到各种UNIX工具中,如大家熟知的 Perl脚本语言 .后来正则表达式在各种 计算机语言 和各种应用领域得到了广泛的应用和发展,目前 ...
- mysql数据库修改数据库编码,字段编码与表编码(转) good
最近看了一下KIGG框架,发现在用EF + MYSQL数据库时,数据出现了乱码,用工具(Navicat )查看一下表category的结构发现 KIGG 数据库的默认情况是用latin1编码的(DEF ...