X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FIdCanvas.java;h=4f5288d924d0b16068f09d7bc26c4ce9ac8f98be;hb=339c2de5fce77a1e1518df6df0c2d894352d6648;hp=11d99d84d2ec8737afd713104e9015d78b83bf82;hpb=07c25ef5f4631d5d385191bb01630f02fd1e06bb;p=jalview.git diff --git a/src/jalview/gui/IdCanvas.java b/src/jalview/gui/IdCanvas.java index 11d99d8..4f5288d 100755 --- a/src/jalview/gui/IdCanvas.java +++ b/src/jalview/gui/IdCanvas.java @@ -2,7 +2,7 @@ package jalview.gui; import java.awt.*; import java.awt.Graphics2D.*; - +import java.awt.image.*; import javax.swing.*; import jalview.datamodel.*; import jalview.analysis.*; @@ -10,11 +10,16 @@ public class IdCanvas extends JPanel { protected AlignViewport av; - public boolean paintFlag = false; protected boolean showScores = true; protected int maxIdLength = -1; protected String maxIdStr = null; + BufferedImage image; + Graphics2D gg; + int imgHeight=0; + boolean fastPaint = false; + + java.util.Vector searchResults; public IdCanvas(AlignViewport av) { @@ -23,53 +28,121 @@ public class IdCanvas extends JPanel PaintRefresher.Register(this); } - public void drawIdString(Graphics gg,SequenceI ds,int i, int starty, int ypos) { + public void drawIdString(Graphics2D gg,SequenceI s,int i, int starty, int ypos) { int charHeight = av.getCharHeight(); - if (av.getSelection().contains(ds)) { + if(searchResults!=null && searchResults.contains(s)) + { + gg.setColor(Color.black); + gg.fillRect(0,AlignmentUtil.getPixelHeight(starty,i,charHeight)+ ypos,getWidth(),charHeight); + gg.setColor(Color.white); + } + else if (av.getSelectionGroup()!=null && av.getSelectionGroup().sequences.contains(s)) { gg.setColor(Color.lightGray); gg.fillRect(0,AlignmentUtil.getPixelHeight(starty,i,charHeight)+ ypos,getWidth(),charHeight); gg.setColor(Color.white); } else { - gg.setColor(ds.getColor()); + gg.setColor(s.getColor()); gg.fillRect(0,AlignmentUtil.getPixelHeight(starty,i,charHeight)+ ypos,getWidth(),charHeight); gg.setColor(Color.black); } - String string = ds.getName() + "/" + ds.getStart() + "-" + ds.getEnd(); + String string = s.getName(); + if(av.getShowFullId()) + string = s.getDisplayId(); gg.drawString(string,0,AlignmentUtil.getPixelHeight(starty,i,charHeight) + ypos + charHeight- (charHeight/5)); } - public void paintComponent(Graphics gg) { - AlignmentI da = av.getAlignment(); - int charHeight = av.getCharHeight(); - gg.setFont(av.getFont()); + public void fastPaint(int vertical) + { + if(gg==null) + { repaint(); return;} + + gg.copyArea( 0,0, getWidth(), imgHeight, 0, -vertical*av.charHeight ); + + int ss=av.startSeq, es=av.endSeq, transY = 0; + if (vertical > 0) // scroll down + { + ss = es - vertical; + if(ss av.endSeq) + es = av.endSeq; + } + + + + gg.translate(0, transY); + + drawIds(ss, es); + + gg.translate( 0, -transY ); + + + fastPaint = true; + repaint(); + } + + public void paintComponent(Graphics g) + { + g.setColor(Color.white); + g.fillRect(0, 0, getWidth(), getHeight()); + + if (fastPaint) + { + fastPaint = false; + g.drawImage(image, 0, 0, this); + return; + } + + imgHeight = getHeight(); + imgHeight -= imgHeight % av.charHeight; + if (imgHeight<1) + return; + + image = new BufferedImage(getWidth(), imgHeight, BufferedImage.TYPE_INT_RGB); + gg = (Graphics2D) image.getGraphics(); //Fill in the background gg.setColor(Color.white); - gg.fillRect(0,0,getWidth(),getHeight()); + gg.fillRect(0, 0, getWidth(), imgHeight); + gg.setRenderingHint(RenderingHints.KEY_ANTIALIASING, + RenderingHints.VALUE_ANTIALIAS_ON); + Font italic = new Font(av.getFont().getName(), Font.ITALIC, + av.getFont().getSize()); + gg.setFont(italic); + + drawIds( av.getStartSeq(), av.endSeq); + + g.drawImage(image, 0, 0, this); + } + void drawIds(int starty, int endy) + { Color currentColor = Color.white; Color currentTextColor = Color.black; - //Which ids are we printing - int starty = av.getStartSeq(); - int endy = da.getHeight(); - if (av.getWrapAlignment()) { + + int rowSize = av.getEndRes() - av.getStartRes(); // Draw the rest of the panels - int chunkHeight = (da.getHeight() + 2)*av.charHeight; - int row = av.getStartRes() / av.chunkWidth ; - for(int ypos=2*av.charHeight; - ypos <= getHeight() && row*av.chunkWidth idWidth) - idWidth = fm.stringWidth(str); - i++; - } - - return new Dimension(idWidth + 10,getHeight()); - } - - public Dimension getPreferredSize() - { - return getLabelWidth(); - } - - + searchResults = found; + repaint(); + } }