Java程序  |  76行  |  2.58 KB

/*
 * Author: Alexander Komarov <alexander.komarov@intel.com>
 * Copyright (c) 2014 Intel Corporation.
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the
 * "Software"), to deal in the Software without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Software, and to
 * permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */

public class Bmp85 {
  static {
    try {
      System.loadLibrary("mraajava");
    } catch (UnsatisfiedLinkError e) {
      System.err.println(
          "Native code library failed to load. See the chapter on Dynamic Linking Problems in the SWIG Java documentation for help.\n" +
          e);
      System.exit(1);
    }
  }
  public static void main(String argv[]) {
    mraa.mraa.init();
    System.out.println(mraa.mraa.getVersion());

    // helper function to go from hex val to dec
    // function char(x) { return parseInt(x, 16); }

    mraa.I2c i2c = new mraa.I2c(0);
    i2c.address((byte)0x77);
    i2c.writeByte((byte)0xd0);
    /*
    SWIGTYPE_p_unsigned_char data0 = new SWIGTYPE_p_unsigned_char();*/
    byte[] data = new byte[1];
    i2c.read(data);
    System.out.println((new Integer(data[0])).toString());

    i2c.writeReg((byte)0xf4, (byte)0x2e);
    // initialise device
    if (i2c.readReg((byte)0xd0) != 0x55) {
      System.out.println("error");
    }

    // we want to read temperature so write 0x2e into control reg
    i2c.writeReg((byte)0xf4, (byte)0x2e);

    // read a 16bit reg, obviously it's uncalibrated so mostly a useless value
    // :)
    System.out.println(i2c.readWordReg((byte)0xf6));

    byte[] buf = new byte[2];
    buf[0] = (byte)0xf4;
    buf[1] = (byte)0x2e;
    i2c.write(buf);

    i2c.writeByte((byte)0xf6);
    int d = i2c.readReg((byte)2);
    System.out.println((new Integer(d)).toString());
  };
}
;