[icedtea-web] RFC: Patch to double-buffer applets
Deepak Bhole
dbhole at redhat.com
Wed Nov 3 07:52:33 PDT 2010
* Deepak Bhole <dbhole at redhat.com> [2010-11-03 10:52]:
> * Omair Majid <omajid at redhat.com> [2010-11-03 09:32]:
> > Hi Deepak,
> >
> > On 11/02/2010 05:37 PM, Deepak Bhole wrote:
> > >* Deepak Bhole<dbhole at redhat.com> [2010-11-02 17:31]:
> > >>Hi,
> > >>
> > >>IcedTea plugin currently does not double-buffer the applet panel. As a
> > >>result, some applets may flicker depending on the machine.
> > >>
> > >>Attached patch buffers the frame offscreen and then draws it, thereby
> > >>addressing the issue.
> > >>
> >
> > Is there a specific test case that this fixes? The only flickering
> > applet that I know of is at
> > http://download.oracle.com/javase/1.4.2/docs/guide/misc/applet.html,
> > and I dont see any change in that applet with the patch applied.
> >
>
> Nope, no specific applet. I came across the problem when I was working
> on a splash screen for the plugin -- it flickers significantly without
> the patch.
>
> Applets which do something similar would flicker as well (the splash
> screen is embedded into the same frame that the plugin would be).
>
s/plugin would be/applet would be
> Deepak
>
> > >>ChangeLog:
> > >>2010-11-02 Deepak Bhole<dbhole at redhat.com>
> > >>
> > >> * plugin/icedteanp/java/sun/applet/PluginAppletViewer.java (update):
> > >> Override method and implement double-buffering.
> > >>
> > >>Cheers,
> > >>Deepak
> > >
> > >
> > >Doh! There shouldn't be a println in there. New patch attached. I also
> > >fixed the variable names for the image and its graphics.
> > >
> > >
> > >>diff -r 6c2527d42900 ChangeLog
> > >>--- a/ChangeLog Mon Nov 01 11:44:15 2010 -0400
> > >>+++ b/ChangeLog Tue Nov 02 17:29:03 2010 -0700
> > >>@@ -1,3 +1,8 @@
> > >>+2010-11-02 Deepak Bhole<dbhole at redhat.com>
> > >>+
> > >>+ * plugin/icedteanp/java/sun/applet/PluginAppletViewer.java (update):
> > >>+ Override method and implement double-buffering.
> > >>+
> > >> 2010-11-01 Omair Majid<omajid at redhat.com>
> > >>
> > >> * Makefile.am (clean-IcedTeaPlugin): Only delete launcher directory if it
> > >>diff -r 6c2527d42900 NEWS
> > >>--- a/NEWS Mon Nov 01 11:44:15 2010 -0400
> > >>+++ b/NEWS Tue Nov 02 17:29:03 2010 -0700
> > >>@@ -12,3 +12,4 @@
> > >>
> > >> * Initial release of IcedTea-Web
> > >> * PR542: Plugin fails with NPE on http://www.openprocessing.org/visuals/iframe.php?visualID=2615
> > >>+* Applets are now double-buffered to eliminate flicker in ones that do heavy drawing
> > >>diff -r 6c2527d42900 plugin/icedteanp/java/sun/applet/PluginAppletViewer.java
> > >>--- a/plugin/icedteanp/java/sun/applet/PluginAppletViewer.java Mon Nov 01 11:44:15 2010 -0400
> > >>+++ b/plugin/icedteanp/java/sun/applet/PluginAppletViewer.java Tue Nov 02 17:29:03 2010 -0700
> > >>@@ -359,6 +366,9 @@
> > >>
> > >> private static Long requestIdentityCounter = 0L;
> > >>
> > >>+ private Image bufferedPanelImage;
> > >>+ private Graphics bufferedImageGraphics;
> > >>+
> > >> /**
> > >> * Null constructor to allow instantiation via newInstance()
> > >> */
> > >>@@ -2163,4 +2178,24 @@
> > >> }
> > >> }
> > >> }
> > >>+
> > >>+ /**
> > >>+ * {@inheritDoc}
> > >>+ */
> > >>+ public void update(Graphics g) {
> > >>+
> > >>+ System.err.println("Buffering and drawing");
> > >>+
> > >>+ // If the image or the graphics don't exist, create new ones
> > >>+ if (bufferedPanelImage == null || bufferedImageGraphics == null) {
> > >>+ bufferedPanelImage = createImage(getWidth(), getHeight());
> > >>+ bufferedImageGraphics = bufferedPanelImage.getGraphics ();
> > >>+ }
> > >>+
> > >>+ // Paint off-screen
> > >>+ paint(bufferedImageGraphics);
> >
> > The overridden method is update, but paint is called here instead.
> > Is there a reason for that? As far as I know, the semantics of
> > update() are slightly different from paint() - update() clears the
> > background and then calls paint(). Perhaps super.update() might be
> > more appropriate?
> >
> > >>+
> > >>+ // Draw the painted image
> > >>+ g.drawImage(bufferedPanelImage, 0, 0, this);
> > >>+ }
> > >> }
> > >
> >
> > Thanks,
> > Omair
More information about the distro-pkg-dev
mailing list