JavaFX - 阴影效果



JavaFX 中的阴影效果会创建指定节点的副本,并带有模糊的边缘。

名为 Shadow 的类,位于 javafx.scene.effect 包中,表示棕褐色效果。此类包含六个属性,它们是:

  • color - 此属性为 Color 类型,表示阴影的颜色。

  • blur type - 此属性为 BlurType 类型,表示用于模糊阴影的模糊效果类型。

  • radius - 此属性为 double 类型,表示阴影模糊内核的半径。

  • width - 此属性为 double 类型,表示阴影模糊内核的宽度。

  • height - 此属性为 double 类型,表示阴影模糊内核的高度。

  • input - 此属性为 Effect 类型,表示阴影效果的输入。

示例

以下程序是一个演示 JavaFX 阴影效果的示例。在这里,我们在场景中绘制了文本“欢迎使用 Tutorialspoint”和一个圆形。

我们应用了阴影效果,模糊类型为高斯,颜色为玫瑰棕色,高度、宽度和半径为 5。

将此代码保存在名为 ShadowEffectExample.java 的文件中。

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.effect.BlurType; 
import javafx.scene.effect.Shadow; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Circle; 
import javafx.stage.Stage; 
import javafx.scene.text.Font; 
import javafx.scene.text.FontWeight; 
import javafx.scene.text.Text; 
         
public class ShadowEffectExample extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text object 
      Text text = new Text();       
      
      //Setting font to the text 
      text.setFont(Font.font(null, FontWeight.BOLD, 40));        
      
      //setting the position of the text 
      text.setX(60);  
      text.setY(50); 
      
      //Setting the text to be embedded. 
      text.setText("Welcome to Tutorialspoint");       
      
      //Setting the color of the text 
      text.setFill(Color.DARKSEAGREEN);
      
      //Drawing a Circle 
      Circle circle = new Circle();         
      
      //Setting the center of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(160.0f); 
      
      //Setting the radius of the circle 
      circle.setRadius(100.0f); 
       
      //Instantiating the Shadow class 
      Shadow shadow = new Shadow(); 
      
      //setting the type of blur for the shadow 
      shadow.setBlurType(BlurType.GAUSSIAN); 
      
      //Setting color of the shadow 
      shadow.setColor(Color.ROSYBROWN); 
      
      //Setting the height of the shadow 
      shadow.setHeight(5); 
      
      //Setting the width of the shadow 
      shadow.setWidth(5); 
      
      //Setting the radius of the shadow 
      shadow.setRadius(5);  
      
      //Applying shadow effect to the text 
      text.setEffect(shadow);      
      
      //Applying shadow effect to the circle 
      circle.setEffect(shadow); 
         
      //Creating a Group object    
      Group root = new Group(circle, text);   
               
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Bloom effect example");
      
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show();         
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}      

使用以下命令从命令提示符编译并执行保存的 java 文件。

javac --module-path %PATH_TO_FX% --add-modules javafx.controls ShadowEffectExample.java 
java --module-path %PATH_TO_FX% --add-modules javafx.controls ShadowEffectExample    

输出

执行上述程序后,会生成一个如下图所示的 JavaFX 窗口。

Shadow Effect
广告