/* * Author: Jon Trulson * Copyright (c) 2016-2017 Intel Corporation. * * The MIT License * * This program and the accompanying materials are made available under the * terms of the The MIT License which is available at * https://opensource.org/licenses/MIT. * * SPDX-License-Identifier: MIT */ var sensorObj = require('jsupm_bno055'); // Instantiate an BNO055 using default parameters (bus 0, addr // 0x28). The default running mode is NDOF absolute orientation // mode. var sensor = new sensorObj.BNO055(); console.log("First we need to calibrate. 4 numbers will be output every"); console.log("second for each sensor. 0 means uncalibrated, and 3 means"); console.log("fully calibrated."); console.log("See the UPM documentation on this sensor for instructions on"); console.log("what actions are required to calibrate."); console.log(""); // do the calibration... var calInterval = setInterval(function() { if (sensor.isFullyCalibrated()) { clearInterval(calInterval); console.log(""); console.log("Calibration complete."); console.log(""); setInterval(outputData, 250) } else { var intData = sensor.getCalibrationStatus(); console.log("Magnetometer: " + intData.get(0) + " Accelerometer: " + intData.get(1) + " Gyroscope: " + intData.get(2) + " System: " + intData.get(3)); } }, 1000); // now output various fusion data every 250 milliseconds function outputData() { sensor.update(); var floatData = sensor.getEulerAngles(); console.log("Euler: Heading: " + floatData.get(0) + " Roll: " + floatData.get(1) + " Pitch: " + floatData.get(2) + " degrees"); floatData = sensor.getQuaternions(); console.log("Quaternion: W: " + floatData.get(0) + " X:" + floatData.get(1) + " Y: " + floatData.get(2) + " Z: " + floatData.get(3)); floatData = sensor.getLinearAcceleration(); console.log("Linear Acceleration: X: " + floatData.get(0) + " Y: " + floatData.get(1) + " Z: " + floatData.get(2) + " m/s^2"); floatData = sensor.getGravityVectors(); console.log("Gravity Vector: X: " + floatData.get(0) + " Y: " + floatData.get(1) + " Z: " + floatData.get(2) + " m/s^2"); console.log(""); }; // exit on ^C process.on('SIGINT', function() { sensor = null; sensorObj.cleanUp(); sensorObj = null; console.log("Exiting."); process.exit(0); });