项目作者: cagdasc

项目描述 :
HMC5883L 3-axis magnetometer AndroidThings device driver
高级语言: Java
项目地址: git://github.com/cagdasc/AndroidThings-HMC5883L.git
创建时间: 2016-12-24T18:17:20Z
项目社区:https://github.com/cagdasc/AndroidThings-HMC5883L

开源协议:Apache License 2.0

下载


HMC5883L driver for Android Things

This driver include 3-axis magnetometer. There is no warranty for this driver. NOT USE IN PRODUCTION!!

How to use the driver

Sample usage

Manual usage

  1. import com.cacaosd.android.things.contrib.driver.hmc5883l;
  2. // Access the environmental sensor:
  3. HMC5883L hmcl5883l;
  4. try {
  5. hmcl5883l = new HMC5883L(i2cBusName);
  6. hmcl5883l.setSamplesAvarage(SAMPLES_AVARAGE_8);
  7. hmcl5883l.setOutputRate(OUTPUT_RATE_4);
  8. hmcl5883l.setMeasurementMode(MEASUREMENT_NORMAL);
  9. hmcl5883l.setMeasurementGain(GAIN_1090);
  10. hmcl5883l.setOperationMode(OPERATION_MODE_CONT);
  11. } catch (IOException e) {
  12. // error.
  13. }
  14. try {
  15. float[] magnitudes = hmcl5883l.getMagnitudes();
  16. } catch (IOException e) {
  17. // error reading
  18. }
  19. try {
  20. hmcl5883l.close();
  21. } catch (IOException e) {
  22. // error closing sensor
  23. }

You can register Android Sensor Service like this.

  1. SensorManager mSensorManager = getSystemService(Context.SENSOR_SERVICE);
  2. SensorEventListener mListener = ...;
  3. HMC5883LSensorDriver mSensorDriver;
  4. mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
  5. mSensorManager.registerDynamicSensorCallback(new SensorManager.DynamicSensorCallback() {
  6. @Override
  7. public void onDynamicSensorConnected(Sensor sensor) {
  8. if (sensor.getType() == Sensor.TYPE_MAGNETIC_FIELD) {
  9. mSensorManager.registerListener(MagnetometerActivity.this,
  10. sensor, SensorManager.SENSOR_DELAY_NORMAL);
  11. }
  12. }
  13. });
  14. try {
  15. mSensorDriver = new HMC5883LSensorDriver(BoardDefaults.getI2CPort());
  16. mSensorDriver.registerMagmetormeterSensor();
  17. } catch (IOException e) {
  18. Log.e(TAG, "Error configuring sensor", e);
  19. }
  20. }
  21. if (mSensorDriver != null) {
  22. mSensorManager.unregisterListener(this);
  23. mSensorDriver.unregisterMagmetormeterSensor();
  24. try {
  25. mSensorDriver.close();
  26. } catch (IOException e) {
  27. Log.e(TAG, "Error closing sensor", e);
  28. } catch (Exception e) {
  29. e.printStackTrace();
  30. } finally {
  31. mSensorDriver = null;
  32. }
  33. }

device

License

  1. Copyright 2016 Cagdas Caglak
  2. Licensed under the Apache License, Version 2.0 (the "License");
  3. you may not use this file except in compliance with the License.
  4. You may obtain a copy of the License at
  5. http://www.apache.org/licenses/LICENSE-2.0
  6. Unless required by applicable law or agreed to in writing, software
  7. distributed under the License is distributed on an "AS IS" BASIS,
  8. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. See the License for the specific language governing permissions and
  10. limitations under the License.