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

com.pi4j.io.gpio.GpioFactory Maven / Gradle / Ivy

Go to download

This bundle wraps Pi4j (http://pi4j.com) that wraps the native code Wiring Pi (http://wiringpi.com). It wraps these libraries to make them OSGi friendly and allow them to work together with the OSGi enRoute IoT circuit library (osgi.enroute.iot.circuit). The bundle will first use Pi4J to detect on what hardware it runs. If it runs on an appropriate type, it will register a component that can be configured with Metatype. The Metatype defines a full blown configuration template for all the Pi's functions. The GPIO's are registered as components for the circuit. Regardless of the success of the configuration, this bundle will also register a GpioController service, which is the main Pi4J class.

The newest version!
package com.pi4j.io.gpio;

/*
 * #%L
 * **********************************************************************
 * ORGANIZATION  :  Pi4J
 * PROJECT       :  Pi4J :: Java Library (Core)
 * FILENAME      :  GpioFactory.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 - 2015 Pi4J
 * %%
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */


import com.pi4j.concurrent.DefaultExecutorServiceFactory;
import com.pi4j.concurrent.ExecutorServiceFactory;
import com.pi4j.io.gpio.impl.GpioControllerImpl;

/**
 * 

This factory class provides a static method to create new 'GpioController' instances.

* *

* Before using the Pi4J library, you need to ensure that the Java VM in configured with access to * the following system libraries: *

    *
  • pi4j
  • *
  • wiringPi
  • *
* *
This library depends on the wiringPi native system library.
(developed by * Gordon Henderson @ http://wiringpi.com/) *
*

* * @see com.pi4j.io.gpio.GpioController * @see com.pi4j.io.gpio.GpioProvider * * @see http://www.pi4j.com/ * @author Robert Savage (http://www.savagehomeautomation.com) */ @SuppressWarnings("unused") public class GpioFactory { // we only allow a single controller to exists private static GpioController controller = null; // we only allow a single default provider to exists private static GpioProvider provider = null; // we only allow a single default scheduled executor service factory to exists private static ExecutorServiceFactory executorServiceFactory = null; // private constructor private GpioFactory() { // forbid object construction } /** *

Return default instance of {@link GpioController}.

*

Note: this is not thread safe singleton pattern implementation. * Implementation does not provide any synchronization or mechanisms to prevent * instantiation of two instances.

* * @return Return a new GpioController impl instance. */ public static GpioController getInstance() { // if a controller has not been created, then create a new instance // Note: this is not thread safe singleton if (controller == null) { controller = new GpioControllerImpl(); } // else return a copy of the existing controller return controller; } /** *

Return default instance of {@link GpioProvider}.

*

Note: this is not thread safe singleton pattern implementation. * Implementation does not provide any synchronization or mechanisms to prevent * instantiation of two instances.

* * @return Return a new GpioController impl instance. */ public static GpioProvider getDefaultProvider() { // if a provider has not been created, then create a new instance if (provider == null) { provider = new RaspiGpioProvider(); } // return the provider instance return provider; } /** * Sets default {@link GpioProvider}. * * @param provider default gpio provider */ public static void setDefaultProvider(GpioProvider provider) { // set the default provider instance GpioFactory.provider = provider; } /** *

Return instance of {@link ExecutorServiceFactory}.

*

Note: .

* * @return Return a new GpioController impl instance. */ public static ExecutorServiceFactory getExecutorServiceFactory() { // if an executor service provider factory has not been created, then create a new default instance if (executorServiceFactory == null) { executorServiceFactory = new DefaultExecutorServiceFactory(); } // return the provider instance return executorServiceFactory; } /** * Sets default {@link ExecutorServiceFactory}. * * @param executorServiceFactory service factory instance */ public static void setExecutorServiceFactory(ExecutorServiceFactory executorServiceFactory) { // set the default factory instance GpioFactory.executorServiceFactory = executorServiceFactory; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy