JavaFX Effects – Kensoft PH https://kensoftph.com Power up your knowledge in programming Fri, 29 Oct 2021 08:50:14 +0000 en-US hourly 1 https://wordpress.org/?v=6.7.1 https://kensoftph.com/wp-content/uploads/2021/07/cropped-Kensoftph-New-logo-32x32.png JavaFX Effects – Kensoft PH https://kensoftph.com 32 32 JavaFX Effects Tutorial | 100% best for beginners https://kensoftph.com/javafx-effects-tutorial-best-for-beginners/ https://kensoftph.com/javafx-effects-tutorial-best-for-beginners/#respond Sun, 03 Oct 2021 12:11:32 +0000 https://kensoftph.com/?p=1317 JavaFX Tutorial

JavaFX Effects offers a wide variety of effects for creating visually appealing UI elements. Some developers are used to put extra eye catching UI to make their application visually appealing. Visually appealing applications are one of the most important factors in keeping users interested and loving it.

This article explains how to apply basic effects to your JavaFX application to make it more appealing. In JavaFX, we will go over some useful effects as well as others. Continue reading to find out more.

How to apply the JavaFX Effects

The good thing here is we can apply any effects to any Node on the SceneGraph using the setEffect() method. To apply the effect in JavaFX, use the setEffect() method, like this one setEffect(shadow), but first you must instantiate a respective class representing the effect to be applied in the Node. This is how you instantiate an effect DropShadow shadow = new DropShadow().

Set the properties of the effect

After you’ve instantiated the effect, you’ll need to use its setter method to configure its properties. This is how you set the properties of the effect as shown in the code block below.

// Setting the properties of the effect
shadow.setColor(Color.DARKGRAY);

Applying the effect to the node

Once you’ve finished configuring the effect’s properties. You can now use the setEffect() method to apply the desired effect to the node. As shown in the code block below, this is how to apply an effect to a node. Let’s assume that we have a button to apply an effect.

// Applying the effect to the Node
button.setEffect(shadow);

Output

JavaFX Effects

Effect in JavaFX

The following topics gives you descriptions and examples. Continue reading to learn more about JavaFX Effects.

Type of EffectDescription
BlendA blending effect that combines two inputs together
BloomAn effect that makes brighter portions of the input image appear to glow
Box blurA blur effect using a simple box filter kernel to make it unclear
Color AdjustAn effect that allows the adjustments of hue, saturation, brightness, and contrast
Color InputAn effect that gives you the same output that renders a rectangular region that is filled with the given color
Displacement mapAn effect that gives you the illusion of floating
Drop ShadowAn effect that gives you a shadow effect behind the node
Gaussian BlurAn effect similar to box blur that makes things unclear and uses a Gaussian convolution kernel
GlowAn image that glows as a result of this effect
Image InputAn effect that embeds an image just like Color Input that input to another effect
Inner ShadowAn effect similar to Drop Shadow that gives you a shadow inside the edges of the node
LightingAn effect that gives light shining on the given node
Motion BlurAn effect similar to Gaussian blur with configurable radius and angle
Perspective TransformAn effect that is mostly used in Three-dimensional effect. It provides non-affine transformation of the input content
ReflectionAn effect shows the reflected version of the node
Sepia ToneIt is an effect that is similar to old photographs
ShadowThis effect creates a duplicate of the node blurry edges
Types of Effects in JavaFX

Blend

Blend is a type of effect in JavaFX. Blending is a way to merging two different nodes. We’ll use an image input and a text to demonstrate a blend. By combining the two, we’ll be able to fill the text with an image. There will be a beautiful clipping effect as a result. Go ahead and follow the code example below.

Example: Blend Effect

Image image = new Image("https://kensoftph.com/wp-content/uploads/2021/09/java-quiz-3.jpg", 400, 400, true, true);
ImageInput ii = new ImageInput(image, 0, 0);

Blend blend = new Blend();
blend.setMode(BlendMode.SRC_ATOP);
blend.setTopInput(ii);

Text text = new Text(0, 80, "KENSOFT");
text.setFont(Font.font("Verdana", FontWeight.BOLD, 80));
text.setEffect(blend);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(new Scene(new StackPane(text), 400, 400));
primaryStage.show();

Output

Javafx effects - Blend

Bloom

Bloom is a JavaFX effect that creates a glowing effect similar to the Glow effect. We will use an image to demonstrate a bloom effect in JavaFX. To create a glowing effect using the bloom effect, you will need to use the setThreshold()method. The range of the threshold value is 0.0 to 1.0. To do that, check out the code example below and make your own bloom effect.

Example: Bloom Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400,400);
        
