Skip to main content
aboutsummaryrefslogtreecommitdiffstats
blob: d88f4cc90dbca0ffea45485ecf66a72a47ffa07e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*******************************************************************************
 * Copyright (c) 2004, 2008 John Krasnay and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors:
 *     John Krasnay - initial API and implementation
 *******************************************************************************/
package org.eclipse.wst.xml.vex.core.internal.css;


/**
 * A length that may be expressed as an absolute or relative value.
 */
public class RelativeLength {

	private float percentage;
	private int absolute;
	boolean isAbsolute;

	private static RelativeLength ZERO = new RelativeLength(0, 0, true);

	/**
	 * Create a relative length representing an absolute value.
	 * 
	 * @return the new RelativeLength value.
	 */
	public static RelativeLength createAbsolute(int value) {
		if (value == 0) {
			return ZERO;
		} else {
			return new RelativeLength(0, value, true);
		}
	}

	/**
	 * Create a relative length representing a relative value.
	 * 
	 * @return the new RelativeLength value.
	 */
	public static RelativeLength createRelative(float percentage) {
		return new RelativeLength(percentage, 0, false);
	}

	/**
	 * Return the value of the length given a reference value. If this object
	 * represents an absolute value, that value is simply returned. Otherwise,
	 * returns the given reference length multiplied by the given percentage and
	 * rounded to the nearest integer.
	 * 
	 * @param referenceLength
	 *            reference length by which percentage lengths will by
	 *            multiplied.
	 * @return the actual value
	 */
	public int get(int referenceLength) {
		if (this.isAbsolute) {
			return this.absolute;
		} else {
			return Math.round(this.percentage * referenceLength);
		}
	}

	// ==================================================== PRIVATE

	private RelativeLength(float percentage, int absolute, boolean isAbsolute) {
		this.percentage = percentage;
		this.absolute = absolute;
		this.isAbsolute = isAbsolute;
	}
}

Back to the top