freecol/src/net/sf/freecol/client/gui/menu/FreeColMenuBar.java

261 lines
8.3 KiB
Java

/**
* Copyright (C) 2002-2022 The FreeCol Team
*
* This file is part of FreeCol.
*
* FreeCol is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* FreeCol is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with FreeCol. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.freecol.client.gui.menu;
import java.awt.Graphics;
import java.awt.event.ActionListener;
import java.awt.event.KeyEvent;
import java.awt.event.MouseMotionListener;
import java.util.logging.Logger;
import javax.swing.ButtonGroup;
import javax.swing.JCheckBoxMenuItem;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JRadioButtonMenuItem;
import net.sf.freecol.client.FreeColClient;
import net.sf.freecol.client.gui.ImageLibrary;
import net.sf.freecol.client.gui.action.AboutAction;
import net.sf.freecol.client.gui.action.ActionManager;
import net.sf.freecol.client.gui.action.ColopediaAction;
import net.sf.freecol.client.gui.action.ColopediaAction.PanelType;
import net.sf.freecol.client.gui.action.FreeColAction;
import net.sf.freecol.client.gui.action.SelectableAction;
import net.sf.freecol.client.gui.action.SelectableOptionAction;
import net.sf.freecol.client.gui.panel.FreeColImageBorder;
import net.sf.freecol.client.gui.panel.Utility;
import net.sf.freecol.common.util.ImageUtils;
/**
* The menu bar that is displayed on the top left corner of the
* {@code Canvas}.
*/
public abstract class FreeColMenuBar extends JMenuBar {
private static final Logger logger = Logger.getLogger(FreeColMenuBar.class.getName());
protected final FreeColClient freeColClient;
private final MouseMotionListener listener;
protected final ActionManager am;
/**
* Creates a new {@code FreeColMenuBar}. This menu bar will include
* all of the submenus and items.
*
* @param f The main controller.
*/
protected FreeColMenuBar(FreeColClient f, MouseMotionListener listener) {
// FIXME: FreeColClient should not have to be passed in to
// this class. This is only a menu bar, it doesn't need a
// reference to the main controller. The only reason it has
// one now is because DebugMenu needs it. And DebugMenu needs
// it because it is using inner classes for ActionListeners
// and those inner classes use the reference. If those inner
// classes were in seperate classes, when they were created,
// they could use the FreeColClient reference of the
// ActionManger. So DebugMenu needs to be refactored to remove
// inner classes so that this MenuBar can lose its unnecessary
// reference to the main controller. See FreeColMenuTest.
//
// Okay, I lied.. the update() and paintComponent() methods in
// this MenuBar use freeColClient, too. But so what. Move
// those to another class too. :)
super();
setOpaque(false);
this.freeColClient = f;
this.listener = listener;
this.am = f.getActionManager();
// Add a mouse listener so that autoscrolling can happen here
this.addMouseMotionListener(listener);
setBorder(FreeColImageBorder.menuBarBorder);
}
@Override
public JMenu add(JMenu c) {
// Add a mouse listener so that autoscrolling can happen here
c.addMouseMotionListener(listener);
return super.add(c);
}
/**
* Resets this menu bar.
*
* <br><br>
* <b>For subclasses:</b>
* This method should reset both the texts and
* the accelerator keys used by the menu items.
*/
public abstract void reset();
/**
* Creates a default FreeCol JMenuItem.
*
* @param actionId The identifier given to the
* {@link ActionManager#getFreeColAction(String) action manager}.
* @return The menu item.
*/
protected JMenuItem getMenuItem(String actionId) {
JMenuItem rtn = null;
FreeColAction action = am.getFreeColAction(actionId);
if (action != null) {
rtn = new JMenuItem();
rtn.setAction(action);
rtn.setOpaque(false);
if (action.getMnemonic() != null) {
rtn.addMenuKeyListener(action.getMenuKeyListener());
}
} else {
logger.finest("Could not create menu item. [" + actionId
+ "] not found.");
}
return rtn;
}
/**
* Creates a default FreeCol JMenuItem.
*
* @param actionId The identifier given to the
* {@link ActionManager#getFreeColAction(String) action manager}.
* @param actionListener An {@code ActionListener} that will be
* added to the menu item.
* @return The menu item with the {@code ActionListener} added.
*/
protected JMenuItem getMenuItem(String actionId,
ActionListener actionListener) {
JMenuItem rtn = getMenuItem(actionId);
rtn.addActionListener(actionListener);
return rtn;
}
/**
* Creates a default FreeCol {@code JCheckBoxMenuItem}.
*
* @param actionId The identifier given to the
* {@link ActionManager#getFreeColAction(String) action manager}.
* @return The menu item.
*/
protected JCheckBoxMenuItem getCheckBoxMenuItem(String actionId) {
JCheckBoxMenuItem rtn = null;
FreeColAction action = am.getFreeColAction(actionId);
if (action != null) {
rtn = new JCheckBoxMenuItem();
rtn.setAction(action);
rtn.setOpaque(false);
//rtn.setSelected(((SelectableAction) am.getFreeColAction(actionId)).isSelected());
} else {
logger.finest("Could not create menu item. [" + actionId + "] not found.");
}
return rtn;
}
/**
* Creates a default FreeCol {@code JRadioButtonMenuItem}.
*
* @param actionId The identifier given to the
* {@link ActionManager#getFreeColAction(String) action manager}.
* @param group The {@code ButtonGroup} to add this item to
* @return The menu item.
*/
protected JRadioButtonMenuItem getRadioButtonMenuItem(String actionId,
ButtonGroup group) {
JRadioButtonMenuItem rtn = null;
FreeColAction action = am.getFreeColAction(actionId);
if (action != null) {
rtn = new JRadioButtonMenuItem();
rtn.setAction(action);
rtn.setOpaque(false);
rtn.setSelected(((SelectableOptionAction) am.getFreeColAction(actionId)).isSelected());
group.add(rtn);
} else {
logger.finest("Could not create menu item. [" + actionId
+ "] not found.");
}
return rtn;
}
/**
* Updates this {@code FreeColMenuBar}.
*/
public void update() {
revalidate();
repaint();
}
/**
* When a {@code FreeColMenuBar} is disabled, it does not show the
* "in game options".
*/
@Override
public void setEnabled(boolean enabled) {
// Not implemented (and possibly not needed).
update();
}
protected void buildColopediaMenu() {
// --> Colopedia
JMenu menu = Utility.localizedMenu("menuBar.colopedia");
menu.setOpaque(false);
menu.setMnemonic(KeyEvent.VK_C);
for (PanelType type : PanelType.values()) {
menu.add(getMenuItem(ColopediaAction.id + type.getKey()));
}
menu.addSeparator();
menu.add(getMenuItem(AboutAction.id));
add(menu);
}
/**
* Paints the background and borders of the menubar.
*/
@Override
public void paintComponent(Graphics g) {
if (isOpaque()) {
super.paintComponent(g);
} else {
ImageUtils.drawTiledImage(ImageLibrary.getMenuBarBackground(),
g, this, getInsets());
}
}
}