package com.pi4j.wiringpi; /* * #%L * ********************************************************************** * ORGANIZATION : Pi4J * PROJECT : Pi4J :: Java Library (Core) * FILENAME : GpioInterruptEvent.java * * This file is part of the Pi4J project. More information about * this project can be found here: http://www.pi4j.com/ * ********************************************************************** * %% * Copyright (C) 2012 - 2013 Pi4J * %% * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * #L% */ import java.util.EventObject; /** * <p> This class provides the event object for GPIO interrupt state changes. </p> * * <p> * Before using the Pi4J library, you need to ensure that the Java VM in configured with access to * the following system libraries: * <ul> * <li>pi4j</li> * <li>wiringPi</li> * </ul> * <blockquote> This library depends on the wiringPi native system library.</br> (developed by * Gordon Henderson @ <a href="https://projects.drogon.net/">https://projects.drogon.net/</a>) * </blockquote> * </p> * * @see <a href="http://www.pi4j.com/">http://www.pi4j.com/</a> * @author Robert Savage (<a * href="http://www.savagehomeautomation.com">http://www.savagehomeautomation.com</a>) */ public class GpioInterruptEvent extends EventObject { private static final long serialVersionUID = 1L; private int pin; private boolean state; /** * <h1>Default event constructor</h1> * * @param obj Ignore this parameter * @param pin GPIO pin number (not header pin number; not wiringPi pin number) * @param state New GPIO pin state. */ public GpioInterruptEvent(Object obj, int pin, boolean state) { super(obj); this.pin = pin; this.state = state; } /** * Get the pin number that changed and raised this event. * * @return GPIO pin number (not header pin number; not wiringPi pin number) */ public int getPin() { return pin; } /** * Get the new pin state raised in this event. * * @return GPIO pin state (HIGH=true, LOW=false) */ public boolean getState() { return state; } /** * Get the new pin state value raised in this event. * * @return GPIO pin state (HIGH=1, LOW=0) */ public int getStateValue() { return (state == true) ? 1 : 0; } }