JavaFX+Jfoenix 学习笔记(四)–MenuBar菜单栏

JavaFX+Jfoenix 学习笔记(四)–MenuBar菜单栏1、菜单栏,如图2、实例-1,最简单且简陋的菜单栏packagezkh.javafx.learn.menubar;importjavafx.application.Application;importjavafx.geometry.Pos;importjavafx.scene.Scene;importjavafx.scene.control.Label;i…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

1、菜单栏,如图

JavaFX+Jfoenix 学习笔记(四)--MenuBar菜单栏

 

2、实例-1,最简单且简陋的菜单栏

package zkh.javafx.learn.menubar;

import javafx.application.Application;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Label;
import javafx.scene.control.Menu;
import javafx.scene.control.MenuBar;
import javafx.scene.control.MenuItem;
import javafx.stage.Stage;

/**
 * MenuBar
 */
// 继承javafx.application.Application是JavaFX的开始
public class MenuBar1 extends Application {
	
	/**
	 * Stage:就是你能看到的整个软件界面(窗口)
	 * Scene:就是除了窗口最上面有最大、最小化及关闭按钮那一行及窗口边框外其它的区域(场景)
	 * 场景(Scene)是一个窗口(Stage)必不可少的
	 */
	@Override
	public void start(Stage stage) throws Exception {
		// 创建一个标签,用于存放我们的Hello World文本,并设置让它在父容器中居中
		Label label = new Label("Hello"); label.setAlignment(Pos.CENTER);
		
		// 总共分两步:1:创建菜单栏(MenuBar);2:给菜单栏添加菜单项(MenuItem)
		// 创建一个菜单栏
		MenuBar menuBar = new MenuBar();
		
		// 创建菜单
		Menu menu1 = new Menu("菜单1");
		Menu menu2 = new Menu("菜单2");
		
		// 创建多级菜单的父级
		Menu menu3 = new Menu("多级菜单");
		MenuItem menuItem1 = new MenuItem("子菜单项1");
		MenuItem menuItem2 = new MenuItem("子菜单项1");
		MenuItem menuItem3 = new MenuItem("子菜单项1");
		// 将子菜单项添加进父级菜单
		menu3.getItems().addAll(menuItem1, menuItem2, menuItem3);
		
		// 将菜单添加进菜单栏
		menuBar.getMenus().addAll(menu1, menu2, menu3);
		
		// 1、初始化一个场景
		Scene scene = new Scene(menuBar, 400, 300);
		// 2、将场景放入窗口
		stage.setScene(scene);
		// 3、打开窗口
		stage.show();
	}
	
	public static void main( String[] args ){
		// 启动软件
		Application.launch(args);
    }
    
}

Jetbrains全家桶1年46,售后保障稳定

效果图:

JavaFX+Jfoenix 学习笔记(四)--MenuBar菜单栏

3、实例-2:菜单栏美化

package zkh.javafx.learn.menubar;

import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.control.Menu;
import javafx.scene.control.MenuBar;
import javafx.scene.control.MenuItem;
import javafx.scene.control.ScrollPane;
import javafx.scene.image.Image;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;
import zkh.javafx.util.Constants;

/**
 * MenuBar
 */
// 继承javafx.application.Application是JavaFX的开始
public class MenuBar2 extends Application {
	
	/**
	 * Stage:就是你能看到的整个软件界面(窗口)
	 * Scene:就是除了窗口最上面有最大、最小化及关闭按钮那一行及窗口边框外其它的区域(场景)
	 * 场景(Scene)是一个窗口(Stage)必不可少的
	 */
	@Override
	public void start(Stage stage) throws Exception {
		// (如果需要的话)定位横纵坐标,避免太靠边上遮盖菜单栏,,这两行如果不屑,一般电脑默认是居中屏幕显示,但在有些电脑会跑偏
        // stage.setX(0);stage.setY(4);
        // stage和Scene不再注释
  	    stage.setTitle(Constants.TITLE);
  	    stage.getIcons().add(new Image(Constants.IMG + "icon.png"));
		
  	   
  	    // 使用BorderPane布局
  	    BorderPane borderPane = new BorderPane();
  	    
		// 创建一个菜单栏
		MenuBar menuBar = new MenuBar();
		menuBar.getStyleClass().add("zkh_MenuBar");
		
		// 创建菜单
		Menu menu1 = new Menu("菜单1");
		Menu menu2 = new Menu("菜单2");
		
		// 创建多级菜单的父级
		Menu menu3 = new Menu("多级菜单");
		MenuItem menuItem1 = new MenuItem("子菜单项1");
		menuItem1.getStyleClass().add("zkh_MenuItem");
		MenuItem menuItem2 = new MenuItem("子菜单项2");
		menuItem2.getStyleClass().add("zkh_MenuItem");
		MenuItem menuItem3 = new MenuItem("子菜单项3");
		menuItem3.getStyleClass().add("zkh_MenuItem");
		// 将子菜单项添加进父级菜单
		menu3.getItems().addAll(menuItem1, menuItem2, menuItem3);
		
		// 将菜单添加进菜单栏
		menuBar.getMenus().addAll(menu1, menu2, menu3);
		
		borderPane.setTop(menuBar);
		borderPane.setCenter(new ScrollPane());
		
		
		// 1、初始化一个场景
		Scene scene = new Scene(borderPane, 400, 300);
		// 样式文件最好在Scene中引入,这样其他子组件就都可以使用了(哲理注意替换斜杠\,不能会报错找不到路径)
	    scene.getStylesheets().add((Constants.CSS + "app.css").replace("\\", "/"));
		// 2、将场景放入窗口
		stage.setScene(scene);
		// 3、打开窗口
		stage.show();
	}
	
