暂无描述

lsm303.js 2.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*jslint node:true, vars:true, bitwise:true, unparam:true */
  2. /*jshint unused:true */
  3. /*global */
  4. /*
  5. * Author: Zion Orent <zorent@ics.com>
  6. * Copyright (c) 2014 Intel Corporation.
  7. *
  8. * Permission is hereby granted, free of charge, to any person obtaining
  9. * a copy of this software and associated documentation files (the
  10. * "Software"), to deal in the Software without restriction, including
  11. * without limitation the rights to use, copy, modify, merge, publish,
  12. * distribute, sublicense, and/or sell copies of the Software, and to
  13. * permit persons to whom the Software is furnished to do so, subject to
  14. * the following conditions:
  15. *
  16. * The above copyright notice and this permission notice shall be
  17. * included in all copies or substantial portions of the Software.
  18. *
  19. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  20. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  21. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  22. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  23. * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  24. * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  25. * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  26. */
  27. var accelrCompassSensor = require('jsupm_lsm303');
  28. // Instantiate LSM303 compass on I2C
  29. var myAccelrCompass = new accelrCompassSensor.LSM303(0);
  30. setInterval(function()
  31. {
  32. // Load coordinates into LSM303 object
  33. var successFail = myAccelrCompass.getCoordinates();
  34. // in XYZ order. The sensor returns XZY,
  35. // but the driver compensates and makes it XYZ
  36. var coords = myAccelrCompass.getRawCoorData();
  37. // Print out the X, Y, and Z coordinate data using two different methods
  38. var outputStr = "coor: rX " + coords.getitem(0)
  39. + " - rY " + coords.getitem(1)
  40. + " - rZ " + coords.getitem(2);
  41. console.log(outputStr);
  42. outputStr = "coor: gX " + myAccelrCompass.getCoorX()
  43. + " - gY " + myAccelrCompass.getCoorY()
  44. + " - gZ " + myAccelrCompass.getCoorZ();
  45. console.log(outputStr);
  46. // Get and print out the heading
  47. console.log("heading: " + myAccelrCompass.getHeading());
  48. // Get the acceleration
  49. myAccelrCompass.getAcceleration();
  50. var accel = myAccelrCompass.getRawAccelData();
  51. // Print out the X, Y, and Z acceleration data using two different methods
  52. outputStr = "acc: rX " + accel.getitem(0)
  53. + " - rY " + accel.getitem(1)
  54. + " - Z " + accel.getitem(2);
  55. console.log(outputStr);
  56. outputStr = "acc: gX " + myAccelrCompass.getAccelX()
  57. + " - gY " + myAccelrCompass.getAccelY()
  58. + " - gZ " + myAccelrCompass.getAccelZ();
  59. console.log(outputStr);
  60. console.log(" ");
  61. }, 1000);