/* * Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package test.javafx.scene.effect; import static test.com.sun.javafx.test.TestHelper.box; import java.util.ArrayList; import java.util.Collection; import javafx.scene.Node; import javafx.scene.effect.BoxBlur; import javafx.scene.effect.GaussianBlur; import javafx.scene.effect.Glow; import javafx.scene.shape.Rectangle; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; import test.com.sun.javafx.test.BBoxComparator; import test.com.sun.javafx.test.PropertiesTestBase; @RunWith(Parameterized.class) public final class GaussianBlur_properties_Test extends PropertiesTestBase { @Parameters public static Collection data() { ArrayList array = new ArrayList(); // simple property tests final GaussianBlur testGaussianBlur = new GaussianBlur(); array.add(config(testGaussianBlur, "input", null, new BoxBlur())); array.add(config(testGaussianBlur, "radius", 20.0, 40.0)); // bounding box calculation tests Node testNode = createTestNode(); array.add(config(testNode.getEffect(), "radius", 0.0, 10.0, testNode, "boundsInLocal", box(0.0, 0.0, 100.0, 100.0), box(-10.0, -10.0, 120.0, 120.0), new BBoxComparator(0.01))); testNode = createTestNode(); array.add(config(testNode.getEffect(), "input", null, new BoxBlur(), testNode, "boundsInLocal", box(-10.0, -10.0, 120.0, 120.0), box(-12.0, -12.0, 124.0, 124.0), new BBoxComparator(0.01))); testNode = createTestNodeWithChainedEffect(); array.add(config(((Glow)testNode.getEffect()).getInput(), "radius", 0.0, 10.0, testNode, "boundsInLocal", box(0.0, 0.0, 100.0, 100.0), box(-10.0, -10.0, 120.0, 120.0), new BBoxComparator(0.01))); testNode = createTestNodeWithChainedEffect(); array.add(config(((Glow)testNode.getEffect()).getInput(), "input", null, new BoxBlur(), testNode, "boundsInLocal", box(-10.0, -10.0, 120.0, 120.0), box(-12.0, -12.0, 124.0, 124.0), new BBoxComparator(0.01))); return array; } public GaussianBlur_properties_Test(final Configuration configuration) { super(configuration); } private static Rectangle createTestNode() { Rectangle r = new Rectangle(100, 100); r.setEffect(new GaussianBlur()); return r; } private static Rectangle createTestNodeWithChainedEffect() { Rectangle r = new Rectangle(100, 100); Glow g = new Glow(); g.setInput(new GaussianBlur()); r.setEffect(g); return r; } }