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 ...
随机推荐
- UVA 531 - Compromise(dp + LCS打印路径)
Compromise In a few months the European Currency Union will become a reality. However, to join th ...
- IOS SWIFT 网络请求JSON解析 基础一
前言:移动互联网时代,网络通信已经是手机端必不可少的功能.应用中也必不可少地使用了网络通信,增强客户端与服务器交互.使用NSURLConnection实现HTTP的通信.NSURLConnection ...
- 17.1 Replication Configuration 复制:
17.1 Replication Configuration 复制: 17.1.1 How to Set Up Replication 17.1.2 Replication Formats 17.1. ...
- boost::share_ptr用法
boost中提供了几种智能指针方法:scoped_ptr shared_ptr intrusive_ptr weak_ptr,而标准库中提供的智能指针为auto_ptr. 这其中,我最喜欢,使用最多的 ...
- 我的Android进阶之旅------>HTTP 返回状态值详解
(本文转载于:http://blog.csdn.net/ithomer/article/details/10240351) 当用户点击或搜索引擎向网站服务器发出浏览请求时,服务器将返回Http Hea ...
- ARM相关知识
ARM7采用冯·诺依曼(Von-Neumann)结构,数据存储器和程序存储器重合在一起. 同时,此结构也被大多数计算机所采用. ARM7为三级流水线结构(取指,译码,执行),平均功耗为0.6mW ...
- HNCU1330:算法3-1:八进制数
http://hncu.acmclub.com/index.php?app=problem_title&id=111&problem_id=1330 题目描述 将十进制数转换为八进制, ...
- C/C++迭代器使用具体解释
迭代器是一种检查容器内元素并遍历元素的数据类型.能够替代下标訪问vector对象的元素. 每种容器类型都定义了自己的迭代器类型,如 vector: vector<int>::iterato ...
- Oracle数据库索引使用及索引失效总结
容易引起oracle索引失效的原因很多: 1.在索引列上使用函数.如SUBSTR,DECODE,INSTR等,对索引列进行运算.需要建立函数索引就可以解决了. 2.新建的表还没来得及生成统计信息,分析 ...
- UVA 10317 - Equating Equations (背包)
Problem F Equating Equations Input: standard input Output: standard output Time Limit: 6 seconds Mem ...