![JAR search and dependency download from the Maven repository](/logo.png)
com.pi4j.io.pwm.PwmConfigBuilder Maven / Gradle / Ivy
package com.pi4j.io.pwm;
/*-
* #%L
* **********************************************************************
* ORGANIZATION : Pi4J
* PROJECT : Pi4J :: LIBRARY :: Java Library (CORE)
* FILENAME : PwmConfigBuilder.java
*
* This file is part of the Pi4J project. More information about
* this project can be found here: https://pi4j.com/
* **********************************************************************
*
* 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 com.pi4j.context.Context;
import com.pi4j.io.gpio.GpioConfigBuilder;
import com.pi4j.io.pwm.impl.DefaultPwmConfigBuilder;
/**
* PwmConfigBuilder interface.
*
* @author Robert Savage (http://www.savagehomeautomation.com)
* @version $Id: $Id
*/
public interface PwmConfigBuilder extends GpioConfigBuilder {
/**
* newInstance.
*
* @param context {@link Context}
* @return a {@link com.pi4j.io.pwm.PwmConfigBuilder} object.
*/
static PwmConfigBuilder newInstance(Context context) {
return DefaultPwmConfigBuilder.newInstance(context);
}
/**
* Set the configured frequency value in Hertz (number of cycles per second)
* that the PWM signal generator should attempt to output when the PWM state
* is enabled.
*
* Please note that certain PWM signal generators may be limited to specific
* frequency bands and may not generate all possible explicit frequency values.
* After enabling the PWM signal using the 'on(...)' method, you can check the
* 'Pwm::frequency()' or 'Pwm::getFrequency()' properties to determine what
* frequency the PWM generator actually applied.
*
* @param frequency the number of cycles per second (Hertz)
* @return this builder instance
*/
PwmConfigBuilder frequency(Integer frequency);
/**
* Set the duty-cycle value as a decimal value that represents the
* percentage of the ON vs OFF time of the PWM signal for each
* period. The duty-cycle range is valid from 0 to 100 including
* factional values. (Values above 50% mean the signal will
* remain HIGH more time than LOW.)
*
* Example: A value of 50 represents a duty-cycle where half of
* the time period the signal is LOW and the other half is HIGH.
*
* @param dutyCycle duty-cycle value expressed as a percentage (rage: 0-100)
* @return this builder instance
*/
PwmConfigBuilder dutyCycle(Number dutyCycle);
/**
* Set the PwmType of this PWM instance. (Hardware/Software)
* Please note that not all PWM providers support both hardware and software
* PWM generators. Please consult the documentation for your PWM provider
* to determine what support is available and what limitations may apply.
*
* @return this builder instance
* @param pwmType a {@link com.pi4j.io.pwm.PwmType} object.
*/
PwmConfigBuilder pwmType(PwmType pwmType);
/**
* Set the polarity of this PWM instance. (Normal/Inversed)
* Please note that not all PWM providers support polarity. Please
* consult the documentation for your PWM provider to determine
* what support is available and what limitations may apply.
*
* @return this builder instance
* @param polarity a {@link com.pi4j.io.pwm.PwmPolarity} object.
*/
PwmConfigBuilder polarity(PwmPolarity polarity);
/**
* Optionally configure a PWM duty-cycle value that should automatically
* be applied to the PWM instance when the Pi4J context is shutdown.
* This option can be helpful if you wish to do something like stop a PWM
* signal (by configuring this 'shutdown' value to zero) when your application
* is terminated an Pi4J is shutdown.
*
* @param dutyCycle duty-cycle value expressed as a percentage (rage: 0-100)
* @return this builder instance
*/
PwmConfigBuilder shutdown(Number dutyCycle);
/**
* Optionally configure a PWM duty-cycle value that should automatically
* be applied to the PWM instance when this PWM instance is created and initialized.
* This option can be helpful if you wish to do something like set a default PWM
* signal (by configuring this 'initial' value to 50%) when your application
* creates the PWM instance. This just helps eliminate a second line of code
* to manually start the PWM signal for cases where you prefer it is auto-started.
*
* @param dutyCycle duty-cycle value expressed as a percentage (rage: 0-100)
* @return this builder instance
*/
PwmConfigBuilder initial(Number dutyCycle);
/**
* Add one or more PwmPresets to this PWM instance. You can create new PWM
* preset instance using the 'PwmPreset::newBuilder(name)' static
* factory method.
*
* @param preset one or more pre-configured PwmPreset instances
* @return this builder instance
*/
PwmConfigBuilder preset(PwmPreset ... preset);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy