X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FScalePanel.java;h=5419d2722bafee2c15d6df8beb2d4456647b976d;hb=3caa3405a5822c7248bab517b8d1a7776e0dc210;hp=51a03cc2c3c2e9998841220ba0d18b057322c177;hpb=ec955aa655d8320258b91eb079bc57f688cd0a07;p=jalview.git diff --git a/src/jalview/appletgui/ScalePanel.java b/src/jalview/appletgui/ScalePanel.java index 51a03cc..5419d27 100755 --- a/src/jalview/appletgui/ScalePanel.java +++ b/src/jalview/appletgui/ScalePanel.java @@ -1,114 +1,297 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer + * Copyright (C) 2005 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 + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program 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 this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA + */ + package jalview.appletgui; -import jalview.datamodel.*; import java.awt.*; import java.awt.event.*; -public class ScalePanel extends Panel +import jalview.datamodel.*; + +public class ScalePanel + extends Panel implements MouseMotionListener, MouseListener { protected int offy = 4; - public int width; + public int width; protected AlignViewport av; AlignmentPanel ap; boolean stretchingGroup = false; + int min; //used by mouseDragged to see if user + int max; //used by mouseDragged to see if user + boolean mouseDragging = false; + int [] reveal; public ScalePanel(AlignViewport av, AlignmentPanel ap) { setLayout(null); - this.av = av; + this.av = av; this.ap = ap; - addMouseListener(new MouseAdapter() + addMouseListener(this); + addMouseMotionListener(this); + + } + + public void mousePressed(MouseEvent evt) + { + int x = (evt.getX() / av.getCharWidth()) + av.getStartRes(); + final int res; + + if (av.hasHiddenColumns) + res = av.getColumnSelection().adjustForHiddenColumns(x); + else + res = x; + + min = res; + max = res; + if ((evt.getModifiers() & InputEvent.BUTTON3_MASK) + == InputEvent.BUTTON3_MASK) { - public void mousePressed(MouseEvent evt) + PopupMenu pop = new PopupMenu(); + if (reveal != null) { - doMousePressed(evt); + MenuItem item = new MenuItem("Reveal"); + item.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + av.showColumn(reveal[0]); + reveal = null; + ap.repaint(); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); + } + }); + pop.add(item); + + if (av.getColumnSelection().getHiddenColumns().size() > 1) + { + item = new MenuItem("Reveal All"); + item.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + av.showAllHiddenColumns(); + reveal = null; + ap.repaint(); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); + } + }); + pop.add(item); + } + pop.show(this, evt.getX(), evt.getY()); } - public void mouseReleased(MouseEvent evt) + else if (av.getColumnSelection().contains(res)) { - doMouseReleased(evt); + MenuItem item = new MenuItem("Hide Columns"); + item.addActionListener(new ActionListener() + { + public void actionPerformed(ActionEvent e) + { + av.hideColumns(res, res); + ap.repaint(); + if (ap.overviewPanel != null) + ap.overviewPanel.updateOverviewImage(); + } + }); + pop.add(item); + pop.show(this, evt.getX(), evt.getY()); } - - }); - addMouseMotionListener(new MouseMotionAdapter() + } + else // LEFT MOUSE TO SELECT { - public void mouseDragged(MouseEvent evt) + if (!evt.isControlDown() && !evt.isShiftDown()) { - doMouseDragged(evt); + av.getColumnSelection().clear(); } - }); - } - - - public void doMousePressed(MouseEvent evt) { - int x = evt.getX(); - int res = x/av.getCharWidth() + av.getStartRes(); - SequenceGroup sg = null; - - if (av.getColumnSelection().contains(res)) - av.getColumnSelection().removeElement(res); - else - { av.getColumnSelection().addElement(res); - - sg = new SequenceGroup(); + SequenceGroup sg = new SequenceGroup(); for (int i = 0; i < av.alignment.getSequences().size(); i++) - sg.addSequence(av.alignment.getSequenceAt(i)); + { + sg.addSequence(av.alignment.getSequenceAt(i), false); + } sg.setStartRes(res); sg.setEndRes(res); + av.setSelectionGroup(sg); - ap.annotationPanel.addEditableColumn(res); + 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); + + if (!stretchingGroup) + { + ap.repaint(); - SequenceGroup sg = av.getSelectionGroup(); + return; + } + + SequenceGroup sg = av.getSelectionGroup(); - if(res>sg.getStartRes()) - sg.setEndRes(res); - else if(res sg.getStartRes()) + { + sg.setEndRes(res); + } + else if (res < sg.getStartRes()) + { + sg.setStartRes(res); + } - stretchingGroup = false; - ap.repaint(); + stretchingGroup = false; + ap.repaint(); } - public void doMouseDragged(MouseEvent evt) + public void mouseDragged(MouseEvent evt) { - int x = evt.getX(); - int res = x/av.getCharWidth() + av.getStartRes(); + 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; + } + + if (res > max) + { + max = res; + } SequenceGroup sg = av.getSelectionGroup(); - if(sg!=null) + + if (sg != null) { stretchingGroup = true; + + if (!av.getColumnSelection().contains(res)) + { + av.getColumnSelection().addElement(res); + } + if (res > sg.getStartRes()) + { sg.setEndRes(res); - else if (res < sg.getStartRes()) + } + if (res < sg.getStartRes()) + { sg.setStartRes(res); + } + + for (int i = min; i <= max; i++) + { + if ( (i < sg.getStartRes()) || (i > sg.getEndRes())) + { + av.getColumnSelection().removeElement(i); + } + else + { + av.getColumnSelection().addElement(i); + } + } - ap.annotationPanel.addEditableColumn(res); ap.repaint(); } } + + public void mouseEntered(MouseEvent evt) + { + if (mouseDragging) + ap.seqPanel.scrollCanvas(null); + } + + public void mouseExited(MouseEvent evt) + { + if (mouseDragging) + ap.seqPanel.scrollCanvas(evt); + } + + public void mouseClicked(MouseEvent evt) + { + + } + + public void mouseMoved(MouseEvent evt) + { + if (!av.hasHiddenColumns) + return; + + int res = (evt.getX() / av.getCharWidth()) + av.getStartRes(); + + res = av.getColumnSelection().adjustForHiddenColumns(res); + + reveal = null; + for (int i = 0; i < av.getColumnSelection().getHiddenColumns().size(); i++) + { + int[] region = (int[]) av.getColumnSelection().getHiddenColumns(). + elementAt(i); + if (res + 1 == region[0] || res - 1 == region[1]) + { + reveal = region; + break; + } + } + + repaint(); + } + public void update(Graphics g) { paint(g); @@ -116,60 +299,119 @@ public class ScalePanel extends Panel public void paint(Graphics g) { - drawScale(g, av.getStartRes(), av.getEndRes(), getSize().width, getSize().height); + drawScale(g, av.getStartRes(), av.getEndRes(), getSize().width, + getSize().height); } // scalewidth will normally be screenwidth, - public void drawScale(Graphics gg, int startx, int endx, int width, int height) + public void drawScale(Graphics gg, int startx, int endx, int width, + int height) { gg.setFont(av.getFont()); + //Fill in the background gg.setColor(Color.white); - gg.fillRect(0,0,width, height); + gg.fillRect(0, 0, width, height); gg.setColor(Color.black); - //Fill the selected columns ColumnSelection cs = av.getColumnSelection(); - gg.setColor(new Color(220,0,0)); - for (int i=0; i= startx && sel <= endx) - gg.fillRect((sel-startx)*av.charWidth,0,av.charWidth, getSize().height); - } + int sel = cs.columnAt(i); + if(av.hasHiddenColumns) + sel = av.getColumnSelection().findColumnPosition(sel); + + if ((sel >= startx) && (sel <= endx)) + { + gg.fillRect((sel - startx) * av.charWidth, 0, av.charWidth, + getSize().height); + } + } // Draw the scale numbers gg.setColor(Color.black); - int scalestartx = (startx/10) * 10; + + int scalestartx = (startx / 10) * 10; FontMetrics fm = gg.getFontMetrics(av.getFont()); - int y = av.charHeight -fm.getDescent(); + int y = av.charHeight - fm.getDescent(); - if(scalestartx%10==0) - scalestartx+=5; + if ((scalestartx % 10) == 0) + { + scalestartx += 5; + } - for (int i=scalestartx;i < endx; i+= 5) + String string; + int maxX=0; + + for (int i = scalestartx; i < endx; i += 5) { - if(i%10==0) + if ((i % 10) == 0) + { + string = String.valueOf(av.getColumnSelection().adjustForHiddenColumns(i)); + if ( (i - startx - 1) * av.charWidth > maxX) + { + gg.drawString(string, + (i - startx - 1) * av.charWidth, y); + maxX = (i - startx + 1) * av.charWidth + fm.stringWidth(string); + } + + gg.drawLine( (int) ( ( (i - startx - 1) * av.charWidth) + + (av.charWidth / 2)), y + 2, + (int) ( ( (i - startx - 1) * av.charWidth) + + (av.charWidth / 2)), + y + (fm.getDescent() * 2)); + + } + else + { + gg.drawLine((int) (((i - startx - 1) * av.charWidth) + + (av.charWidth / 2)), y + fm.getDescent(), + (int) (((i - startx - 1) * av.charWidth) + + (av.charWidth / 2)), y + (fm.getDescent() * 2)); + } + } + + if (av.hasHiddenColumns) + { + gg.setColor(Color.blue); + int res; + if(av.getShowHiddenMarkers()) { - gg.drawString(String.valueOf(i), (i - startx - 1) * av.charWidth, y); - gg.drawLine( (int) ( (i - startx - 1) * av.charWidth + av.charWidth / 2), - y+2, - (int) ( (i - startx - 1) * av.charWidth + av.charWidth / 2), - y+fm.getDescent()*2); + for (int i = 0; i < av.getColumnSelection().getHiddenColumns().size(); + i++) + { + + 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); + + } } - else - gg.drawLine( (int) ( (i - startx - 1) * av.charWidth + av.charWidth / 2), - y+fm.getDescent(), - (int) ( (i - startx - 1) * av.charWidth + av.charWidth / 2), - y+fm.getDescent()*2); - + if (reveal != null && reveal[0] > startx && reveal[0] < endx) + { + gg.drawString("Reveal Columns", reveal[0] * av.charWidth, 0); + } } - } + } }