X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FViewSelectionMenu.java;h=d906c6d66b43dc6be874d4299303baba67d1614c;hb=17e77c3f2949a0729322b4a8d907f3f34b6a9914;hp=c5433e5b9fed44c7e8fb11c869661deb937e54dc;hpb=8665af1fa6a2b21f4bcfe50e8e375f3a59253313;p=jalview.git diff --git a/src/jalview/gui/ViewSelectionMenu.java b/src/jalview/gui/ViewSelectionMenu.java index c5433e5..d906c6d 100644 --- a/src/jalview/gui/ViewSelectionMenu.java +++ b/src/jalview/gui/ViewSelectionMenu.java @@ -1,12 +1,34 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.9) + * Copyright (C) 2015 The Jalview Authors + * + * This file is part of Jalview. + * + * Jalview 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 3 + * of the License, or (at your option) any later version. + * + * Jalview 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 Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ package jalview.gui; +import jalview.util.MessageManager; + import java.awt.Component; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.ItemEvent; import java.awt.event.ItemListener; +import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; -import java.awt.event.MouseListener; import java.util.List; import javax.swing.JCheckBoxMenuItem; @@ -104,12 +126,17 @@ public class ViewSelectionMenu extends JMenu * menu selection event occurred. */ private boolean append = false; + /** - * flag indicating if the itemStateChanged listener for view associated menu items is currently enabled + * flag indicating if the itemStateChanged listener for view associated menu + * items is currently enabled */ private boolean enabled = true; + private JMenuItem selectAll, invertSel; - private JCheckBoxMenuItem toggleview=null; + + private JCheckBoxMenuItem toggleview = null; + private void rebuild() { removeAll(); @@ -122,10 +149,13 @@ public class ViewSelectionMenu extends JMenu if (allviews.length >= 2) { // ensure we update menu state to reflect external selection list state - append = append || _selectedviews.size()>1; - toggleview = new JCheckBoxMenuItem("Select many views",append); - toggleview.setToolTipText("When enabled, allows many views to be selected."); - toggleview.addItemListener(new ItemListener() { + append = append || _selectedviews.size() > 1; + toggleview = new JCheckBoxMenuItem( + MessageManager.getString("label.select_many_views"), append); + toggleview.setToolTipText(MessageManager + .getString("label.toggle_enabled_views")); + toggleview.addItemListener(new ItemListener() + { @Override public void itemStateChanged(ItemEvent arg0) @@ -136,12 +166,13 @@ public class ViewSelectionMenu extends JMenu selectAll.setEnabled(append); invertSel.setEnabled(append); } - + } - + }); add(toggleview); - add(selectAll= new JMenuItem("Select all views")); + add(selectAll = new JMenuItem( + MessageManager.getString("label.select_all_views"))); selectAll.addActionListener(new ActionListener() { @@ -150,141 +181,118 @@ public class ViewSelectionMenu extends JMenu { for (Component c : getMenuComponents()) { - boolean t=append; - append=true; + boolean t = append; + append = true; if (c instanceof JCheckBoxMenuItem) { - if (toggleview!=c && !((JCheckBoxMenuItem) c).isSelected()) + if (toggleview != c && !((JCheckBoxMenuItem) c).isSelected()) { ((JCheckBoxMenuItem) c).doClick(); } } - append=t; + append = t; } } }); - add(invertSel = new JMenuItem("Invert selection")); + add(invertSel = new JMenuItem( + MessageManager.getString("label.invert_selection"))); invertSel.addActionListener(new ActionListener() { @Override public void actionPerformed(ActionEvent e) { - boolean t=append; - append=true; + boolean t = append; + append = true; for (Component c : getMenuComponents()) { - if (toggleview!=c && c instanceof JCheckBoxMenuItem) + if (toggleview != c && c instanceof JCheckBoxMenuItem) { ((JCheckBoxMenuItem) c).doClick(); } } - append=t; + append = t; } }); invertSel.setEnabled(append); selectAll.setEnabled(append); } - for (AlignmentPanel ap : allviews) + for (final AlignmentPanel ap : allviews) { String nm = ((ap.getViewName() == null || ap.getViewName().length() == 0) ? "" : ap.getViewName() + " for ") + ap.alignFrame.getTitle(); - final JCheckBoxMenuItem a = new JCheckBoxMenuItem(nm, + final JCheckBoxMenuItem checkBox = new JCheckBoxMenuItem(nm, _selectedviews.contains(ap)); - final AlignmentPanel p = ap; - a.addItemListener(new ItemListener() + checkBox.addItemListener(new ItemListener() { @Override public void itemStateChanged(ItemEvent e) { if (enabled) { - if (append) - { - enabled=false; - // toggle the inclusion state - if (_selectedviews.indexOf(p)==-1) + if (append) { - _selectedviews.add(p); - a.setSelected(true); + enabled = false; + // toggle the inclusion state + if (_selectedviews.indexOf(ap) == -1) + { + _selectedviews.add(ap); + checkBox.setSelected(true); + } + else + { + _selectedviews.remove(ap); + checkBox.setSelected(false); + } + enabled = true; + _handler.itemStateChanged(e); } else { - _selectedviews.remove(p); - a.setSelected(false); - } - enabled=true; - _handler.itemStateChanged(e); - } - else - { - // Deselect everything and select this item only - _selectedviews.clear(); - _selectedviews.add(p); - enabled=false; - for (Component c : getMenuComponents()) - { - if (c instanceof JCheckBoxMenuItem) + // Deselect everything and select this item only + _selectedviews.clear(); + _selectedviews.add(ap); + enabled = false; + for (Component c : getMenuComponents()) { - ((JCheckBoxMenuItem) c).setSelected(a == c); + if (c instanceof JCheckBoxMenuItem) + { + ((JCheckBoxMenuItem) c).setSelected(checkBox == c); + } } + enabled = true; + // only fire event if we weren't selected before + _handler.itemStateChanged(e); } - enabled=true; - // only fire event if we weren't selected before - _handler.itemStateChanged(e); - } } } }); - a.addMouseListener(new MouseListener() + checkBox.addMouseListener(new MouseAdapter() { - - @Override - public void mouseReleased(MouseEvent e) - { - // TODO Auto-generated method stub - - } - - @Override - public void mousePressed(MouseEvent e) - { - // TODO Auto-generated method stub - - } - @Override public void mouseExited(MouseEvent e) { try { - p.setSelected(false); + ap.setSelected(false); } catch (Exception ex) { } - ; } @Override public void mouseEntered(MouseEvent e) { - try { - p.setSelected(true); + ap.setSelected(true); } catch (Exception ex) { } - ; - } - - @Override - public void mouseClicked(MouseEvent e) - { } }); - add(a); + add(checkBox); } }