208 lines
5.4 KiB
C
208 lines
5.4 KiB
C
|
/* Copyright (c) <year> <copyright holders>, MIT License
|
||
|
*
|
||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of this software
|
||
|
* and associated documentation files (the "Software"), to deal in the Software without restriction,
|
||
|
* including without limitation the rights to use, copy, modify, merge, publish, distribute,
|
||
|
* sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
|
||
|
* furnished to do so, subject to the following conditions:
|
||
|
*
|
||
|
* The above copyright notice and this permission notice shall be included in all copies or
|
||
|
* substantial portions of the Software.
|
||
|
*
|
||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
|
||
|
* BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||
|
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
*/
|
||
|
|
||
|
#include "mbed.h"
|
||
|
|
||
|
|
||
|
#ifndef MMA7660_H
|
||
|
#define MMA7660_H
|
||
|
|
||
|
#define MMA7660_ADDRESS 0x98
|
||
|
#define MMA7660_SENSITIVITY 21.33
|
||
|
|
||
|
#define MMA7660_XOUT_R 0x00
|
||
|
#define MMA7660_YOUT_R 0x01
|
||
|
#define MMA7660_ZOUT_R 0x02
|
||
|
#define MMA7660_TILT_R 0x03
|
||
|
#define MMA7660_INT_R 0x06
|
||
|
#define MMA7660_MODE_R 0x07
|
||
|
#define MMA7660_SR_R 0x08
|
||
|
|
||
|
|
||
|
/** An interface for the MMA7660 triple axis accelerometer
|
||
|
*
|
||
|
* @code
|
||
|
* //Uses the measured z-acceleration to drive leds 2 and 3 of the mbed
|
||
|
*
|
||
|
* #include "mbed.h"
|
||
|
* #include "MMA7660.h"
|
||
|
*
|
||
|
* MMA7660 MMA(p28, p27);
|
||
|
*
|
||
|
* DigitalOut connectionLed(LED1);
|
||
|
* PwmOut Zaxis_p(LED2);
|
||
|
* PwmOut Zaxis_n(LED3);
|
||
|
*
|
||
|
* int main() {
|
||
|
* if (MMA.testConnection())
|
||
|
* connectionLed = 1;
|
||
|
*
|
||
|
* while(1) {
|
||
|
* Zaxis_p = MMA.z();
|
||
|
* Zaxis_n = -MMA.z();
|
||
|
* }
|
||
|
*
|
||
|
* }
|
||
|
* @endcode
|
||
|
*/
|
||
|
class MMA7660
|
||
|
{
|
||
|
public:
|
||
|
/**
|
||
|
* The 6 different orientations and unknown
|
||
|
*
|
||
|
* Up & Down = X-axis
|
||
|
* Right & Left = Y-axis
|
||
|
* Back & Front = Z-axis
|
||
|
*
|
||
|
*/
|
||
|
enum Orientation {Up, Down,
|
||
|
Right, Left,
|
||
|
Back, Front,
|
||
|
Unknown
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Creates a new MMA7660 object
|
||
|
*
|
||
|
* @param sda - I2C data pin
|
||
|
* @param scl - I2C clock pin
|
||
|
* @param active - true (default) to enable the device, false to keep it standby
|
||
|
*/
|
||
|
MMA7660(PinName sda, PinName scl, bool active = true);
|
||
|
|
||
|
/**
|
||
|
* Tests if communication is possible with the MMA7660
|
||
|
*
|
||
|
* Because the MMA7660 lacks a WHO_AM_I register, this function can only check
|
||
|
* if there is an I2C device that responds to the MMA7660 address
|
||
|
*
|
||
|
* @param return - true for successfull connection, false for no connection
|
||
|
*/
|
||
|
bool testConnection( void );
|
||
|
|
||
|
/**
|
||
|
* Sets the active state of the MMA7660
|
||
|
*
|
||
|
* Note: This is unrelated to awake/sleep mode
|
||
|
*
|
||
|
* @param state - true for active, false for standby
|
||
|
*/
|
||
|
void setActive( bool state);
|
||
|
|
||
|
/**
|
||
|
* Reads acceleration data from the sensor
|
||
|
*
|
||
|
* When the parameter is a pointer to an integer array it will be the raw data.
|
||
|
* When it is a pointer to a float array it will be the acceleration in g's
|
||
|
*
|
||
|
* @param data - pointer to array with length 3 where the acceleration data will be stored, X-Y-Z
|
||
|
*/
|
||
|
void readData( int *data);
|
||
|
void readData( float *data);
|
||
|
|
||
|
/**
|
||
|
* Get X-data
|
||
|
*
|
||
|
* @param return - X-acceleration in g's
|
||
|
*/
|
||
|
float x( void );
|
||
|
|
||
|
/**
|
||
|
* Get Y-data
|
||
|
*
|
||
|
* @param return - Y-acceleration in g's
|
||
|
*/
|
||
|
float y( void );
|
||
|
|
||
|
/**
|
||
|
* Get Z-data
|
||
|
*
|
||
|
* @param return - Z-acceleration in g's
|
||
|
*/
|
||
|
float z( void );
|
||
|
|
||
|
/**
|
||
|
* Sets the active samplerate
|
||
|
*
|
||
|
* The entered samplerate will be rounded to nearest supported samplerate.
|
||
|
* Supported samplerates are: 120 - 64 - 32 - 16 - 8 - 4 - 2 - 1 samples/second.
|
||
|
*
|
||
|
* @param samplerate - the samplerate that will be set
|
||
|
*/
|
||
|
void setSampleRate(int samplerate);
|
||
|
|
||
|
/**
|
||
|
* Returns if it is on its front, back, or unknown side
|
||
|
*
|
||
|
* This is read from MMA7760s registers, page 12 of datasheet
|
||
|
*
|
||
|
* @param return - Front, Back or Unknown orientation
|
||
|
*/
|
||
|
Orientation getSide( void );
|
||
|
|
||
|
/**
|
||
|
* Returns if it is on it left, right, down or up side
|
||
|
*
|
||
|
* This is read from MMA7760s registers, page 12 of datasheet
|
||
|
*
|
||
|
* @param return - Left, Right, Down, Up or Unknown orientation
|
||
|
*/
|
||
|
Orientation getOrientation ( void );
|
||
|
|
||
|
|
||
|
private:
|
||
|
|
||
|
/**
|
||
|
* Writes data to the device
|
||
|
*
|
||
|
* @param adress - register address to write to
|
||
|
* @param data - data to write
|
||
|
*/
|
||
|
void write( char address, char data);
|
||
|
|
||
|
/**
|
||
|
* Read data from the device
|
||
|
*
|
||
|
* @param adress - register address to write to
|
||
|
* @return - data from the register specified by RA
|
||
|
*/
|
||
|
char read( char adress);
|
||
|
|
||
|
/**
|
||
|
* Read multiple regigsters from the device, more efficient than using multiple normal reads.
|
||
|
*
|
||
|
* @param adress - register address to write to
|
||
|
* @param length - number of bytes to read
|
||
|
* @param data - pointer where the data needs to be written to
|
||
|
*/
|
||
|
void read( char adress, char *data, int length);
|
||
|
|
||
|
/**
|
||
|
* Reads single axis
|
||
|
*/
|
||
|
float getSingle(int number);
|
||
|
|
||
|
I2C _i2c;
|
||
|
bool active;
|
||
|
float samplerate;
|
||
|
};
|
||
|
|
||
|
|
||
|
#endif
|