资讯专栏INFORMATION COLUMN

Java 实现与 Word 风格相似的菜单

JeOam / 1486人阅读

摘要:因为这意味着用户实现功能的时间变少。人类的失误设计过程中要尽量避免用户意外点中不相关的功能。常见的操作会用工具栏来实现,它们被包裹在子菜单中。子菜单可以利用实现,当用户点击其他的子菜单时当前显示的子菜单应从移除。

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

菜单效果演示图

Microsoft Word

本程序菜单

简单的菜单布局设计

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

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

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

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

功能分组原理 功能性

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

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

时序性

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

例如,先复制后粘贴。

使用频率

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

例如,保存和打印。

菜单设计原理 费茨法则

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

人类是会犯错误的

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

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

人类的失误

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

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

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 哦!
https://github.com/Hephaest/M...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75243.html

相关文章

  • 慕课网_《Java微信公众号开发进阶》学习总结

    摘要:时间年月日星期六说明本文部分内容均来自慕课网。慕课网教学源码学习源码第一章概述课程简介本课程是在之前的初识微信公众号开发课程基础之上的。慕课网课程涵盖前端开发等前沿技术语言,包括基础课程实用案例高级分享三大类型,适合不同阶段的学习人群。 时间:2017年08月12日星期六说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com教学源码:http://img.m...

    Freelander 评论0 收藏0
  • Web前端开发规范手册

    摘要:规范目的为提高团队协作效率便于后台人员添加功能及前端后期优化维护输出高质量的文档特制订此文档。 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档。 文件规范 文件命名规则 文件名称统一用小写的英文字母、数字和下划线的组合,其中不得包含汉字、空格和特殊字符;命名原则的指导思想一是使得你自己和工作组的每一个成员能够方便的理解每一个...

    wua_wua2012 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<