JavaFX - 投影效果



通常,陰影效果會複製指定的節點並使其邊緣模糊。投影效果是一種陰影效果;將此效果應用於節點時,將在指定節點後面建立陰影。

名為 **DropShadow** 的類(位於 **javafx.scene.effect** 包中)表示投影效果。此類包含九個屬性,它們是:

  • **color** - 此屬性為 Color 型別,表示陰影的顏色。

  • **blur type** - 此屬性為 BlurType 型別,表示用於模糊陰影的模糊效果型別。

  • **radius** - 此屬性為 double 型別,表示陰影模糊核的半徑。

  • **width** - 此屬性為 double 型別,表示陰影模糊核的寬度。

  • **height** - 此屬性為 double 型別,表示陰影模糊核的高度。

  • **input** - 此屬性為 Effect 型別,表示陰影效果的輸入。

  • **spread** - 此屬性為 double 型別,表示陰影的擴散。

  • **offsetX** - 此屬性為 double 型別,表示陰影在 x 方向上的偏移量(以畫素為單位)。

  • **offsetY** - 此屬性為 double 型別,表示陰影在 y 方向上的偏移量(以畫素為單位)。

示例

以下程式是一個演示 JavaFX 投影效果的示例。在這裡,我們在場景中繪製文字“歡迎來到 Tutorialspoint”和一個圓形。

我們將投影效果應用於這些圖形。將此程式碼儲存在名為 **DropShadowEffectExample.java** 的檔案中。

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.effect.BlurType; 
import javafx.scene.effect.DropShadow; 
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 DropShadowEffectExample 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 centre 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 
      DropShadow dropShadow = new DropShadow(); 
      
      //setting the type of blur for the shadow 
      dropShadow.setBlurType(BlurType.GAUSSIAN); 
      
      //Setting color for the shadow 
      dropShadow.setColor(Color.ROSYBROWN); 
      
      //Setting the height of the shadow
      dropShadow.setHeight(5); 
      
      //Setting the width of the shadow 
      dropShadow.setWidth(5); 
      
      //Setting the radius of the shadow 
      dropShadow.setRadius(5); 
      
      //setting the offset of the shadow 
      dropShadow.setOffsetX(3); 
      dropShadow.setOffsetY(2); 
      
      //Setting the spread of the shadow 
      dropShadow.setSpread(12);  
      
      //Applying shadow effect to the text 
      text.setEffect(dropShadow);      
      
      //Applying shadow effect to the circle 
      circle.setEffect(dropShadow); 
          
      //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("Drop Shadow 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 DropShadowEffectExample.java 
java --module-path %PATH_TO_FX% --add-modules javafx.controls DropShadowEffectExample    

輸出

執行上述程式後,將生成一個如下圖所示的 JavaFX 視窗。

Drop Shadow Effect Example
廣告
© . All rights reserved.