在JFrame上的JMenuBar中清空JMenuItems

时间:2013-05-08 07:47:26

标签: java swing jframe jmenuitem jmenubar

我在使用JMenuBar创建JFrame时遇到问题。 我这里有一个MenuBarBuilder类:

public class MenuBuilder extends JMenuBar
{
  private Model model;

  public MenuBuilder(Model model)
  {
    this.model = model;
    buildMenuBar();
  }

  public void buildMenuBar()
  {
    JMenu menuFile = new JMenu("File");
    JMenu menuEdit = new JMenu("Edit");
    JMenu menuHelp = new JMenu("Help");

    menuHelp.setMnemonic('H');
    menuFile.setMnemonic('F');
    menuEdit.setMnemonic('E');

    JMenuItem menuItemExit = new JMenuItem("Exit");

    menuItemExit.setAccelerator(model.getKeyStroke(KeyEvent.VK_ESCAPE, 0));

    menuItemExit.setAction(new ActionExit(model));

    menuFile.add(menuItemExit);

    add(menuFile);
    add(menuEdit);
    add(menuHelp);
  }
}

JFrame是在另一个类中创建的:

public MainGUI(boolean loadConfig, String loadConfigDir, Model model)
  {
    try
    {
      UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
    }
    catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException e)
    {
      GlobalVariables.LOGGING_logger.error("Something went wrong while getting the Look and Feel of current Windows Version for Userinterface", e);
    }

    try
    {
      this.model = model;

      frameMain = new JFrame("MainFrame");
      frameMain.setJMenuBar(new MenuBuilder(model));
      frameMain.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
      frameMain.addWindowListener(this);
      frameMain.setMinimumSize(new Dimension(500, 500));
      frameMain.pack();
      frameMain.setSize(800, 800);
      frameMain.setLocationRelativeTo(null);
      frameMain.setVisible(true);
    }
    catch (Exception e)
    {
      GlobalVariables.LOGGING_logger.error("Error while seeting up the main GUI.", e);
      MessagesToUser.errorMessageBothFilesIssue(true);
    }
  }

显示JFrame后,所有MenuItem都为空,但现有和函数(ActionExit)也正常工作。使用以下代码JMenuItem设置新的menuFile.add(new JMenuItem("Exit"));正在按预期工作,JFrame具有正确的JMenuBar。为什么会这样?

编辑: 这是退出程序的ActionExit类:

public class ActionExit extends AbstractAction
{
  private Model model;

  public ActionExit(Model model)
  {
    this.model = model;
  }

  @Override
  public void actionPerformed(ActionEvent e)
  {
    System.exit(0);
  }
}

2 个答案:

答案 0 :(得分:1)

JMenuItem(实际上所有AbstractButton的孩子)都从Action.NAME属性中获取显示文字。

尝试更像......

public class ActionExit extends AbstractAction
{
  private Model model;

  public ActionExit(Model model)
  {
    this.model = model;
    putValue(NAME, "Exit");
  }

  @Override
  public void actionPerformed(ActionEvent e)
  {
    System.exit(0);
  }
}

此外,Action类还定义了mnemonicaccelerator值。

请查看How to use ActionsAction API了解详情

答案 1 :(得分:1)

选中这个,我的小可爱代码,这个程序在 JFrame 中只有一个 JMenuBar ,在中只有一个 JMenuItem JMenuBar ,这可能会对你有所帮助。当你单击menuBar里面的menuItem时,所有这个程序都可以退出框架。为了更好地理解,请运行此程序

import javax.swing.*;

import java.awt.*;
import java.awt.event.*;
public class Class5 extends JFrame 
    {
        static JMenuBar exampleMenuBar = new JMenuBar();
        static JMenu fileMenu = new JMenu("Help");
        static JMenuItem Exit = new JMenuItem("Exit");


public static void main(String args[]) 
    {
        // construct frame
        new Class5().show();
    }
public Class5() 
   {
        // frame constructor
        setTitle("Menu Example");
        setSize(100, 100);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        // build menu
        setJMenuBar(exampleMenuBar);
        exampleMenuBar.add(fileMenu);
        fileMenu.add(Exit);

        Exit.addActionListener(new ActionListener()
            {
                public void actionPerformed(ActionEvent e)
                    {
                        System.exit(0);
                    }
            });



  }

}