* @param horizontal
* repaint with horizontal shift in alignment
*/
- public void fastPaint(int horizontal)
+ public void fastPaint(int horizontal, boolean isresize)
{
if ((horizontal == 0) || gg == null
|| av.getAlignment().getAlignmentAnnotation() == null
repaint();
return;
}
- long stime = System.currentTimeMillis();
- gg.copyArea(0, 0, imgWidth, getHeight(),
- -horizontal * av.getCharWidth(), 0);
- long mtime = System.currentTimeMillis();
+
int sr = av.getRanges().getStartRes();
int er = av.getRanges().getEndRes() + 1;
int transX = 0;
+ long stime;
+ long mtime;
- if (horizontal > 0) // scrollbar pulled right, image to the left
+ if (isresize)
{
- transX = (er - sr - horizontal) * av.getCharWidth();
- sr = er - horizontal;
+ imgWidth = (av.getRanges().getEndRes() - av.getRanges().getStartRes()
+ + 1) * av.getCharWidth();
+
+ BufferedImage newimage = new BufferedImage(imgWidth,
+ ap.getAnnotationPanel().getHeight(),
+ BufferedImage.TYPE_INT_ARGB);
+
+ gg = (Graphics2D) newimage.getGraphics();
+ gg.setFont(av.getFont());
+ gg.drawImage(image, null, 0, 0);
+ image = newimage;
+
+ transX = (er - horizontal - sr) * av.getCharWidth();
+ sr = er - horizontal - sr;
}
- else if (horizontal < 0)
+ else
{
- er = sr - horizontal;
+ stime = System.currentTimeMillis();
+ gg.copyArea(0, 0, imgWidth, getHeight(),
+ -horizontal * av.getCharWidth(), 0);
+ mtime = System.currentTimeMillis();
+
+ if (horizontal > 0) // scrollbar pulled right, image to the left
+ {
+ transX = (er - sr - horizontal) * av.getCharWidth();
+ sr = er - horizontal;
+ }
+ else if (horizontal < 0)
+ {
+ er = sr - horizontal;
+ }
}
gg.translate(transX, 0);
// Respond to viewport range changes (e.g. alignment panel was scrolled)
if (evt.getPropertyName().equals("startres"))
{
- fastPaint((int) evt.getNewValue() - (int) evt.getOldValue());
+ fastPaint((int) evt.getNewValue() - (int) evt.getOldValue(), false);
}
else if (evt.getPropertyName().equals("endres"))
{
// resize
+ fastPaint((int) evt.getNewValue() - (int) evt.getOldValue(), true);
}
}
}
* @param vertical
* shift up or down in repaint
*/
- public void fastPaint(int horizontal, int vertical)
+ public void fastPaint(int horizontal, int vertical, boolean isresize)
{
if (fastpainting || gg == null)
{
fastpainting = true;
fastPaint = true;
updateViewport();
- gg.copyArea(horizontal * charWidth, vertical * charHeight, imgWidth,
- imgHeight, -horizontal * charWidth, -vertical * charHeight);
ViewportRanges ranges = av.getRanges();
int sr = ranges.getStartRes();
int transX = 0;
int transY = 0;
- if (horizontal > 0) // scrollbar pulled right, image to the left
+ if (isresize)
{
- transX = (er - sr - horizontal) * charWidth;
- sr = er - horizontal;
- }
- else if (horizontal < 0)
- {
- er = sr - horizontal;
+ imgWidth = getWidth();
+ imgHeight = getHeight();
+
+ imgWidth -= (imgWidth % charWidth);
+ imgHeight -= (imgHeight % charHeight);
+
+ BufferedImage newimg = new BufferedImage(imgWidth, imgHeight,
+ BufferedImage.TYPE_INT_ARGB);
+
+ gg = (Graphics2D) newimg.getGraphics();
+ gg.setFont(av.getFont());
+ gg.drawImage(img, null, 0, 0);
+ img = newimg;
+
+ transX = (er - horizontal - sr) * charWidth;
+ sr = er - horizontal - sr;
}
- else if (vertical > 0) // scroll down
+ else
{
- ss = es - vertical;
+ gg.copyArea(horizontal * charWidth, vertical * charHeight, imgWidth,
+ imgHeight, -horizontal * charWidth, -vertical * charHeight);
- if (ss < ranges.getStartSeq())
- { // ie scrolling too fast, more than a page at a time
- ss = ranges.getStartSeq();
+ if (horizontal > 0) // scrollbar pulled right, image to the left
+ {
+ transX = (er - sr - horizontal) * charWidth;
+ sr = er - horizontal;
}
- else
+ else if (horizontal < 0)
{
- transY = imgHeight - ((vertical + 1) * charHeight);
+ er = sr - horizontal;
}
- }
- else if (vertical < 0)
- {
- es = ss - vertical;
+ else if (vertical > 0) // scroll down
+ {
+ ss = es - vertical;
- if (es > ranges.getEndSeq())
+ if (ss < ranges.getStartSeq())
+ { // ie scrolling too fast, more than a page at a time
+ ss = ranges.getStartSeq();
+ }
+ else
+ {
+ transY = imgHeight - ((vertical + 1) * charHeight);
+ }
+ }
+ else if (vertical < 0)
{
- es = ranges.getEndSeq();
+ es = ss - vertical;
+
+ if (es > ranges.getEndSeq())
+ {
+ es = ranges.getEndSeq();
+ }
}
}
{
scrollX = vpRanges.getStartRes() - vpRanges.getEndRes();
}
- fastPaint(scrollX, 0);
+ fastPaint(scrollX, 0, false);
}
else if (evt.getPropertyName().equals("endres"))
{
// resize - only endres changes
+ int scrollX = (int) evt.getNewValue() - (int) evt.getOldValue();
+ fastPaint(scrollX, 0, true);
}
else if (evt.getPropertyName().equals("startseq"))
{
// scroll
- fastPaint(0, (int) evt.getNewValue() - (int) evt.getOldValue());
+ fastPaint(0, (int) evt.getNewValue() - (int) evt.getOldValue(), false);
}
else if (evt.getPropertyName().equals("endseq"))
{