Returns the input angle put into the 360 degree range centered on the input center, [center-180, center+180) - Java 2D Graphics

Java examples for 2D Graphics:Angle

Description

Returns the input angle put into the 360 degree range centered on the input center, [center-180, center+180)

Demo Code

/**//from w w w. ja  v  a  2 s.co  m
 * Copyright (c) 2013 Oculus Info Inc.
 * http://www.oculusinfo.com/
 *
 * Released under the MIT License.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of
 * this software and associated documentation files (the "Software"), to deal in
 * the Software without restriction, including without limitation the rights to
 * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
 * of the Software, and to permit persons to whom the Software is furnished to do
 * so, subject to the following conditions:

 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.

 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */
//package com.java2s;

public class Main {
    public static void main(String[] argv) throws Exception {
        double center = 2.45678;
        double angle = 2.45678;
        System.out.println(intoRangeDegrees(center, angle));
    }

    /**
     * Returns the input angle put into the 360 degree range centered on the
     * input center, <code>[center-180, center+180)</code>
     * 
     * @param center
     *            The center of the desired output range
     * @param angle
     *            The angle to return in the given range
     * @return <code>angle</code>, but specified in the given range, in degrees.
     */
    public static double intoRangeDegrees(double center, double angle) {
        return intoRange(center, angle, 360);
    }

    /**
     * Essentially number mod modulus, but with the ability to specify the
     * output range.
     * 
     * @param center
     *            The center of the desired output range
     * @param number
     *            The number in question
     * @param modulus
     *            The modulus - i.e., the width of the range
     * @returnthe equivalent of number, mod modulus, centered on the given
     *            center (i.e., in the range [center-modulus/2,
     *            center+modulus/2))
     */
    public static double intoRange(double center, double number,
            double modulus) {
        return number - modulus * Math.round((number - center) / modulus);
    }
}

Related Tutorials