org.fujion.gmaps.Styler Maven / Gradle / Ivy
/*
* #%L
* fujion
* %%
* Copyright (C) 2008 - 2018 Regenstrief Institute, Inc.
* %%
* 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%
*/
package org.fujion.gmaps;
import org.fujion.ancillary.OptionMap;
import org.fujion.ancillary.OptionMap.IOptionMapConverter;
import org.springframework.util.Assert;
/**
* Stylers are formatting options that you can apply to map features and elements.
*
* @param The data type of the option value.
*/
public class Styler implements IOptionMapConverter {
private final OptionMap map = new OptionMap();
private Styler(String type, T value) {
map.put(type, value);
}
@Override
public OptionMap toMap() {
return map;
}
/**
* This option sets the hue while keeping the saturation and lightness specified in the default
* Google style (or in other style options you define on the map). The resulting color is
* relative to the style of the base map. If Google makes any changes to the base map style, the
* changes affect your map's features styled with hue. It's better to use the absolute color
* styler if you can.
*/
public static class HueStyler extends Styler {
/**
* Creates a hue styler with the specified color.
*
* @param color An RGB hex string of format #RRGGBB
*/
public HueStyler(String color) {
super("hue", color);
}
}
/**
* This option sets the color of the feature.
*/
public static class ColorStyler extends Styler {
/**
* Creates a color styler with the specified color.
*
* @param color An RGB hex string of format #RRGGBB
*/
public ColorStyler(String color) {
super("color", color);
}
}
/**
* This option sets the lightness while keeping the saturation and hue specified in the default
* Google style (or in other style options you define on the map). The resulting color is
* relative to the style of the base map. If Google makes any changes to the base map style, the
* changes affect your map's features styled with lightness. It's better to use the absolute
* color styler if you can.
*/
public static class LightnessStyler extends Styler {
/**
* Creates a lightness styler with the specified lightness factor that indicates the
* percentage change in brightness of the element. Negative values increase darkness (where
* -100 specifies black) while positive values increase brightness (where +100 specifies
* white).
*
* @param lightness Indicates the percentage change in brightness of the element. Negative
* values increase darkness (where -100 specifies black) while positive values
* increase brightness (where +100 specifies white).
*
* Constraints: ≥-100 and ≤100
*/
public LightnessStyler(double lightness) {
super("lightness", lightness);
Assert.isTrue(lightness >= -100.0 && lightness <= 100.0, () -> "Lightness must be between -100 and 100, inclusive");
}
}
/**
* This option sets the saturation while keeping the hue and lightness specified in the default
* Google style (or in other style options you define on the map). The resulting color is
* relative to the style of the base map. If Google makes any changes to the base map style, the
* changes affect your map's features styled with saturation. It's better to use the absolute
* color styler if you can.
*/
public static class SaturationStyler extends Styler {
/**
* Creates a saturation styler with the specified saturation that indicates the percentage
* change in intensity of the basic color to apply to the element.
*
* @param saturation Indicates the percentage change in brightness of the element. Negative
* values increase darkness (where -100 specifies black) while positive values
* increase brightness (where +100 specifies white).
*
* Constraints: ≥-100 and ≤100
*/
public SaturationStyler(double saturation) {
super("saturation", saturation);
Assert.isTrue(saturation >= -100.0 && saturation <= 100.0, () -> "Saturation must be between -100 and 100, inclusive");
}
}
/**
* This option adjusts the lightness relative to the default Google style, using a gamma curve.
* If Google makes any changes to the base map style, the changes affect your map's features
* styled with gamma. It's better to use the absolute color styler if you can.
*/
public static class GammaStyler extends Styler {
/**
* Creates a gamma styler with the specified gamma value that indicates the amount of gamma
* correction to apply to the element. Gamma corrections modify the lightness of colors in a
* non-linear fashion, while not affecting white or black values. Gamma correction is
* typically used to modify the contrast of multiple elements. For example, you can modify
* the gamma to increase or decrease the contrast between the edges and interiors of
* elements.
*
* @param gamma The gamma value.
*
* Constraints: ≥0.01 and ≤10.0
*/
public GammaStyler(double gamma) {
super("gamma", gamma);
Assert.isTrue(gamma >= 0.01 && gamma <= 10.0, () -> "Gamma must be between 0.01 and 10.0, inclusive");
}
}
/**
* This option simply inverts the default Google style. If Google makes any changes to the base
* map style, the changes affect your map's features styled with invert_lightness. It's better
* to use the absolute color styler if you can.
*/
public static class InvertLightnessStyler extends Styler {
/**
* Creates a styler for inverting lightness.
*/
public InvertLightnessStyler() {
super("invert_lightness", true);
}
}
public enum VisibilityType {
/**
* Visibility is on.
*/
ON,
/**
* Visibility is off.
*/
OFF,
/**
* Removes some style features from the affected features; roads, for example, are
* simplified into thinner lines without outlines, while parks lose their label text but
* retain the label icon.
*/
SIMPLIFIED;
@Override
public String toString() {
return name().toLowerCase();
}
}
/**
* This option indicates whether and how the element appears on the map.
*/
public static class VisibilityStyler extends Styler {
/**
* Creates a visibility styler with the specified visibility type.
*
* @param visibility The visibility type.
*/
public VisibilityStyler(VisibilityType visibility) {
super("visibility", visibility);
}
}
/**
* This option sets the weight of the feature, in pixels.
*/
public static class WeightStyler extends Styler {
/**
* Creates a weight styler.
*
* @param weight The weight of the feature, in pixels. Setting the weight to a high value
* may result in clipping near tile borders.
*
* Constraints: ≥0
*/
public WeightStyler(int weight) {
super("weight", weight);
Assert.isTrue(weight >= 0, () -> "Weight must be greater than or equal to 0");
}
}
}