Bloom bloom = new Bloom();
bloom.setThreshold(0.5);
        
Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(bloom);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Bloom

Box blur

Box blur is a type of effect in JavaFX, Box blur is used to blur a node. It means becoming unclear. The box blur effect has four different types of properties.The height, width, input, and iterations.

  • Height – The height is a double type value that represents the vertical size of the effect.
  • Width – The width is a double type value that represents the horizontal size of the effect.
  • Input –  A property that represents an input of the box blur effect.
  • Iterations – This property is an integer type value that helps improve its quality and smoothness.

Example: Box blur Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400,400);
        
BoxBlur bb = new BoxBlur();
bb.setHeight(5);
bb.setWidth(5);
bb.setIterations(3);
        
Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(bb);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Box Blur

Color Adjust

Color Adjust is a type of effect in JavaFX. Color adjust is used to change the color of an image. By using the Color Adjust effect, you can adjust the hue, saturation, brightness, and contrast of your image. In the example below, we’ll modify the hue, saturation, brightness, and contrast of an image. Take a look at the example code below.

Example: Color Adjust Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400,400);
        
ColorAdjust ca = new ColorAdjust();
ca.setBrightness(0.5);
ca.setContrast(0.3);
ca.setHue(0.3);
ca.setSaturation(0.4);
        
Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(ca);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Color Adjust

Color Input

Color input is type of effect in JavaFX, Color input gives you the same output as rectangle but it is not a rectangle (not a node). It is mostly used to pass as an input for other effects. Take a look at the example code below.

Example: Color Input Effect

ColorInput ci = new ColorInput();
ci.setHeight(400);
ci.setWidth(400);
ci.setPaint(Color.AQUA);
        
        
Rectangle rect = new Rectangle();
rect.setEffect(ci);

Group group = new Group(rect);
Scene scene = new Scene(group, 400,400);
primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

Effect in JavaFX - Color Input

Displacement Map

It is one of the coolest effect. Displacement Map is used to transform images or something like floating. To set up the displacement map in JavaFX. You need to add coordinate correction data for each pixel using the FloatMap helper class. Please take a look at the example code below on how to set up the displacement map in JavaFX.

Example: Displacement Map effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

FloatMap floatMap = new FloatMap();
floatMap.setWidth(400);
floatMap.setHeight(400);
for (int x = 0; x < 400; x++) {
    double v = Math.sin(x / 30.) / 10.;
    for (int y = 0; y < 400; y++) {
        floatMap.setSamples(x, y, 0.0f, (float) v);
    }
}
DisplacementMap displacementMap = new DisplacementMap();
displacementMap.setWrap(true);
displacementMap.setMapData(floatMap);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(displacementMap);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Displacement Map

Drop Shadow

An effect that gives you a shadow effect behind the node. Applying the shadow effect is pretty easy, before we go over at the demonstration. Drop shadow has different types of properties. The following are the properties of the Drop Shadow effect. Color, Blur Type, Radius, Width, Height, Input, Spread, OffsetX, OffsetY. Take a look at the given example below.

Example: Drop Shadow Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

DropShadow dropShadow = new DropShadow();
dropShadow.setBlurType(BlurType.GAUSSIAN);
dropShadow.setColor(Color.DARKGRAY);
dropShadow.setOffsetX(5);
dropShadow.setOffsetY(5);
dropShadow.setRadius(10);
dropShadow.setSpread(0.8);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(dropShadow);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Drop Shadow

Gaussian blur

Gaussian blur is used to blur a node. Gaussian blur is similar to Box blur that make nodes unclear. The difference is the Gaussian Blur uses Gaussian convolution kernel which is use to produce blurring effect. The Gaussian blur contains properties:

  • Input – This is used to represents an input to the blur effect
  • Radius – It is a double type value and representing the radius is to be applied.

Example: Gaussian blur Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

GaussianBlur gb = new GaussianBlur();
gb.setRadius(15);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(gb);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Gaussian Blur

Glow

Glow is a type of effect in JavaFX. Just like Bloom, it makes the given input image to glow. So, in our example just like Bloom, we will use an image to demonstrate to glow effect. The most important property in the glow effect is the Level. The level controls the intensity of the glow. The maximum value of the level is 1.0, it uses double type value. To make the glow effect in your JavaFx application, take a look at the example code below.

Example: Glow Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

Glow glow = new Glow();
glow.setLevel(1.0);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(glow);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Glow

Image Input

Just like Color Input, Image input just embeds an image into your JavaFX application. Image input is a method of passing an image to another effect. The Blend effect has already demonstrated the Image input. To help you understand Image Input, I will show you what the correct meaning inside its paramater looks like. ImageInput ii = new ImageInput(image, 0, 0); The first parameter is the image’s source, while the other two are the image’s x and y coordinates.

