Skip to content

Latest commit

 

History

History
288 lines (206 loc) · 5.48 KB

README.md

File metadata and controls

288 lines (206 loc) · 5.48 KB

Iono Pi - Java library and utility program

Java library and utility program for Iono Pi (www.sferalabs.cc/iono-pi), a professional input/output expansion for Raspberry Pi.

This library is a JNI wrapper of the Iono Pi native library which must be installed before.

The Main.java class is an example of how to use the library; it provides a command-line utility to access Iono Pi's functionalities.

Usage

Development

Include Iono Pi in your Java project using Maven:

<project>
    ...
    <repositories>
        ...
        <repository>
            <id>sfera-repo</id>
            <url>http://sfera.sferalabs.cc/mvn-repo</url>
        </repository>
        ...
    </repositories>

    <dependencies>
        ...
        <dependency>
            <groupId>cc.sferalabs.libs</groupId>
            <artifactId>iono-pi</artifactId>
            <version>1.2.1</version>
        </dependency>
        ...
    </dependencies>
    ...
</project>

Utility program

Install the Iono Pi native library and setup your Raspberry Pi as described here.

Install Java 8:

$ sudo apt-get install oracle-java8-jdk

Clone this repo using git:

$ git clone https://github.com/sfera-labs/iono-pi-java-lib.git

Build the jar using Maven:

$ cd iono-pi-java-lib
$ mvn clean install

The resulting jar will be in the target directory: iono-pi-<version>.jar

Run the utility program (replace <version> with the actual version number):

$ sudo java -jar target/iono-pi-<version>.jar

IonoPi library documentation

The entry point to the API is the IonoPi abstract class.

Before anything else, you need to call once:

IonoPi.init();

to initialize the library and configure the Raspberry Pi's GPIO pins.

When Iono Pi's functionalities are no longer needed:

IonoPi.shutdown();

And here are the available functionalities:

LED

Set the LED on/off:

boolean on = true; // or false
IonoPi.LED.set(on);

Check if it's on:

boolean on = IonoPi.LED.isOn();

Outputs

The outputs are accessible via the IonoPi.Output enumeration.

The relay outputs:

IonoPi.Output.O1
IonoPi.Output.O2
IonoPi.Output.O3
IonoPi.Output.O4

and the open collectors:

IonoPi.Output.OC1
IonoPi.Output.OC2
IonoPi.Output.OC3

Set closed/open:

boolean closed = true; // or false
IonoPi.Output.O1.set(closed);

Check:

boolean closed = IonoPi.Output.OC3.isClosed();

Digital Inputs

IonoPi.DigitalInput.DI1
IonoPi.DigitalInput.DI2
IonoPi.DigitalInput.DI3
IonoPi.DigitalInput.DI4
IonoPi.DigitalInput.DI5
IonoPi.DigitalInput.DI6

Read state:

boolean high = IonoPi.DigitalInput.DI4.isHigh();

Set debounce time:

IonoPi.DigitalInput.DI4.setDebounce(100);

Set interrupt listener:

IonoPi.DigitalInput.DI6.setListener(new DigitalInputListener() {

    @Override
    public void onChange(DigitalInput input, boolean high) {
        System.out.println(high ? "high" : "low");
    }
});

Remove listener:

IonoPi.DigitalInput.DI6.setListener(null);

Digital I/Os (TTL lines)

IonoPi.DigitalIO.TTL1
IonoPi.DigitalIO.TTL2
IonoPi.DigitalIO.TTL3
IonoPi.DigitalIO.TTL4

Set high/low:

boolean high = true; // or false
IonoPi.DigitalIO.TTL2.set(high);

Check:

boolean high = IonoPi.DigitalIO.TTL2.isHigh();

Analog Inputs

IonoPi.AnalogInput.AI1
IonoPi.AnalogInput.AI2
IonoPi.AnalogInput.AI3
IonoPi.AnalogInput.AI4

Read value:

int v = IonoPi.AnalogInput.AI1.read();

Read value converted to voltage (V):

float v = IonoPi.AnalogInput.AI1.readVoltage();

1-Wire

1-Wire Bus

Retrieve all devices on the bus:

List<OneWireBusDevice> devices = IonoPi.OneWire.getBusDevices();
for (OneWireBusDevice d : devices) {
    System.out.println("ID: " + d.getId());
}

Read temperature measured by device (with max 3 attempts):

OneWireBusDevice d;
int milliC = d.readTemperature(3);
System.out.println("T: " + milliC / 1000.0 + " °C");

1-Wire MaxDetect

Read temperature and relative humidity from the probe connected to TTL2 (with max 3 attempts):

int[] t_rh = IonoPi.OneWire.maxDetectRead(IonoPi.DigitalIO.TTL2, 3);
if (t_rh != null) {
    System.out.println("T: " + t_rh[0] / 10.0 + "°C");
    System.out.println("RH: " + t_rh[1] / 10.0 + "%");
}

Wiegand

IonoPi.Wiegand.W1 // TTL1 = Wiegand Data 0, TTL2 = Wiegand Data 1
IonoPi.Wiegand.W2 // TTL3 = Wiegand Data 0, TTL4 = Wiegand Data 1

Monitor interface 1 in a new thread and stop after 30 seconds or if 42 is received:

Thread th = new Thread() {
    public void run() {
        try {
            IonoPi.Wiegand.W1.monitor(new WiegandListener() {

                @Override
                public boolean onData(Wiegand wInterface, int count, long data) {
                    System.out.println("Bits: " + count + " - Data: " + data);
                    if (data == 42) {
                        return false;
                    }
                    return true;
                }
            });
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
};

th.start();

try {
    Thread.sleep(30000);
} catch (InterruptedException e) {
}

IonoPi.Wiegand.W1.stop();
th.join();