X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FScalePanel.java;h=7ed0146de4bb7babefd36e2c400d21fe5f5763d8;hb=0b23947e2cdcd704d3f313b23ba271e43d097344;hp=e9082b88cc761f024cc6a48279f55d8172fb28fd;hpb=f0ea7e292e26e7cec19720be39b143d261f53821;p=jalview.git diff --git a/src/jalview/gui/ScalePanel.java b/src/jalview/gui/ScalePanel.java index e9082b8..7ed0146 100755 --- a/src/jalview/gui/ScalePanel.java +++ b/src/jalview/gui/ScalePanel.java @@ -1,6 +1,6 @@ /* * Jalview - A Sequence Alignment Editor and Viewer - * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle + * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -73,83 +73,95 @@ public class ScalePanel extends JPanel implements MouseMotionListener, MouseList min = res; max = res; - /* if(reveal != null && SwingUtilities.isRightMouseButton(evt)) + if (SwingUtilities.isRightMouseButton(evt)) + { + JPopupMenu pop = new JPopupMenu(); + if (reveal != null) { - JPopupMenu pop = new JPopupMenu(); JMenuItem item = new JMenuItem("Reveal"); item.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { - av.getColumnSelection().revealHiddenColumns(reveal[0], av); + av.showColumn(reveal[0]); reveal = null; ap.repaint(); - if(ap.overviewPanel != null) - ap.overviewPanel.updateOverviewImage(); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); } }); pop.add(item); - if(av.getColumnSelection().hiddenColumns.size()>1) + if (av.getColumnSelection().getHiddenColumns().size() > 1) { item = new JMenuItem("Reveal All"); item.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { - av.getColumnSelection().revealAllHiddenColumns(av); + av.showAllHiddenColumns(); reveal = null; ap.repaint(); - if(ap.overviewPanel != null) + if (ap.overviewPanel != null) ap.overviewPanel.updateOverviewImage(); } }); pop.add(item); } - pop.show(this, evt.getX(), evt.getY()); - } - else*/ - if (av.getColumnSelection().contains(res)) - { - /* if( SwingUtilities.isRightMouseButton(evt)) + else if (av.getColumnSelection().contains(res)) { - JPopupMenu pop = new JPopupMenu(); JMenuItem item = new JMenuItem("Hide Columns"); item.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { - av.getColumnSelection().hideColumns(res, av); + av.hideColumns(res, res); + if(av.getSelectionGroup()!=null + && av.getSelectionGroup().getSize(false)==av.alignment.getHeight()) + av.setSelectionGroup(null); + ap.repaint(); - if(ap.overviewPanel != null) + if (ap.overviewPanel != null) ap.overviewPanel.updateOverviewImage(); } }); pop.add(item); pop.show(this, evt.getX(), evt.getY()); - - } - else*/ - { - av.getColumnSelection().removeElement(res); - av.setSelectionGroup(null); } } - else + else // LEFT MOUSE TO SELECT { - av.getColumnSelection().addElement(res); - SequenceGroup sg = new SequenceGroup(); + if (!evt.isControlDown() && !evt.isShiftDown()) + { + av.getColumnSelection().clear(); + } + + av.getColumnSelection().addElement(res); + SequenceGroup sg = new SequenceGroup(); + for (int i = 0; i < av.alignment.getSequences().size(); i++) + { + sg.addSequence(av.alignment.getSequenceAt(i), false); + } + + sg.setStartRes(res); + sg.setEndRes(res); + av.setSelectionGroup(sg); - for (int i = 0; i < av.alignment.getSequences().size(); i++) + if(evt.isShiftDown()) + { + int min = Math.min(av.getColumnSelection().getMin(), res); + int max = Math.max(av.getColumnSelection().getMax(), res); + for (int i = min; i av.alignment.getWidth()) + { + res = av.alignment.getWidth()-1; + } + if(av.hasHiddenColumns) res = av.getColumnSelection().adjustForHiddenColumns(res); @@ -202,10 +219,18 @@ public class ScalePanel extends JPanel implements MouseMotionListener, MouseList mouseDragging = true; int res = (evt.getX() / av.getCharWidth()) + av.getStartRes(); + if(res<0) + res = 0; if(av.hasHiddenColumns) res = av.getColumnSelection().adjustForHiddenColumns(res); + + if(res> av.alignment.getWidth()) + { + res = av.alignment.getWidth()-1; + } + if (res < min) { min = res; @@ -217,6 +242,7 @@ public class ScalePanel extends JPanel implements MouseMotionListener, MouseList } + SequenceGroup sg = av.getSelectionGroup(); if (sg != null) @@ -388,20 +414,29 @@ public class ScalePanel extends JPanel implements MouseMotionListener, MouseList { gg.setColor(Color.blue); int res; - for (int i = 0; i < av.getColumnSelection().getHiddenColumns().size(); i++) + if(av.getShowHiddenMarkers()) { - res = av.getColumnSelection().findHiddenRegionPosition( i )-startx; + for (int i = 0; i < av.getColumnSelection().getHiddenColumns().size(); + i++) + { - gg.fillPolygon(new int[] { res*av.charWidth - av.charHeight/4, - res*av.charWidth + av.charHeight/4, - res*av.charWidth }, - new int[] - { - y-av.charHeight/2 , y-av.charHeight/2 , - y + 8 - }, 3); + res = av.getColumnSelection().findHiddenRegionPosition(i) - + startx; + if(res < 0 || res > endx-scalestartx) + continue; + gg.fillPolygon(new int[] + {res * av.charWidth - av.charHeight / 4, + res * av.charWidth + av.charHeight / 4, + res * av.charWidth}, + new int[] + { + y - av.charHeight / 2, y - av.charHeight / 2, + y + 8 + }, 3); + + } } if (reveal != null && reveal[0] > startx && reveal[0] < endx)