JAVA实现A类似word帮助_Java 实现与 Word 风格相似的菜单

这是一个关于Java编程实现类似Microsoft Word菜单布局的项目。文章介绍了设计原则,包括功能性、时序性和使用频率,以及菜单设计的费茨法则和避免用户错误。作者通过JToolBar和JMenuBar创建了可动态切换的子菜单,并讨论了快捷键的实现。
摘要由CSDN通过智能技术生成

最后一次更新于 2019/07/09

菜单效果演示图

Microsoft Word

39a3fe1d904a741091f0edbc36f7fd12.png

本程序菜单

7c231fc0fe2002ec95204d09e7729004.png

简单的菜单布局设计

这个项目是人机交互设计课程的一个小作业。

不过该作业的要求是不需要编写任何代码的。

但为了体现我们小组的设计和分组理念,我还是决定编写一个菜单小程序,该程序有灵活的布局,是微软的 Word 编辑器和 IntelliJ IDEA 编辑器布局的综合。

我们小组需要处理的所有功能已经预先被分类成如下几种名称:

867782d87b6cc6bdac8ecac5281fbeb2.png

功能分组原理

功能性

根据 功能相似的应该放在一起 的原则来布局所属的按钮。

例如,空白文本,加粗文本,斜体文本和下划线文本。

时序性

根据 功能的分组可以反应执行的顺序 的原则来布局所属的按钮。

例如,先复制后粘贴。

使用频率

根据 使用频率相似的功能应该放在一起 的原则来布局所属的按钮。通常常用操作都会在工具栏里使用户能直接点击。

例如,保存和打印。

菜单设计原理

费茨法则

按钮的面积越大越好。而用户的鼠标指针和按钮之间的距离越小越好。因为这意味着用户实现功能的时间变少。

人类是会犯错误的

设计过程中要尽量避免误导用户。

比如说,如果先使用户看到“保存为”功能而不是“保存”功能的话很可能使用户误认为“保存为”即是“保存”功能。

人类的失误

设计过程中要尽量避免用户意外点中不相关的功能。

比如说,用户可能误点中“删除”而不是“粘贴”如果这两个功能紧挨在一起的话。

Java 编程实现

从各类文本编辑器和以上原理的灵感激发下,我决定做出灵活布局的菜单。

常见的操作会用工具栏来实现,它们被包裹在子菜单中。

子菜单 可以利用 JToolBar 实现,当用户点击其他的子菜单时当前显示的子菜单应从 JFrame 移除。

举个例子

public void menuSelected(MenuEvent e) {

if(toolbar != null) {

toolbar.setVisible(false);

frame.remove(toolbar);

}

if(viewbar == null) {

viewbar = new JToolBar();

JMenuBar menuBar = new JMenuBar();

// 页面。

ImageIcon pageIcon = new ImageIcon("src/images/page.png");

JMenu page = new JMenu("View Page");

page.setIcon(pageIcon);

menuBar.add(page);

// 页面所在位置。

ImageIcon posIcon = new ImageIcon("src/images/position.png");

JMenu position = new JMenu("Position");

position.setIcon(posIcon);

menuBar.add(position);

// 显示文档。

ImageIcon docIcon = new ImageIcon("src/images/documents.png");

JMenu document= new JMenu("Alternative Document");

document.setIcon(docIcon);

menuBar.add(document);

viewbar.add(menuBar);

}

frame.add(viewbar, BorderLayout.PAGE_START);

viewbar.setVisible(true);

frame.setVisible(true);

}

对于快捷键的实现而言,我们需要调用 setAccelerator() 函数来设置快捷键。

比方说,

toolItem = new JMenuItem("Delete");

toolItem.setAccelerator(javax.swing.KeyStroke.getKeyStroke(java.awt.event.KeyEvent.VK_DELETE, 0));

接着,我们应该为每个按钮设置一个图标以此来提醒用户点击该按钮会发生什么。

这部分的实现比较简单:

ImageIcon pageIcon = new ImageIcon("src/images/page.png");

JMenu page = new JMenu("View Page");

page.setIcon(pageIcon);

源码

如果我的文章可以帮到您,劳烦您点进源码点个 ★ Star 哦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值