如何在 JavaFX 中向選單項新增影像?
選單是向用戶呈現的一系列選項或命令。在 JavaFX 中,選單由 **javafx.scene.control.Menu** 類表示,您可以透過例項化此類來建立選單。
選單項是選單中的一個選項,它由 **javafx.scene.control.MenuItem** 類表示,它是 Menu 類的超類。您可以顯示文字或圖形作為選單項,並向其新增所需的動作。
影像作為選單項
選單項類有一個名為 **graphic** 的屬性,表示選單項的可選圖形元素。通常,影像與專案的標題一起使用。您可以使用 **setGraphic()** 方法將值設定為此屬性,此方法接受 ImageView 物件作為引數。
或者,在例項化 MenuItem 類時,您可以將表示所需影像的 ImageView 物件作為引數傳遞給建構函式,以及選單項的名稱(字串)。
要向選單項新增影像 -
使用影像物件建立一個 ImageView 物件,並傳遞所需圖形的路徑。
透過將 ImageView 物件和專案的名稱作為引數傳遞給其建構函式,例項化 MenuItem 類來建立一個選單項。
透過例項化 Menu 類建立一個選單,並將上面建立的選單項新增到其中。
例項化 **MenuBar** 類,並將選單作為引數傳遞給其建構函式。
將 MenuBar 新增到場景中。
示例
import javafx.application.Application; import javafx.scene.Group; import javafx.scene.Scene; import javafx.scene.control.Menu; import javafx.scene.control.MenuBar; import javafx.scene.control.MenuItem; import javafx.scene.image.ImageView; import javafx.scene.paint.Color; import javafx.stage.Stage; public class MenuItemAddingImages extends Application { public void start(Stage stage) { //Creating image view files ImageView imgView1 = new ImageView("UIControls/open.png"); imgView1.setFitWidth(20); imgView1.setFitHeight(20); ImageView imgView2 = new ImageView("UIControls/Save.png"); imgView2.setFitWidth(20); imgView2.setFitHeight(20); ImageView imgView3 = new ImageView("UIControls/Exit.png"); imgView3.setFitWidth(20); imgView3.setFitHeight(20); //Creating menu Menu fileMenu = new Menu("File"); //Creating menu Items MenuItem item1 = new MenuItem("Open File", imgView1); MenuItem item2 = new MenuItem("Save file", imgView2); MenuItem item3 = new MenuItem("Exit", imgView3); //Adding all the menu items to the menu fileMenu.getItems().addAll(item1, item2, item3); //Creating a menu bar and adding menu to it. MenuBar menuBar = new MenuBar(fileMenu); menuBar.setTranslateX(200); menuBar.setTranslateY(20); //Setting the stage Group root = new Group(menuBar); Scene scene = new Scene(root, 595, 200, Color.BEIGE); stage.setTitle("Menu Example"); stage.setScene(scene); stage.show(); } public static void main(String args[]){ launch(args); } }
輸出
廣告