	public static void main( String[] args ){
		// 启动软件
		Application.launch(args);
    }
    
}

css代码

只有前两行是自定义代码,其它都是重写原始样式

/*顶部菜单栏*/
.zkh_MenuBar{
    -fx-background-color:#F0F0F0;
    -fx-border:none;
    -fx-padding:0;
    -fx-font-size:12;
}
.zkh_MenuItem{
	-fx-padding: 8 60 8 30;
	-fx-font-size:12;
	-fx-cursor:hand;
}
.context-menu{
	-fx-padding:2;
	-fx-border-width:0;
	-fx-background-color:rgb(242,242,242,0.96); /*0.87*/
	/*-fx-background-radius:2px;*/
	/*-fx-effect:dropshadow(three-pass-box, #F2F2F2, 1, 0, 0, 0);*/ /*阴影效果*/
}
.menu-bar > .container > .menu-button:showing{ /*菜单栏选中并移动到二级菜单时一级选中菜单的样式*/
    -fx-background-color:#CCCCCE;
    -fx-border-color:#CCCCCE;
}
.menu-button{
	-fx-padding:1 4 1 4;
	-fx-border-width:1;
	-fx-border-color:#F0F0F0;
}
.menu-button:hover{
	-fx-background-color:#CCCCCE;
	-fx-border-color:#CCCCCE;
}
.menu-button > .label,.menu-item > .label{
	-fx-text-fill:BLACK;
}
.menu-item:focused{
	-fx-background-color:#CCCCCE; /*#90C8F6*/
}
.menu:focused > .right-container > .arrow{
    -fx-background-color:#CCCCCE;
}

效果图:

JavaFX+Jfoenix 学习笔记(四)--MenuBar菜单栏

4、实例-3:菜单的单击事件

菜单最基本的作用就是单击做一些事情这是要用到单击事件:setOnAction(EventHandler<ActionEvent> value)

这里有个坑,Menu的setOnAction不生效,或者说Menu的不能作为一个菜单按钮来使用,所以我都是用MenuItem

package zkh.javafx.learn.menubar;

import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Alert;
import javafx.scene.control.Menu;
import javafx.scene.control.MenuBar;
import javafx.scene.control.MenuItem;
import javafx.scene.control.ScrollPane;
import javafx.scene.image.Image;
import javafx.scene.layout.BorderPane;
import javafx.stage.Stage;
import zkh.javafx.util.Constants;

/**
 * MenuBar
 */
// 继承javafx.application.Application是JavaFX的开始
public class MenuBar3 extends Application {
	