Inner Shadow

Inner Shadow is a type of JavaFX effects that is similar to drop shadow, however the difference is that the inner shadow is created inside the node’s edges. Inner shadow has different types of properties. The following are the properties of the Inner Shadow effect. Color, Blur Type, Radius, Width, Height, Input, Spread, OffsetX, OffsetY,and Choke. Take a look at the given example below.

Example: Inner Shadow Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

InnerShadow is = new InnerShadow();
is.setBlurType(BlurType.GAUSSIAN);
is.setColor(Color.DARKGRAY);
is.setOffsetX(10);
is.setOffsetY(10);
is.setRadius(5);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(is);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Inner Shadow

Lighting

Lighting is also a type of effect in JavaFX. Lighting is used to create a light effect, and there are three types of light sources used in lighting effects. These are the point, distant, and spot. The following example demonstrating the lighting effect with an image. In this example we are applying the effect with its light source. Take a look at the given example code below.

Example: Lighting Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

Light.Distant light = new Light.Distant();
// Azimuth is the angle of the light in degrees
light.setAzimuth(45);

Lighting lighting = new Lighting();
lighting.setLight(light);
lighting.setSurfaceScale(10);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(lighting);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Lighting

Motion blur

Motion blur is similar to Gaussian blur effect. Motion blur is used to blur a node that make nodes unclear. The only difference is the Motion blur has the angle properties that you can apply and modify. To apply the motion blur into your JavaFX application is very easy and simple to do. Take a look at the given example code below.

  • Input – This is used to represents an input to the blur effect
  • Radius – It is a double type value and representing the radius is to be applied.
  • Angle – This type of property represents the angle of the motion blur effect in degrees.

Example: Motion blur Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

MotionBlur mb = new MotionBlur();
mb.setRadius(10);
mb.setAngle(45);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(mb);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Motion Blur

Perspective Transform

Perspective Transform is another effect which tries to look like 3D. The Perspective Transform changes the node’s dimension to a Three-dimensional look. In order to achieve the perspective transform effect. The eight coordinates must be set, four from the upper part and four from the lower part. Take a look at the given example code below.

Example: Perspective Transform Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

PerspectiveTransform pt = new PerspectiveTransform();
pt.setUlx(50); // upper-left
pt.setUly(50);

pt.setUrx(400); // upper-right
pt.setUry(50);

pt.setLlx(0); // lower-left
pt.setLly(220);

pt.setLrx(450); // lower-right
pt.setLry(220);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(pt);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Perspective Transform

Reflection

Reflection is like a mirror it reflects the node. The reflection effect is added at the bottom of the node. You can also change the properties of the reflection. To change its properties, you can use the topOpacity, bottomOpacity, input, topOffset, and fraction. To achieve the reflection effect into your JavaFX application. Take a look at the given example below.

Example: Reflection Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

Reflection reflection = new Reflection();
reflection.setTopOpacity(0.5);
reflection.setBottomOpacity(0.0);
reflection.setFraction(0.7);
reflection.setTopOffset(5);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(200);
iv.setEffect(reflection);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Reflection

Sepia tone

Sepia tone is a type of effect in JavaFX. This effects gives a reddish-brown tone to make it look like an old photo. To achieve the sepia effect, we need to set the level property. The value of the property is a double type it ranges from 0.0 to 1.0. Take a look at the example code below.

Example: Sepia tone Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

SepiaTone sepia = new SepiaTone();
sepia.setLevel(1.0);

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(sepia);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Sepia

Shadow

JavaFX Effects, a shadow effect that creates a duplicate of a specified node with blurry edges. Shadow effect has different types of properties, it is similar to the drop shadow. The following are the types of properties of the shadow effect. Color, Blur Type, Radius, Width, Height, Input, Spread, OffsetX, OffsetY. Take a look at the given example below.

Example: Shadow Effect

StackPane root = new StackPane();
Scene scene = new Scene(root, 400, 400);

Shadow shadow = new Shadow();

Image image = new Image(getClass().getResourceAsStream("/javafx/effects/nature.jpg"));
ImageView iv = new ImageView(image);
iv.setPreserveRatio(true);
iv.setSmooth(true);
iv.setFitHeight(400);
iv.setEffect(shadow);
root.getChildren().add(iv);

primaryStage.setTitle("JavaFX Effects Tutorial");
primaryStage.setScene(scene);
primaryStage.show();

Output

JavaFX Effects - Shadow

YouTube Video

]]>
https://kensoftph.com/javafx-effects-tutorial-best-for-beginners/feed/ 0 JavaFX Effect tutorial for beginners nonadult