[OpenJDK 2D-Dev] X11 uniform scaled wide lines and dashed lines; STROKE_CONTROL in Pisces
    Jim Graham 
    james.graham at oracle.com
       
    Mon Nov  8 19:22:18 UTC 2010
    
    
  
Also, some things to note in the new version - things I had to "fix" not 
related to performance.
In endRendering the pixel bounds of the edges needed to be computed and 
passed along to the next stage.  Unfortunately the code in endRendering 
computed the sub-pixel bounds and then simply shifted them to get the 
pixel addresses of those bounds.  For the bottom and right edges, this 
means that a ceiling operation was performed on the sub-pixel data, but 
a floor operation was performed on the conversion to pixel addresses. 
This means that the bottom few sub-pixel rows could have been sliced off 
in these calculations.  I restructured the calculations there to make 
sure that it produced the pixel bounds of all of the subpixel rows. 
Also, I use a ceil() operation on the sub-pixel values because we really 
want to know what is the next sub-pixel sample row/column that we will 
cross and then get the (pixel) bounds of those sample row/columns.
I think there may have been a couple of other places where the "which 
pixel are we on" code got sloppy along similar lines to the endRendering 
case.
The conditions for sending the alphas for the last row changed a little. 
  I need to have every row visited in my AlphaConsumer because it is 
cleaning out an alpha tile as it incorporates the new alphas.  Thus, I 
needed the logic to call "getAndClear" even if there were no alphas to 
deliver.  I don't think that change would have affected your version 
with the PiscesCache since you can just finalize the cache when the 
alphas are done and clearing the alphaRow[] array is irrelevant at that 
final stage.  The way this works may change as I continue optimizing.
				...jim
On 11/8/2010 6:40 AM, Denis Lila wrote:
> Hi Jim.
>
>> Also, I've gotten another 20% improvement out of the design with a few
>> more tweaks.  (Though I measured the 20% in the stripped down version
>> that I'm prototyping with FX so I'm not sure how much of that 20%
>> would show up through the layers of the 2D code.  Overall, I've about
>> doubled the frame rates of the prototype since your first drop that you
>> checked in to the OpenJDK repository.)
>
> Can I see your new version?
    
    
More information about the 2d-dev
mailing list