All Downloads are FREE. Search and download functionalities are using the official Maven repository.

lejos.hardware.sensor.MindsensorsCompass Maven / Gradle / Ivy

Go to download

leJOS (pronounced like the Spanish word "lejos" for "far") is a tiny Java Virtual Machine. In 2013 it was ported to the LEGO EV3 brick.

The newest version!
package lejos.hardware.sensor;

import lejos.hardware.port.I2CPort;
import lejos.hardware.port.Port;
import lejos.robotics.Calibrate;

/**
 * This class supports the Mindsensors compass sensor.
 * 
 * See http://www.mindsensors.com/index.php?module=pagemaster&PAGE_user_op=view_page&PAGE_id=56
 * 
 * author Lawrie Griffiths
 * 
 */
/**
 * MindSensor Compass sensor
* Description * *

* The code for this sensor has not been tested. Please report test results to * the leJOS forum. *

* *

*

* * * * * * * * * * * * * * * * * * * * * *
Supported modes
Mode nameDescriptionunit(s)Getter
CompassMeasures the orientation of the sensorDegrees, corresponding to the compass rose {@link #getCompassMode() }
AngleMeasures the orientation of the sensorDegrees, corresponding to the right hand coordinate system {@link #getAngleMode() }
* * *

* Sensor configuration
* The sensor can be calibrated for magnetic disturbances coming from the robot * (soft iron calibration). Use the startCalibration method to put the sensor in * calibration mode. While in calibration mode the sensor should be rotated * slowly for making 2 full rotations taking at least 20 seconds per turn. Then * end calibration with the endCalibration method. *

* * See * Sensor datasheet * See * Sensor Product page * See The * leJOS sensor framework * See {@link lejos.robotics.SampleProvider leJOS conventions for * SampleProviders} * *

* * * @author Lawrie Griffiths * */ public class MindsensorsCompass extends I2CSensor implements Calibrate { private final static byte COMMAND = 0x41; private final static byte BEGIN_CALIBRATION = 0x43; private final static byte END_CALIBRATION = 0x44; private byte[] buf = new byte[2]; /** * Create a compass sensor object * * @param port * I2C port for the compass * @param address * The I2C address used by the sensor */ public MindsensorsCompass(I2CPort port, int address) { super(port, address); init(); } /** * Create a compass sensor object * * @param port * I2C port for the compass */ public MindsensorsCompass(I2CPort port) { super(port, DEFAULT_I2C_ADDRESS); init(); } /** * Create a compass sensor object * * @param port * Sensor port for the compass * @param address * The I2C address used by the sensor */ public MindsensorsCompass(Port port, int address) { super(port, address); init(); } /** * Create a compass sensor object * * @param port * Sensor port for the compass */ public MindsensorsCompass(Port port) { super(port); init(); } protected void init() { setModes(new SensorMode[] { new CompassMode(), new AngleMode() }); } /** * Mindsensors compass sensor, Compass mode
* Measures the bearing of the sensor. * *

* Size and content of the sample
* The sample contains one element containing the bearing of the sensor * relative to north expressed in degrees. East being at 90 degrees. */ public SensorMode getCompassMode() { return getMode(0); } private class CompassMode implements SensorMode { @Override public int sampleSize() { return 1; } @Override public void fetchSample(float[] sample, int offset) { getData(0x42, buf, 1); // TODO: Could use integer mode for higher resolution sample[offset] = (255 - (buf[0] & 0xFF)) * 359f / 255f; } @Override public String getName() { return "Compass"; } } /** * MindSensors compass sensor, Angle mode
* Measures the bearing of the sensor. * *

* Size and content of the sample
* The sample contains one element containing the bearing of the sensor * relative to north expressed in degrees using a right hand coordinate system * in the range of (-180 to 180). West being at 90 degrees, east being at -90 * degrees. */ public SensorMode getAngleMode() { return getMode(0); } private class AngleMode implements SensorMode { @Override public int sampleSize() { return 1; } @Override public void fetchSample(float[] sample, int offset) { getData(0x42, buf, 1); // TODO: Could use integer mode for higher resolution sample[offset] = (255 - (buf[0] & 0xFF)) * -359f / 255f; } @Override public String getName() { return "Angle"; } } /** * Starts calibration for the compass. Must rotate *very* slowly, taking at * least 20 seconds per rotation. * * Should make 1.5 to 2 full rotations. Must call stopCalibration() when done. */ public void startCalibration() { buf[0] = BEGIN_CALIBRATION; sendData(COMMAND, buf, 1); } /** * Ends calibration sequence. * */ public void stopCalibration() { buf[0] = END_CALIBRATION; sendData(COMMAND, buf, 1); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy