/*\r
* Jalview - A Sequence Alignment Editor and Viewer\r
- * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
+ * Copyright (C) 2006 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
*\r
* This program is free software; you can redistribute it and/or\r
* modify it under the terms of the GNU General Public License\r
import java.awt.*;\r
import java.awt.event.*;\r
import java.awt.print.*;\r
-\r
import java.io.*;\r
-\r
import javax.swing.*;\r
+import java.beans.*;\r
\r
-import org.biojava.dasobert.eventmodel.*;\r
\r
\r
/**\r
* @version $Revision$\r
*/\r
public class AlignmentPanel extends GAlignmentPanel\r
- implements AdjustmentListener, Printable, FeatureListener\r
+ implements AdjustmentListener, Printable\r
{\r
public AlignViewport av;\r
OverviewPanel overviewPanel;\r
annotationPanel = new AnnotationPanel(this);\r
alabels = new AnnotationLabels(this);\r
\r
-\r
annotationScroller.setViewportView(annotationPanel);\r
annotationSpaceFillerHolder.add(alabels, BorderLayout.CENTER);\r
\r
fontChanged();\r
\r
scalePanelHolder.add(scalePanel, BorderLayout.CENTER);\r
- seqPanelHolder.add(seqPanel, BorderLayout.CENTER);\r
+ seqPanelHolder.add(seqPanel, BorderLayout.CENTER);\r
\r
setScrollValues(0, 0);\r
\r
- adjustAnnotationHeight();\r
-\r
setAnnotationVisible(av.getShowAnnotation());\r
\r
hscroll.addAdjustmentListener(this);\r
vscroll.addAdjustmentListener(this);\r
\r
- af.addKeyListener(new KeyAdapter()\r
+ final AlignmentPanel ap = this;\r
+ av.addPropertyChangeListener(new PropertyChangeListener()\r
{\r
- public void keyPressed(KeyEvent evt)\r
+ public void propertyChange(PropertyChangeEvent evt)\r
{\r
- if(av.cursorMode\r
- && evt.getKeyCode()>=KeyEvent.VK_0\r
- && evt.getKeyCode()<=KeyEvent.VK_9)\r
+ if (evt.getPropertyName().equals("alignment"))\r
{\r
- seqPanel.numberPressed(evt.getKeyChar());\r
+ PaintRefresher.Refresh(ap,\r
+ av.getSequenceSetId(),\r
+ true,\r
+ true);\r
+ alignmentChanged();\r
}\r
+ }\r
+ });\r
\r
- switch (evt.getKeyCode())\r
- {\r
- case 27: // escape key\r
- av.setSelectionGroup(null);\r
- repaint();\r
-\r
- break;\r
-\r
- case KeyEvent.VK_DOWN:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.moveCursor(0,1);\r
- }\r
- else\r
- alignFrame.moveSelectedSequences(false);\r
- break;\r
-\r
- case KeyEvent.VK_UP:\r
- if (av.cursorMode)\r
- {\r
- seqPanel.moveCursor(0,-1);\r
- }\r
- else\r
- alignFrame.moveSelectedSequences(true);\r
- break;\r
-\r
- case KeyEvent.VK_LEFT:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.moveCursor(-1,0);\r
- }\r
- break;\r
-\r
- case KeyEvent.VK_RIGHT:\r
- if (av.cursorMode)\r
- {\r
- seqPanel.moveCursor(1,0);\r
- }\r
- break;\r
-\r
- case KeyEvent.VK_SPACE:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.insertGapAtCursor(evt.isControlDown() || evt.isShiftDown());\r
- }\r
- break;\r
-\r
- case KeyEvent.VK_DELETE:\r
- case KeyEvent.VK_BACK_SPACE:\r
- if(!av.cursorMode)\r
- {\r
- alignFrame.cut_actionPerformed(null);\r
- seqPanel.seqCanvas.repaint();\r
- }\r
- else\r
- seqPanel.deleteGapAtCursor(evt.isControlDown() || evt.isShiftDown());\r
-\r
- break;\r
+ adjustAnnotationHeight();\r
\r
- case KeyEvent.VK_S:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setCursorRow();\r
- }\r
- break;\r
- case KeyEvent.VK_C:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setCursorColumn();\r
- }\r
- break;\r
- case KeyEvent.VK_P:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setCursorPosition();\r
- }\r
- break;\r
+ }\r
\r
- case KeyEvent.VK_ENTER:\r
- case KeyEvent.VK_COMMA:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setCursorRowAndColumn();\r
- }\r
- break;\r
+ public void alignmentChanged()\r
+ {\r
+ av.alignmentChanged(this);\r
\r
- case KeyEvent.VK_Q:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setSelectionAreaAtCursor(true);\r
- }\r
- break;\r
- case KeyEvent.VK_M:\r
- if(av.cursorMode)\r
- {\r
- seqPanel.setSelectionAreaAtCursor(false);\r
- }\r
- break;\r
-\r
- case KeyEvent.VK_F2:\r
- av.cursorMode = ! av.cursorMode;\r
- alignFrame.statusBar.setText("Keyboard editing mode is "+\r
- (av.cursorMode ? "on" : "off"));\r
- if(av.cursorMode)\r
- {\r
- seqPanel.seqCanvas.cursorX = av.startRes;\r
- seqPanel.seqCanvas.cursorY = av.startSeq;\r
- }\r
- seqPanel.seqCanvas.repaint();\r
- break;\r
-\r
- case KeyEvent.VK_F1:\r
- try\r
- {\r
- ClassLoader cl = jalview.gui.Desktop.class.getClassLoader();\r
- java.net.URL url = javax.help.HelpSet.findHelpSet(cl, "help/help");\r
- javax.help.HelpSet hs = new javax.help.HelpSet(cl, url);\r
+ if (overviewPanel != null)\r
+ overviewPanel.updateOverviewImage();\r
\r
- javax.help.HelpBroker hb = hs.createHelpBroker();\r
- hb.setCurrentID("home");\r
- hb.setDisplayed(true);\r
- }\r
- catch (Exception ex)\r
- {\r
- ex.printStackTrace();\r
- }\r
- break;\r
+ alignFrame.updateEditMenuBar();\r
\r
- }\r
- }\r
- });\r
+ repaint();\r
}\r
\r
- public void comeBackLater(FeatureEvent evt)\r
- {}\r
\r
- public void newFeatures(FeatureEvent evt)\r
- {\r
- seqPanel.seqCanvas.fr.findAllFeatures();\r
- repaint();\r
- }\r
\r
/**\r
* DOCUMENT ME!\r
idPanel.idCanvas.setPreferredSize(d);\r
hscrollFillerPanel.setPreferredSize(d);\r
\r
- if (av.getWrapAlignment())\r
- {\r
- int max = av.alignment.getWidth() /\r
- seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.seqCanvas.getWidth());\r
- vscroll.setMaximum(max);\r
- vscroll.setUnitIncrement(1);\r
- vscroll.setVisibleAmount(1);\r
- }\r
- else\r
- {\r
- setScrollValues(av.getStartRes(), av.getStartSeq());\r
- }\r
-\r
if (overviewPanel != null)\r
overviewPanel.setBoxPosition();\r
\r
{\r
Container c = new Container();\r
\r
- FontMetrics fm = c.getFontMetrics(av.font);\r
+ FontMetrics fm = c.getFontMetrics(\r
+ new Font(av.font.getName(), Font.ITALIC, av.font.getSize()));\r
+\r
AlignmentI al = av.getAlignment();\r
\r
int i = 0;\r
\r
public void adjustAnnotationHeight()\r
{\r
- javax.swing.SwingUtilities.invokeLater(new Runnable()\r
+ if (alignFrame.getHeight() == 0)\r
{\r
- public void run()\r
- {\r
- while(alignFrame.getHeight()==0)\r
- {\r
- Thread.yield();\r
- }\r
+ System.out.println("NEEDS FIXING");\r
+ }\r
\r
- int height = annotationPanel.adjustPanelHeight();\r
+ int height = annotationPanel.adjustPanelHeight();\r
\r
- if (height > alignFrame.getHeight() / 2)\r
- {\r
- height = alignFrame.getHeight() / 2;\r
- }\r
+ if (height > alignFrame.getHeight() / 2)\r
+ {\r
+ height = alignFrame.getHeight() / 2;\r
+ }\r
\r
- annotationScroller.setPreferredSize(\r
- new Dimension(annotationScroller.getWidth(),\r
- height));\r
+ annotationScroller.setPreferredSize(\r
+ new Dimension(annotationScroller.getWidth(),\r
+ height));\r
\r
- annotationSpaceFillerHolder.setPreferredSize(new Dimension(\r
- annotationSpaceFillerHolder.getWidth(),\r
- height));\r
+ annotationSpaceFillerHolder.setPreferredSize(new Dimension(\r
+ annotationSpaceFillerHolder.getWidth(),\r
+ height));\r
\r
- annotationPanel.repaint();\r
- }\r
- });\r
+ repaint();\r
}\r
\r
/**\r
*/\r
public void adjustmentValueChanged(AdjustmentEvent evt)\r
{\r
+\r
int oldX = av.getStartRes();\r
int oldY = av.getStartSeq();\r
\r
\r
if (av.getWrapAlignment())\r
{\r
- int rowSize = seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.\r
- seqCanvas.getWidth());\r
- av.setStartRes(vscroll.getValue() * rowSize);\r
- av.setEndRes( (vscroll.getValue() + 1) * rowSize);\r
+ if(offy>-1)\r
+ {\r
+ int rowSize = seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.\r
+ seqCanvas.getWidth());\r
+ av.setStartRes(offy * rowSize);\r
+ av.setEndRes( (offy + 1) * rowSize);\r
+ }\r
+ else\r
+ {\r
+ //This is only called if file loaded is a jar file that\r
+ //was wrapped when saved and user has wrap alignment true\r
+ //as preference setting\r
+ SwingUtilities.invokeLater(new Runnable()\r
+ {\r
+ public void run()\r
+ {\r
+ setScrollValues(av.getStartRes(), av.getStartSeq());\r
+ }\r
+ });\r
+ }\r
}\r
else\r
{\r
\r
if (av.getWrapAlignment())\r
{\r
- int max = av.alignment.getWidth() /\r
- seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.seqCanvas.getWidth()) +1;\r
+ int maxwidth = av.alignment.getWidth();\r
\r
+ if (av.hasHiddenColumns)\r
+ maxwidth = av.getColumnSelection().findColumnPosition(maxwidth) - 1;\r
\r
- vscroll.setMaximum(max);\r
- vscroll.setUnitIncrement(1);\r
- vscroll.setVisibleAmount(1);\r
+ int canvasWidth = seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.seqCanvas.getWidth());\r
+ if(canvasWidth>0)\r
+ {\r
+ int max = maxwidth /\r
+ seqPanel.seqCanvas.getWrappedCanvasWidth(seqPanel.seqCanvas.\r
+ getWidth()) +\r
+ 1;\r
+ vscroll.setMaximum(max);\r
+ vscroll.setUnitIncrement(1);\r
+ vscroll.setVisibleAmount(1);\r
+ }\r
}\r
else\r
{\r
if( this.getVisibleRect().getBounds() == g.getClipBounds()\r
&& overviewPanel != null)\r
overviewPanel.updateOverviewImage();\r
-\r
}\r
\r
/**\r
public int printUnwrapped(Graphics pg, int pwidth, int pheight, int pi)\r
throws PrinterException\r
{\r
- int idWidth = calculateIdWidth().width + 4;\r
+ int idWidth = getVisibleIdWidth();\r
FontMetrics fm = getFontMetrics(av.getFont());\r
int scaleHeight = av.charHeight + fm.getDescent();\r
\r
Color currentColor = null;\r
Color currentTextColor = null;\r
\r
- pg.setFont(new Font(av.getFont().getName(),\r
- Font.ITALIC,\r
- av.getFont().getSize()));\r
+ pg.setFont(idPanel.idCanvas.idfont);\r
+\r
+ SequenceI seq;\r
for (int i = startSeq; i < endSeq; i++)\r
{\r
+ seq = av.getAlignment().getSequenceAt(i);\r
if ( (av.getSelectionGroup() != null) &&\r
- av.getSelectionGroup().sequences.contains(\r
- av.getAlignment().getSequenceAt(i)))\r
+ av.getSelectionGroup().getSequences(null).contains(seq))\r
{\r
currentColor = Color.gray;\r
currentTextColor = Color.black;\r
}\r
else\r
{\r
- currentColor = av.getAlignment().getSequenceAt(i).getColor();\r
+ currentColor = av.getSequenceColour(seq);\r
currentTextColor = Color.black;\r
}\r
\r
\r
pg.setColor(currentTextColor);\r
\r
- String string = av.getAlignment().getSequenceAt(i).getDisplayId\r
- ( av.getShowJVSuffix());\r
+ int xPos = 0;\r
+ if (av.rightAlignIds)\r
+ {\r
+ fm = pg.getFontMetrics();\r
+ xPos = idWidth - fm.stringWidth(\r
+ seq.getDisplayId(av.getShowJVSuffix())\r
+ ) - 4;\r
+ }\r
\r
- pg.drawString(string, 0,\r
+ pg.drawString(seq.getDisplayId( av.getShowJVSuffix()),\r
+ xPos,\r
( ( (i - startSeq) * av.charHeight) + av.getCharHeight()) -\r
(av.getCharHeight() / 5));\r
}\r
+ hgap\r
+ annotationHeight;\r
\r
- int idWidth = calculateIdWidth().width + 4;\r
+ int idWidth = getVisibleIdWidth();\r
+\r
+ int maxwidth = av.alignment.getWidth();\r
+ if (av.hasHiddenColumns)\r
+ maxwidth = av.getColumnSelection().findColumnPosition(maxwidth) - 1;\r
+\r
\r
int resWidth = seqPanel.seqCanvas.getWrappedCanvasWidth(pwidth -\r
idWidth);\r
\r
- int totalHeight = cHeight * (av.alignment.getWidth() / resWidth + 1);\r
+ int totalHeight = cHeight * (maxwidth / resWidth + 1);\r
\r
pg.setColor(Color.white);\r
pg.fillRect(0, 0, pwidth, pheight);\r
pg.setClip(0, pi * pheight, pwidth, pheight);\r
\r
int ypos = hgap;\r
- Font italic = new Font(av.getFont().getName(), Font.ITALIC,\r
- av.getFont().getSize());\r
- pg.setFont(italic);\r
+\r
+\r
\r
do\r
{\r
for (int i = 0; i < av.alignment.getHeight(); i++)\r
{\r
+ pg.setFont(idPanel.idCanvas.idfont);\r
SequenceI s = av.alignment.getSequenceAt(i);\r
String string = s.getDisplayId( av.getShowJVSuffix());\r
-\r
- pg.drawString(string, 0,\r
+ int xPos = 0;\r
+ if (av.rightAlignIds)\r
+ {\r
+ FontMetrics fm = pg.getFontMetrics();\r
+ xPos = idWidth - fm.stringWidth( string ) - 4;\r
+ }\r
+ pg.drawString(string, xPos,\r
( (i * av.charHeight) + ypos + av.charHeight) -\r
(av.charHeight / 5));\r
}\r
\r
pg.setFont(av.getFont());\r
labels.drawComponent(pg, idWidth);\r
- pg.setFont(italic);\r
pg.translate(+3,\r
-ypos -\r
(av.getAlignment().getHeight() * av.charHeight));\r
}\r
}\r
\r
+ int getVisibleIdWidth()\r
+ {\r
+ return\r
+ idPanel.getWidth() > 0 ? idPanel.getWidth() :\r
+ calculateIdWidth().width + 4;\r
+ }\r
+\r
void makeAlignmentImage(int type, File file)\r
{\r
+ int maxwidth = av.alignment.getWidth();\r
+ if (av.hasHiddenColumns)\r
+ maxwidth = av.getColumnSelection().findColumnPosition(maxwidth);\r
+\r
int height = ( (av.alignment.getHeight() + 1) * av.charHeight) + 30;\r
- int width = idPanel.getWidth() + (av.alignment.getWidth() * av.charWidth);\r
- if (idPanel.getWidth() == 0)\r
- {\r
- width += calculateIdWidth().getWidth() + 4;\r
- }\r
+ int width = getVisibleIdWidth() + (maxwidth * av.charWidth);\r
\r
if (av.getWrapAlignment())\r
{\r
if (System.getProperty("java.awt.headless") != null\r
&& System.getProperty("java.awt.headless").equals("true"))\r
{\r
- width = alignFrame.getWidth() - 22;\r
+ width = alignFrame.getWidth()\r
+ - vscroll.getPreferredSize().width\r
+ - alignFrame.getInsets().left\r
+ - alignFrame.getInsets().right;\r
}\r
else\r
-\r
- width = seqPanel.getWidth() + idPanel.getWidth();\r
+ width = seqPanel.getWidth() + getVisibleIdWidth();\r
\r
}\r
else if (av.getShowAnnotation())\r
height += annotationPanel.adjustPanelHeight() + 3;\r
}\r
\r
+ try\r
+ {\r
+\r
jalview.util.ImageMaker im;\r
if(type==jalview.util.ImageMaker.PNG)\r
im = new jalview.util.ImageMaker(this,\r
"Create EPS file from alignment",\r
width, height, file, alignFrame.getTitle() );\r
\r
- try\r
- {\r
if (av.getWrapAlignment())\r
{\r
if(im.getGraphics()!=null)\r
{\r
///////ONLY WORKS WITH NONE WRAPPED ALIGNMENTS\r
//////////////////////////////////////////////\r
- int idWidth = calculateIdWidth().width + 4;\r
+ int idWidth = getVisibleIdWidth();\r
FontMetrics fm = getFontMetrics(av.getFont());\r
int scaleHeight = av.charHeight + fm.getDescent();\r
\r
{\r
int seqPanelWidth = seqPanel.seqCanvas.getWidth();\r
\r
- //If headless, seqPanel will have 0 width\r
if (System.getProperty("java.awt.headless") != null\r
- && System.getProperty("java.awt.headless").equals("true"))\r
+ && System.getProperty("java.awt.headless").equals("true"))\r
{\r
- int idWidth = calculateIdWidth().width + 4;\r
- seqPanelWidth = alignFrame.getWidth() - idWidth;\r
+ seqPanelWidth = alignFrame.getWidth()\r
+ - getVisibleIdWidth()\r
+ - vscroll.getPreferredSize().width\r
+ - alignFrame.getInsets().left\r
+ - alignFrame.getInsets().right;\r
}\r
\r
int chunkWidth = seqPanel.seqCanvas.getWrappedCanvasWidth(\r
+ hgap\r
+ annotationHeight;\r
\r
- int height = ( (av.alignment.getWidth() / chunkWidth) + 1) * cHeight;\r
+ int maxwidth = av.alignment.getWidth();\r
+ if (av.hasHiddenColumns)\r
+ maxwidth = av.getColumnSelection().findColumnPosition(maxwidth) - 1;\r
+\r
+\r
+ int height = ( (maxwidth / chunkWidth) + 1) * cHeight;\r
\r
return height;\r
}\r