An input/output controller for virtual pinball machines, with plunger position tracking, accelerometer-based nudge sensing, button input encoding, and feedback device control.

Dependencies:   USBDevice mbed FastAnalogIn FastIO FastPWM SimpleDMA

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers MMA8451Q.h Source File

MMA8451Q.h

00001 /* Copyright (c) 2010-2011 mbed.org, MIT License
00002 *
00003 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
00004 * and associated documentation files (the "Software"), to deal in the Software without
00005 * restriction, including without limitation the rights to use, copy, modify, merge, publish,
00006 * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
00007 * Software is furnished to do so, subject to the following conditions:
00008 *
00009 * The above copyright notice and this permission notice shall be included in all copies or
00010 * substantial portions of the Software.
00011 *
00012 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
00013 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
00014 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
00015 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
00016 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
00017 */
00018 
00019 #ifndef MMA8451Q_H
00020 #define MMA8451Q_H
00021 
00022 #include "mbed.h"
00023 
00024 /**
00025 * MMA8451Q accelerometer example
00026 *
00027 * @code
00028 * #include "mbed.h"
00029 * #include "MMA8451Q.h"
00030 * 
00031 * #define MMA8451_I2C_ADDRESS (0x1d<<1)
00032 * 
00033 * int main(void) {
00034 * 
00035 * MMA8451Q acc(P_E25, P_E24, MMA8451_I2C_ADDRESS);
00036 * PwmOut rled(LED_RED);
00037 * PwmOut gled(LED_GREEN);
00038 * PwmOut bled(LED_BLUE);
00039 * 
00040 *     while (true) {       
00041 *         rled = 1.0 - abs(acc.getAccX());
00042 *         gled = 1.0 - abs(acc.getAccY());
00043 *         bled = 1.0 - abs(acc.getAccZ());
00044 *         wait(0.1);
00045 *     }
00046 * }
00047 * @endcode
00048 */
00049 class MMA8451Q
00050 {
00051 public:
00052   /**
00053   * MMA8451Q constructor
00054   *
00055   * @param sda SDA pin
00056   * @param sdl SCL pin
00057   * @param addr addr of the I2C peripheral
00058   */
00059   MMA8451Q(PinName sda, PinName scl, int addr);
00060 
00061   /**
00062   * MMA8451Q destructor
00063   */
00064   ~MMA8451Q();
00065   
00066   /**
00067   *  Reset the accelerometer hardware and set our initial parameters
00068   */
00069   void init();
00070 
00071   /**
00072    * Enter standby mode
00073    */
00074   void standby();
00075   
00076   /**
00077    * Enter active mode
00078    */
00079   void active();
00080   
00081   /**
00082    * Get the value of the WHO_AM_I register
00083    *
00084    * @returns WHO_AM_I value
00085    */
00086   uint8_t getWhoAmI();
00087 
00088   /**
00089    * Get X axis acceleration
00090    *
00091    * @returns X axis acceleration
00092    */
00093   float getAccX();
00094 
00095   /**
00096    * Get Y axis acceleration
00097    *
00098    * @returns Y axis acceleration
00099    */
00100   float getAccY();
00101   
00102   /**
00103    *  Read an X,Y pair
00104    */
00105   void getAccXY(float &x, float &y);
00106   
00107   /**
00108    *  Read X,Y,Z.  This is the most efficient way to fetch
00109    *  all of the axes at once, since it fetches all three
00110    *  in a single I2C transaction.
00111    */
00112   void getAccXYZ(float &x, float &y, float &z);
00113 
00114   /**
00115    * Get Z axis acceleration
00116    *
00117    * @returns Z axis acceleration
00118    */
00119   float getAccZ();
00120 
00121   /**
00122    * Get XYZ axis acceleration
00123    *
00124    * @param res array where acceleration data will be stored
00125    */
00126   void getAccAllAxis(float * res);
00127   
00128   /**
00129    * Set interrupt mode.  'pin' is 1 for INT1_ACCEL (PTA14) and 2 for INT2_ACCEL (PTA15).
00130    * The caller is responsible for setting up an interrupt handler on the corresponding
00131    * PTAxx pin.
00132    */
00133   void setInterruptMode(int pin);
00134 
00135 private:
00136   I2C m_i2c;
00137   int m_addr;
00138   void readRegs(int addr, uint8_t * data, int len);
00139   void writeRegs(uint8_t * data, int len);
00140   int16_t getAccAxis(uint8_t addr);
00141 
00142 };
00143 
00144 #endif