use of org.opengis.filter.FilterFactory in project sldeditor by robward-scisys.
the class ArrowUtilsTest method testDecodeArrowThickness.
/**
* Test method for {@link com.sldeditor.ui.detail.vendor.geoserver.marker.arrow.ArrowUtils#decodeArrowThickness(java.lang.String)}.
*/
@Test
public void testDecodeArrowThickness() {
FilterFactory ff = CommonFactoryFinder.getFilterFactory(null);
Expression hr = ff.literal(1.2);
Expression t = ff.literal(0.34);
Expression ab = ff.literal(0.56);
String expectedString = ArrowUtils.encode(hr, t, ab);
Expression actual = ArrowUtils.decodeArrowThickness(expectedString);
assertEquals(t.toString(), actual.toString());
actual = ArrowUtils.decodeArrowThickness("abcdefg");
assertEquals("0.2", actual.toString());
actual = ArrowUtils.decodeHeightOverWidth(expectedString);
assertEquals(hr.toString(), actual.toString());
actual = ArrowUtils.decodeHeightOverWidth("abcdefg");
assertEquals("2.0", actual.toString());
actual = ArrowUtils.decodeHeadBaseRatio(expectedString);
assertEquals(ab.toString(), actual.toString());
actual = ArrowUtils.decodeHeadBaseRatio("abcdefg");
assertEquals("0.5", actual.toString());
}
use of org.opengis.filter.FilterFactory in project sldeditor by robward-scisys.
the class MultipleColourMapEntryTest method testParseList.
/**
* Test method for
* {@link com.sldeditor.ui.detail.config.colourmap.MultipleColourMapEntry#parseList(java.util.List)}.
* Test method for
* {@link com.sldeditor.ui.detail.config.colourmap.MultipleColourMapEntry#getColourMapEntry()}.
*/
@Test
public void testParseList() {
FilterFactory ff = CommonFactoryFinder.getFilterFactory();
MultipleColourMapEntry testObj = new MultipleColourMapEntry();
assertNotNull(testObj.getColourMapEntry());
ColorMapEntry c1 = new ColorMapEntryImpl();
String expectedLabel = "abc";
String expectedColour = "#123456";
double expectedOpacity = 0.5;
int expectedQuantity = 42;
c1.setLabel(expectedLabel);
c1.setColor(ff.literal(expectedColour));
c1.setOpacity(ff.literal(expectedOpacity));
c1.setQuantity(ff.literal(expectedQuantity));
List<ColorMapEntry> expectedList = new ArrayList<ColorMapEntry>();
expectedList.add(c1);
ColorMapEntry c2 = new ColorMapEntryImpl();
c2.setLabel(expectedLabel);
c2.setColor(ff.literal(expectedColour));
c2.setOpacity(ff.literal(expectedOpacity));
c2.setQuantity(ff.literal(expectedQuantity));
expectedList.add(c2);
ColorMapEntry c3 = new ColorMapEntryImpl();
c3.setLabel(expectedLabel);
c3.setColor(ff.literal(expectedColour));
c3.setOpacity(ff.literal(expectedOpacity));
c3.setQuantity(ff.literal(expectedQuantity));
expectedList.add(c3);
testObj.parseList(expectedList);
ColorMapEntry actual = testObj.getColourMapEntry();
// All the same
assertNotNull(testObj.getColourMapEntry());
assertEquals(actual.getLabel(), expectedLabel);
assertEquals(actual.getColor().toString(), expectedColour);
assertEquals(actual.getOpacity().toString(), String.valueOf(expectedOpacity));
assertEquals(actual.getQuantity().toString(), String.valueOf(expectedQuantity));
// Change label
c2.setLabel("different");
testObj.parseList(expectedList);
actual = testObj.getColourMapEntry();
assertNotNull(testObj.getColourMapEntry());
assertNull(actual.getLabel());
assertEquals(actual.getColor().toString(), expectedColour);
assertEquals(actual.getOpacity().toString(), String.valueOf(expectedOpacity));
assertEquals(actual.getQuantity().toString(), String.valueOf(expectedQuantity));
// Change colour
c1.setColor(ff.literal("#987654"));
testObj.parseList(expectedList);
actual = testObj.getColourMapEntry();
assertNotNull(testObj.getColourMapEntry());
assertNull(actual.getLabel());
assertNull(actual.getColor());
assertEquals(actual.getOpacity().toString(), String.valueOf(expectedOpacity));
assertEquals(actual.getQuantity().toString(), String.valueOf(expectedQuantity));
// Change opacity
c3.setOpacity(ff.literal(1.0));
testObj.parseList(expectedList);
actual = testObj.getColourMapEntry();
assertNotNull(testObj.getColourMapEntry());
assertNull(actual.getLabel());
assertNull(actual.getColor());
assertNull(actual.getOpacity());
assertEquals(actual.getQuantity().toString(), String.valueOf(expectedQuantity));
// Change quantity
c2.setQuantity(ff.literal(39.0));
testObj.parseList(expectedList);
actual = testObj.getColourMapEntry();
assertNotNull(testObj.getColourMapEntry());
assertNull(actual.getLabel());
assertNull(actual.getColor());
assertNull(actual.getOpacity());
assertNull(actual.getQuantity());
}
use of org.opengis.filter.FilterFactory in project sldeditor by robward-scisys.
the class RasterSymbolizerDetailsTest method testRasterSymbolizerDetailsGreyChannel.
/**
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#RasterSymbolizerDetails(com.sldeditor.filter.v2.function.FunctionNameInterface)}.
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#isDataPresent()}.
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#populate(com.sldeditor.common.data.SelectedSymbol)}.
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#dataChanged(com.sldeditor.ui.detail.config.FieldId)}.
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#getFieldDataManager()}.
* Test method for {@link com.sldeditor.ui.detail.RasterSymbolizerDetails#preLoadSymbol()}.
*/
@Test
public void testRasterSymbolizerDetailsGreyChannel() {
RasterSymbolizerDetails panel = new RasterSymbolizerDetails();
panel.populate(null);
// Set up test data
StyledLayerDescriptor sld = DefaultSymbols.createNewSLD();
SelectedSymbol.getInstance().createNewSLD(sld);
NamedLayer namedLayer = DefaultSymbols.createNewNamedLayer();
String expectedNameLayerValue = "named layer test value";
namedLayer.setName(expectedNameLayerValue);
Style style = DefaultSymbols.createNewStyle();
String expectedNameStyleValue = "style test value";
style.setName(expectedNameStyleValue);
namedLayer.addStyle(style);
FeatureTypeStyle fts = DefaultSymbols.createNewFeatureTypeStyle();
String expectedNameFTSValue = "feature type style test value";
fts.setName(expectedNameFTSValue);
style.featureTypeStyles().add(fts);
Rule rule = DefaultSymbols.createNewRule();
String expectedRuleValue = "rule test value";
rule.setName(expectedRuleValue);
RasterSymbolizer symbolizer = DefaultSymbols.createDefaultRasterSymbolizer();
StyleFactoryImpl styleFactory = (StyleFactoryImpl) CommonFactoryFinder.getStyleFactory();
FilterFactory ff = CommonFactoryFinder.getFilterFactory();
ContrastEnhancement contrastEnhancement = (ContrastEnhancement) styleFactory.contrastEnhancement(ff.literal(.5), "ramp");
SelectedChannelType greyChannel = styleFactory.createSelectedChannelType("grey", contrastEnhancement);
symbolizer.setChannelSelection(styleFactory.channelSelection(greyChannel));
String expectedNameValue = "symbolizer test value";
symbolizer.setName(expectedNameValue);
rule.symbolizers().add(symbolizer);
fts.rules().add(rule);
sld.layers().add(namedLayer);
SelectedSymbol.getInstance().addNewStyledLayer(namedLayer);
SelectedSymbol.getInstance().setStyledLayer(namedLayer);
SelectedSymbol.getInstance().setStyle(style);
SelectedSymbol.getInstance().setFeatureTypeStyle(fts);
SelectedSymbol.getInstance().setRule(rule);
SelectedSymbol.getInstance().setSymbolizer(symbolizer);
panel.populate(SelectedSymbol.getInstance());
GraphicPanelFieldManager fieldDataManager = panel.getFieldDataManager();
assertNotNull(fieldDataManager);
panel.dataChanged(null);
FieldConfigString nameField = (FieldConfigString) fieldDataManager.get(FieldIdEnum.NAME);
assertNull(nameField);
assertTrue(panel.isDataPresent());
// Reset to default value
panel.preLoadSymbol();
}
use of org.opengis.filter.FilterFactory in project sldeditor by robward-scisys.
the class StrokeDetailsTest method testStrokeDetailsLine.
/**
* Test method for
* {@link com.sldeditor.ui.detail.StrokeDetails#StrokeDetails(com.sldeditor.filter.v2.function.FunctionNameInterface)}.
*/
@SuppressWarnings("deprecation")
@Test
public void testStrokeDetailsLine() {
StrokeDetails panel = new StrokeDetails();
panel.populate(null);
// Set up test data
StyledLayerDescriptor sld = DefaultSymbols.createNewSLD();
SelectedSymbol.getInstance().createNewSLD(sld);
NamedLayer namedLayer = DefaultSymbols.createNewNamedLayer();
String expectedNameLayerValue = "named layer test value";
namedLayer.setName(expectedNameLayerValue);
Style style = DefaultSymbols.createNewStyle();
String expectedNameStyleValue = "style test value";
style.setName(expectedNameStyleValue);
namedLayer.addStyle(style);
FeatureTypeStyle fts = DefaultSymbols.createNewFeatureTypeStyle();
String expectedNameFTSValue = "feature type style test value";
fts.setName(expectedNameFTSValue);
style.featureTypeStyles().add(fts);
Rule rule = DefaultSymbols.createNewRule();
String expectedNameValue = "rule test value";
rule.setName(expectedNameValue);
StyleFactoryImpl styleFactory = (StyleFactoryImpl) CommonFactoryFinder.getStyleFactory();
FilterFactory ff = CommonFactoryFinder.getFilterFactory();
Stroke stroke = styleFactory.getDefaultStroke();
SymbolTypeFactory fillFactory = new SymbolTypeFactory(StrokeDetails.class, new ColourFieldConfig(GroupIdEnum.FILLCOLOUR, FieldIdEnum.STROKE_FILL_COLOUR, FieldIdEnum.OVERALL_OPACITY, FieldIdEnum.STROKE_FILL_WIDTH), new ColourFieldConfig(GroupIdEnum.STROKECOLOUR, FieldIdEnum.STROKE_FILL_COLOUR, FieldIdEnum.OVERALL_OPACITY, FieldIdEnum.STROKE_FILL_WIDTH), FieldIdEnum.STROKE_STYLE);
fillFactory.populate(panel, panel.getFieldDataManager());
Expression symbolType = ff.literal("star");
List<GraphicalSymbol> symbols = fillFactory.getValue(panel.getFieldDataManager(), symbolType, true, true, FieldConfigMarker.class);
Expression initalGap = ff.literal(0);
Expression gap = ff.literal(0);
GraphicStroke graphicStroke = styleFactory.graphicStroke(symbols, null, ff.literal(10), ff.literal(0), styleFactory.createAnchorPoint(ff.literal(0.5), ff.literal(0.75)), styleFactory.createDisplacement(ff.literal(0.35), ff.literal(0.12)), initalGap, gap);
stroke.setDashArray(new float[] { 1.0f, 2.0f, 3.0f });
stroke.setGraphicStroke(graphicStroke);
LineSymbolizer symbolizer = DefaultSymbols.createDefaultLineSymbolizer();
symbolizer.setStroke(stroke);
rule.symbolizers().add(symbolizer);
fts.rules().add(rule);
sld.layers().add(namedLayer);
SelectedSymbol.getInstance().addNewStyledLayer(namedLayer);
SelectedSymbol.getInstance().setStyledLayer(namedLayer);
SelectedSymbol.getInstance().setStyle(style);
SelectedSymbol.getInstance().setFeatureTypeStyle(fts);
SelectedSymbol.getInstance().setRule(rule);
SelectedSymbol.getInstance().setSymbolizer(symbolizer);
panel.populate(SelectedSymbol.getInstance());
GraphicPanelFieldManager fieldDataManager = panel.getFieldDataManager();
assertNotNull(fieldDataManager);
double expectedAngle = 14.5;
FieldConfigDouble angleField = (FieldConfigDouble) fieldDataManager.get(FieldIdEnum.STROKE_SYMBOL_ANGLE);
angleField.populateField(expectedAngle);
FieldConfigSlider opacityField = (FieldConfigSlider) fieldDataManager.get(FieldIdEnum.OVERALL_OPACITY);
double opacity = 0.15;
opacityField.populateField(opacity);
panel.dataChanged(null);
double actualValue = angleField.getDoubleValue();
assertTrue(Math.abs(actualValue - expectedAngle) < 0.01);
assertTrue(panel.isDataPresent());
actualValue = opacityField.getDoubleValue();
assertTrue(Math.abs(actualValue - opacity) < 0.01);
// Reset to default value
panel.preLoadSymbol();
actualValue = angleField.getDoubleValue();
assertTrue(Math.abs(actualValue - 0.0) < 0.01);
actualValue = opacityField.getDoubleValue();
assertTrue(Math.abs(actualValue - 1.0) < 0.01);
}
use of org.opengis.filter.FilterFactory in project sldeditor by robward-scisys.
the class BatchUpdateFontDataTest method testBatchUpdateFontData.
/**
* Test method for
* {@link com.sldeditor.tool.batchupdatefont.BatchUpdateFontData#BatchUpdateFontData(org.geotools.styling.StyledLayerDescriptor, com.sldeditor.common.SLDDataInterface)}.
*/
@Test
public void testBatchUpdateFontData() {
BatchUpdateFontData testObj = new BatchUpdateFontData(null, null);
assertNull(testObj.getName());
assertNull(testObj.getWorkspace());
assertNull(testObj.getSldData());
String expectedWorkspace = "workspace";
String expectedStyle = "layer.sld";
StyleWrapper styleWrapper = new StyleWrapper(expectedWorkspace, expectedStyle);
SLDData data = new SLDData(styleWrapper, null);
testObj = new BatchUpdateFontData(null, data);
assertEquals(testObj.getWorkspace(), expectedWorkspace);
assertEquals(testObj.getName(), expectedStyle);
assertEquals(testObj.getSldData(), data);
String expectedNamedLayer = "namedLayer";
testObj.setNamedLayer(expectedNamedLayer);
assertEquals(testObj.getNamedLayer(), expectedNamedLayer);
String expectedStyleLayer = "style";
testObj.setStyle(expectedStyleLayer);
assertEquals(testObj.getStyle(), expectedStyleLayer);
String expectedFeatureTypeStyleLayer = "feature type style";
testObj.setFeatureTypeStyle(expectedFeatureTypeStyleLayer);
assertEquals(testObj.getFeatureTypeStyle(), expectedFeatureTypeStyleLayer);
assertNull(testObj.getRule());
assertEquals(testObj.getRuleName(), "");
assertEquals(testObj.getSymbolizer(), "");
StyleFactoryImpl styleFactory = (StyleFactoryImpl) CommonFactoryFinder.getStyleFactory();
String expectedRule = "rule";
Rule rule = styleFactory.createRule();
rule.setName(expectedRule);
testObj.setRule(rule);
assertEquals(testObj.getRule(), rule);
assertEquals(testObj.getRuleName(), expectedRule);
String expectedSymbolizer = "text symbolizer";
TextSymbolizer symbolizer = styleFactory.createTextSymbolizer();
symbolizer.setName(expectedSymbolizer);
testObj.setSymbolizer(symbolizer);
testObj.setFont(symbolizer.getFont());
assertEquals(testObj.getSymbolizer(), expectedSymbolizer);
// Test with font == null
assertFalse(testObj.isFontNameSet());
assertFalse(testObj.isFontStyleSet());
assertFalse(testObj.isFontWeightSet());
assertFalse(testObj.isFontSizeSet());
assertEquals(testObj.getFontName(), "");
assertEquals(testObj.getFontStyle(), "");
assertEquals(testObj.getFontWeight(), "");
assertEquals(testObj.getFontSize(), "");
assertFalse(testObj.anyChanges());
testObj.revertToOriginal();
testObj.updateFont((Font) null);
assertFalse(testObj.updateFont((SLDWriterInterface) null));
testObj.setFont(null);
testObj.updateFontSize(45);
// Set font
FilterFactory ff = CommonFactoryFinder.getFilterFactory();
String originalFontname = "Serif";
String originalFontStyle = "normal";
String originalFontWeight = "normal";
int originalFontSize = 24;
Font font = styleFactory.createFont(ff.literal(originalFontname), ff.literal(originalFontStyle), ff.literal(originalFontWeight), ff.literal(originalFontSize));
testObj.setFont(font);
assertTrue(testObj.isFontNameSet());
assertTrue(testObj.isFontStyleSet());
assertTrue(testObj.isFontWeightSet());
assertTrue(testObj.isFontSizeSet());
assertFalse(testObj.isFontNameUpdated());
assertFalse(testObj.isFontStyleUpdated());
assertFalse(testObj.isFontWeightUpdated());
assertFalse(testObj.isFontSizeUpdated());
assertFalse(testObj.anyChanges());
// Update with a different copy of the same font - no changes
Font unchangedFont = styleFactory.createFont(ff.literal(originalFontname), ff.literal(originalFontStyle), ff.literal(originalFontWeight), ff.literal(originalFontSize));
testObj.updateFont(unchangedFont);
assertFalse(testObj.isFontNameUpdated());
assertFalse(testObj.isFontStyleUpdated());
assertFalse(testObj.isFontWeightUpdated());
assertFalse(testObj.isFontSizeUpdated());
// Update with a different copy of the same font - changes
String expectedFontName = "NewFont";
String expectedFontStyle = "italic";
String expectedFontWeight = "bold";
int expectedFontSize = 12;
Font changedFont = styleFactory.createFont(ff.literal(expectedFontName), ff.literal(expectedFontStyle), ff.literal(expectedFontWeight), ff.literal(expectedFontSize));
testObj.updateFont(changedFont);
assertTrue(testObj.isFontNameUpdated());
assertTrue(testObj.isFontStyleUpdated());
assertTrue(testObj.isFontWeightUpdated());
assertTrue(testObj.isFontSizeUpdated());
assertTrue(testObj.anyChanges());
assertEquals(testObj.getFontName(), expectedFontName);
assertEquals(testObj.getFontStyle(), expectedFontStyle);
assertEquals(testObj.getFontWeight(), expectedFontWeight);
assertEquals(testObj.getFontSize(), String.valueOf(expectedFontSize));
assertEquals(testObj.getFont(), changedFont);
// Increment font size
int expectedIncreaseFontSize = 5;
testObj.updateFontSize(expectedIncreaseFontSize);
assertEquals(testObj.getFontSize(), String.valueOf(expectedFontSize + expectedIncreaseFontSize));
// Decrease font size
expectedIncreaseFontSize *= -1;
testObj.updateFontSize(expectedIncreaseFontSize);
assertEquals(testObj.getFontSize(), String.valueOf(expectedFontSize));
// Try setting the font size less than zero
expectedIncreaseFontSize = -100;
testObj.updateFontSize(expectedIncreaseFontSize);
assertEquals(testObj.getFontSize(), String.valueOf(1));
// Update font size when font size is a function
String expectedFieldname = "fieldname";
changedFont.setSize(ff.property(expectedFieldname));
testObj.updateFont(changedFont);
expectedIncreaseFontSize = 5;
testObj.updateFontSize(expectedIncreaseFontSize);
String expectedResult = String.format("(%s+%d)", expectedFieldname, expectedIncreaseFontSize);
String actualResult = testObj.getFontSize();
assertEquals(actualResult, expectedResult);
// Revert to original
testObj.revertToOriginal();
assertFalse(testObj.isFontNameUpdated());
assertFalse(testObj.isFontStyleUpdated());
assertFalse(testObj.isFontWeightUpdated());
assertFalse(testObj.isFontSizeUpdated());
assertFalse(testObj.anyChanges());
assertEquals(testObj.getFontName(), originalFontname);
assertEquals(testObj.getFontStyle(), originalFontStyle);
assertEquals(testObj.getFontWeight(), originalFontWeight);
assertEquals(testObj.getFontSize(), String.valueOf(originalFontSize));
// Update with the changed font again
testObj.updateFont(changedFont);
SLDWriterInterface sldWriter = SLDWriterFactory.createWriter(null);
symbolizer.fonts().add(changedFont);
assertFalse(testObj.updateFont(sldWriter));
}
Aggregations