	/**
	 * Stage:就是你能看到的整个软件界面(窗口)
	 * Scene:就是除了窗口最上面有最大、最小化及关闭按钮那一行及窗口边框外其它的区域(场景)
	 * 场景(Scene)是一个窗口(Stage)必不可少的
	 */
	@Override
	public void start(Stage stage) throws Exception {
		// (如果需要的话)定位横纵坐标,避免太靠边上遮盖菜单栏,,这两行如果不屑,一般电脑默认是居中屏幕显示,但在有些电脑会跑偏
        // stage.setX(0);stage.setY(4);
        // stage和Scene不再注释
  	    stage.setTitle(Constants.TITLE);
  	    stage.getIcons().add(new Image(Constants.IMG + "icon.png"));
		
  	   
  	    // 使用BorderPane布局
  	    BorderPane borderPane = new BorderPane();
  	    
		// 创建一个菜单栏
		MenuBar menuBar = new MenuBar();
		menuBar.getStyleClass().add("zkh_MenuBar");
		
		// 创建菜单
		Menu menu1 = new Menu("菜单1");
		Menu menu2 = new Menu("菜单2");
		
		// 创建多级菜单的父级
		Menu menu3 = new Menu("多级菜单");
		MenuItem menuItem1 = new MenuItem("子菜单项1");
		menuItem1.getStyleClass().add("zkh_MenuItem");
		MenuItem menuItem2 = new MenuItem("子菜单项2");
		menuItem2.getStyleClass().add("zkh_MenuItem");
		MenuItem menuItem3 = new MenuItem("子菜单项3");
		menuItem3.getStyleClass().add("zkh_MenuItem");
		MenuItem menuItem4 = new MenuItem("单击弹出1");
		menuItem4.getStyleClass().add("zkh_MenuItem");
		// 这里有个坑,Menu的setOnAction不生效,或者说Maneu的不能作为一个菜单按钮来使用,所以我都是用MenuItem
		menuItem4.setOnAction(
				new EventHandler<ActionEvent>() {
		            public void handle(ActionEvent event) {
		            	// 这个自己看,用处不大
		            	Alert alert = new Alert(Alert.AlertType.INFORMATION);
		            	alert.setContentText("弹出的那个1");
		            	alert.showAndWait();
		            }
		        }
		);
		// 将子菜单项添加进父级菜单
		menu3.getItems().addAll(menuItem1, menuItem2, menuItem3, menuItem4);
		
		// 将菜单添加进菜单栏
		menuBar.getMenus().addAll(menu1, menu2, menu3);
		
		borderPane.setTop(menuBar);
		borderPane.setCenter(new ScrollPane());
		
		
		// 1、初始化一个场景
		Scene scene = new Scene(borderPane, 400, 300);
		// 样式文件最好在Scene中引入,这样其他子组件就都可以使用了(哲理注意替换斜杠\,不能会报错找不到路径)
	    scene.getStylesheets().add((Constants.CSS + "app.css").replace("\\", "/"));
		// 2、将场景放入窗口
		stage.setScene(scene);
		// 3、打开窗口
		stage.show();
	}
	
	public static void main( String[] args ){
		// 启动软件
		Application.launch(args);
    }
    
}

效果动图:

JavaFX+Jfoenix 学习笔记(四)--MenuBar菜单栏

5、源代码(不推荐,文章基本都有了)

JavaFX+Jfoenix 学习笔记(四)–MenuBar菜单栏源码

好了,多看注释!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/222947.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • jsessionId的使用

    jsessionId的使用jsessionid的作用  在web应用的开发中我们会经常看到这样的url:http://www.xxx.com/xxx_app;jsessionid=xxxxxxxxxx?a=x&amp;b=x…。这跟一般的url基本一样,只有一个地方有区别,那就是“;jessionid=xxxxxxxx”。这个参数有时候有,有时候又没有,说它是参数可又跟一般传递的参数不同,它是紧跟在url后面用分号…

  • vue 路由嵌套_vue路由实现方式

    vue 路由嵌套_vue路由实现方式嵌套路由有时候在路由中,主要的部分是相同的,但是下面可能是不同的。比如访问首页,里面有新闻类的/home/news,还有信息类的/home/message。这时候就需要使用到嵌套路由。项目结构如下:

  • meshgrid方法

    meshgrid方法目录meshgrid绘制曲面图三维网络meshgridmeshgrid和mesh方法的差别在于是否会画出栅格线绘制曲面图生成绘制3D图形所需的网格数据。因为在计算机中进行绘图操作时,往往需要一些采样点,然后根据这些采样点来绘制出整个图形。涉及到x、y这两组数据可以看做是在Oxy平面内对坐标进行采样得到的坐标对(x,y)。[X,Y]=meshgrid…

  • 力扣

    力扣

  • 2015智能家居市场十大收购案

    2015智能家居市场十大收购案一方面,由于智能家居行业发展前景的无可**,大企业纷纷拓展智能家居业务;另一方面,资本寒冬来袭,小型智能家居企业纷纷求抱大腿。一时间,智能家居行业收购案频频发生。此等收购案背后真正企图是什么?又会给智能家居行业的发展带来哪些影响?  高通24亿美元收购英国CSR进军智能家居2015年8月13日,全球最大智能手机芯片供应商高通正式宣布以24亿美元完成对…

  • https和ssl的区别_ssl认证

    https和ssl的区别_ssl认证https加密、解密、及验证过程如下图:HTTPS怎么实现安全传输的?建立安全传输HTTPS中,客户端首先打开一条到WEB服务器443端口的连接。一旦建立了TCP连接,客户端和服务器就会初始化SSL层,对加密参数进行沟通,并交换密钥。握手完成后,SSL初始化就完成了,客户端就可以将请求报文发送给安全层了。重点SSL握手发送已加密的HTTP报文之前,客户端和服…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号