X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FAlignmentPanel.java;h=0e9a0d8ff14cdda2fafbe0cdeb899a020e849e9a;hb=65f3b4a9eadadb7540c329e710bce082ea1dd8a7;hp=5e09da79a02e66e6db05fec25a2b206e0c5c14dc;hpb=3402d066dbd7667cd805e6d78ac5eca66e237c72;p=jalview.git diff --git a/src/jalview/appletgui/AlignmentPanel.java b/src/jalview/appletgui/AlignmentPanel.java index 5e09da7..0e9a0d8 100755 --- a/src/jalview/appletgui/AlignmentPanel.java +++ b/src/jalview/appletgui/AlignmentPanel.java @@ -22,13 +22,9 @@ package jalview.appletgui; import java.awt.*; import java.awt.event.*; -import jalview.analysis.*; import jalview.datamodel.*; -import jalview.jbappletgui.*; -import jalview.schemes.*; -public class AlignmentPanel - extends GAlignmentPanel implements AdjustmentListener +public class AlignmentPanel extends Panel implements AdjustmentListener { AlignViewport av; @@ -44,8 +40,22 @@ public class AlignmentPanel // this value is set false when selection area being dragged boolean fastPaint = true; + boolean MAC = false; + public AlignmentPanel(AlignFrame af, final AlignViewport av) { + try + { + jbInit(); + } + catch (Exception e) + { + e.printStackTrace(); + } + + if(System.getProperty("os.name").startsWith("Mac")) + MAC = true; + alignFrame = af; this.av = av; seqPanel = new SeqPanel(av, this); @@ -55,6 +65,8 @@ public class AlignmentPanel annotationPanel = new AnnotationPanel(this); alabels = new AnnotationLabels(this); + setAnnotationVisible(av.showAnnotation); + idPanelHolder.add(idPanel, BorderLayout.CENTER); idSpaceFillerPanel1.add(idwidthAdjuster, BorderLayout.CENTER); annotationScroller.add(annotationPanel); @@ -68,9 +80,6 @@ public class AlignmentPanel hscroll.addAdjustmentListener(this); vscroll.addAdjustmentListener(this); - seqPanel.seqCanvas.addKeyListener(new MyKeyAdapter()); - idPanel.idCanvas.addKeyListener(new MyKeyAdapter()); - addComponentListener(new ComponentAdapter() { public void componentResized(ComponentEvent evt) @@ -93,80 +102,30 @@ public class AlignmentPanel } - class MyKeyAdapter - extends KeyAdapter - { - public void keyPressed(KeyEvent evt) - { - // System.out.println(evt.getKeyCode()); log. - switch (evt.getKeyCode()) - { - case 27: // escape key - av.setSelectionGroup(null); - alignFrame.alignPanel.repaint(); - break; - case KeyEvent.VK_X: - if (evt.isControlDown()) - { - alignFrame.cut_actionPerformed(null); - } - break; - case KeyEvent.VK_C: - if (evt.isControlDown()) - { - alignFrame.copy_actionPerformed(null); - } - break; - case KeyEvent.VK_V: - if (evt.isControlDown()) - { - alignFrame.paste(true); - } - break; - case KeyEvent.VK_A: - if (evt.isControlDown()) - { - alignFrame.selectAllSequenceMenuItem_actionPerformed(null); - } - break; - case KeyEvent.VK_DOWN: - alignFrame.moveSelectedSequences(false); - break; - case KeyEvent.VK_UP: - alignFrame.moveSelectedSequences(true); - break; - case KeyEvent.VK_F: - if (evt.isControlDown()) - { - alignFrame.findMenuItem_actionPerformed(null); - } - break; - case KeyEvent.VK_BACK_SPACE: - case KeyEvent.VK_DELETE: - alignFrame.cut_actionPerformed(null); - break; - - } - } - } public void fontChanged() { // set idCanvas bufferedImage to null // to prevent drawing old image + idPanel.idCanvas.image =null; FontMetrics fm = getFontMetrics(av.getFont()); scalePanel.setSize(new Dimension(10, av.charHeight + fm.getDescent())); idwidthAdjuster.setSize(new Dimension(10, av.charHeight + fm.getDescent())); - annotationPanel.adjustPanelHeight(); + int ap = annotationPanel.adjustPanelHeight(); annotationPanel.repaint(); Dimension d = calculateIdWidth(); d.setSize(d.width + 4, seqPanel.seqCanvas.getSize().height); + alabels.setSize(d.width+4, ap ); idPanel.idCanvas.setSize(d); hscrollFillerPanel.setSize(d); - alignFrame.pack(); + validate(); + repaint(); + + if(overviewPanel!=null) + overviewPanel.updateOverviewImage(); } public void setIdWidth(int w, int h) @@ -198,14 +157,7 @@ public class AlignmentPanel while (i < al.getHeight() && al.getSequenceAt(i) != null) { SequenceI s = al.getSequenceAt(i); - if (av.getShowFullId()) - { - id = s.getDisplayId(); - } - else - { - id = s.getName(); - } + id = s.getDisplayId(av.getShowJVSuffix()); if (fm.stringWidth(id) > idWidth) { @@ -243,15 +195,42 @@ public class AlignmentPanel SequenceI seq = av.alignment.getSequenceAt(results[0]); int start = seq.findIndex(results[1]) - 1; int end = seq.findIndex(results[2]) - 1; - if (av.getStartRes() > start - || av.getEndRes() < end - || (av.getStartSeq() > results[0] - || av.getEndSeq() < results[0])) + + if(!av.wrapAlignment) { - setScrollValues(start, results[0]); + if ( (av.getStartRes() > start) || (av.getEndRes() < end) || + ( (av.getStartSeq() > results[0]) || + (av.getEndSeq() < results[0]))) + { + int newy = results[0]; + if(start > av.alignment.getWidth() - hextent) + { + start = av.alignment.getWidth() - hextent; + if(start<0) + start = 0; + } + if(newy > av.alignment.getHeight() - vextent) + { + newy = av.alignment.getHeight() - vextent; + if(newy<0) + newy = 0; + } + setScrollValues(start, newy); + } + } + else + { + int cwidth = seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.seqCanvas.getSize().width); + if( start(av.getStartRes()+cwidth) ) + { + + vscroll.setValue(start / cwidth); + av.startRes = vscroll.getValue() * cwidth; + } } } + repaint(); } public OverviewPanel getOverviewPanel() @@ -266,52 +245,46 @@ public class AlignmentPanel public void setAnnotationVisible(boolean b) { - annotationSpaceFillerHolder.setVisible(b); - annotationScroller.setVisible(b); + if (!av.wrapAlignment) + { + annotationSpaceFillerHolder.setVisible(b); + annotationScroller.setVisible(b); + } validate(); repaint(); } public void setWrapAlignment(boolean wrap) { + av.startSeq = 0; scalePanelHolder.setVisible(!wrap); - hscroll.setVisible(!wrap); - idwidthAdjuster.setVisible(!wrap); - - av.setShowAnnotation(!wrap); - annotationScroller.setVisible(!wrap); - annotationSpaceFillerHolder.setVisible(!wrap); - idSpaceFillerPanel1.setVisible(!wrap); - - validate(); - repaint(); - } - public void setColourScheme() - { - ColourSchemeI cs = av.getGlobalColourScheme(); + hscroll.setVisible(!wrap); + idwidthAdjuster.setVisible(!wrap); - if (av.getConservationSelected()) + if (wrap) { + annotationScroller.setVisible(false); + annotationSpaceFillerHolder.setVisible(false); + } + else if (av.showAnnotation) + { + annotationScroller.setVisible(true); + annotationSpaceFillerHolder.setVisible(true); + } - Alignment al = (Alignment) av.getAlignment(); - Conservation c = new Conservation("All", - ResidueProperties.propHash, 3, - al.getSequences(), 0, - al.getWidth()); - - c.calculate(); - c.verdict(false, av.ConsPercGaps); - ConservationColourScheme ccs = new ConservationColourScheme(c, cs); - av.setGlobalColourScheme(ccs); + idSpaceFillerPanel1.setVisible(!wrap); - } + fontChanged();//This is so that the scalePanel is resized correctly + validate(); repaint(); + } + int hextent = 0; int vextent = 0; @@ -421,7 +394,7 @@ public class AlignmentPanel int oldX = av.getStartRes(); int oldY = av.getStartSeq(); - if (evt.getSource() == hscroll) + if (evt==null || evt.getSource() == hscroll) { int x = hscroll.getValue(); av.setStartRes(x); @@ -429,7 +402,7 @@ public class AlignmentPanel 1); } - if (evt.getSource() == vscroll) + if (evt==null || evt.getSource() == vscroll) { int offy = vscroll.getValue(); if (av.getWrapAlignment()) @@ -452,15 +425,25 @@ public class AlignmentPanel overviewPanel.setBoxPosition(); } - if (av.getWrapAlignment() || !fastPaint) + int scrollX = av.startRes - oldX; + int scrollY = av.startSeq - oldY; + + if (av.getWrapAlignment() || !fastPaint || MAC) { repaint(); } - else + else if(!seqPanel.seqCanvas.fastPaint) { - idPanel.idCanvas.fastPaint(av.getStartSeq() - oldY); - seqPanel.seqCanvas.fastPaint(av.getStartRes() - oldX, - av.getStartSeq() - oldY); + // Make sure we're not trying to draw a panel + // larger than the visible window + if(scrollX>av.endRes-av.startRes) + scrollX = av.endRes-av.startRes; + else if(scrollX