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

com.flash3388.flashlib.robot.systems.Rotatable Maven / Gradle / Ivy

package com.flash3388.flashlib.robot.systems;

import com.beans.util.function.Suppliers;
import com.flash3388.flashlib.control.Direction;
import com.flash3388.flashlib.scheduling.Requirement;
import com.flash3388.flashlib.scheduling.actions.Action;

import java.util.function.DoubleSupplier;

/**
 * Interface for object with the capability to rotate.
 *
 * @since FlashLib 3.2.0
 */
public interface Rotatable extends Stoppable, Requirement {

    /**
     * Rotates the system at a given speed.
     *
     * @param speed supplier of speed of motion [-1..1] describing percentage of power and direction.
     * @return action to perform motion.
     */
    Action rotate(DoubleSupplier speed);

    /**
     * Rotates the system at a given speed.
     *
     * @param speed speed of motion [-1..1] describing percentage of power and direction.
     * @return action to perform motion.
     */
    default Action rotate(double speed) {
        return rotate(Suppliers.of(speed));
    }

    /**
     * Rotates the system at a given speed.
     *
     * @param speed speed of motion [0..1] describing percentage of power.
     * @param direction right - forward, left - backward
     * @return action to perform motion.
     */
    default Action rotate(double speed, Direction direction){
        return rotate(Math.abs(speed) * direction.sign());
    }

    /**
     * Rotates the system at a speed to the right.
     *
     * 

Default implementation calls {@link #rotate(double, Direction)} with the given speed * and {@link Direction#FORWARD} for direction. * @param speed supplier of speed of motion [0..1] describing percentage of power. * @return action to perform motion. */ default Action rotateRight(DoubleSupplier speed){ return rotate(()-> Math.abs(speed.getAsDouble())); } /** * Rotates the system at a speed to the right. * *

Default implementation calls {@link #rotate(double, Direction)} with the given speed * and {@link Direction#FORWARD} for direction. * @param speed speed of motion [0..1] describing percentage of power. * @return action to perform motion. */ default Action rotateRight(double speed){ return rotate(speed, Direction.FORWARD); } /** * Rotates the system at a speed to the left. * *

Default implementation calls {@link #rotate(double, Direction)} with the given speed * and {@link Direction#BACKWARD} for direction. * @param speed suppliers speed speed of motion [0..1] describing percentage of power. * @return action to perform motion. */ default Action rotateLeft(DoubleSupplier speed){ return rotate(()-> -Math.abs(speed.getAsDouble())); } /** * Rotates the system at a speed to the left. * *

Default implementation calls {@link #rotate(double, Direction)} with the given speed * and {@link Direction#BACKWARD} for direction. * @param speed speed speed of motion [0..1] describing percentage of power. * @return action to perform motion. */ default Action rotateLeft(double speed){ return rotate(speed, Direction.BACKWARD); } /** * {@inheritDoc} */ @Override void stop(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy