6849805: Nimbus L&F: NimbusLookAndFeel.getDerivedColor() not always returns color2 for 1.0 midPoint
Different rounding mode used for float->int conversion Reviewed-by: malenkov
This commit is contained in:
parent
99370fd871
commit
f17d1e509e
@ -31,7 +31,6 @@ import javax.swing.*;
|
|||||||
import javax.swing.plaf.UIResource;
|
import javax.swing.plaf.UIResource;
|
||||||
import javax.swing.Painter;
|
import javax.swing.Painter;
|
||||||
import java.awt.print.PrinterGraphics;
|
import java.awt.print.PrinterGraphics;
|
||||||
import static javax.swing.plaf.nimbus.NimbusLookAndFeel.deriveARGB;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convenient base class for defining Painter instances for rendering a
|
* Convenient base class for defining Painter instances for rendering a
|
||||||
@ -347,7 +346,7 @@ public abstract class AbstractRegionPainter implements Painter<JComponent> {
|
|||||||
*/
|
*/
|
||||||
protected final Color decodeColor(Color color1, Color color2,
|
protected final Color decodeColor(Color color1, Color color2,
|
||||||
float midPoint) {
|
float midPoint) {
|
||||||
return new Color(deriveARGB(color1, color2, midPoint));
|
return new Color(NimbusLookAndFeel.deriveARGB(color1, color2, midPoint));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -436,15 +436,13 @@ public class NimbusLookAndFeel extends SynthLookAndFeel {
|
|||||||
*/
|
*/
|
||||||
static int deriveARGB(Color color1, Color color2, float midPoint) {
|
static int deriveARGB(Color color1, Color color2, float midPoint) {
|
||||||
int r = color1.getRed() +
|
int r = color1.getRed() +
|
||||||
(int) ((color2.getRed() - color1.getRed()) * midPoint + 0.5f);
|
Math.round((color2.getRed() - color1.getRed()) * midPoint);
|
||||||
int g = color1.getGreen() +
|
int g = color1.getGreen() +
|
||||||
(int) ((color2.getGreen() - color1.getGreen()) * midPoint +
|
Math.round((color2.getGreen() - color1.getGreen()) * midPoint);
|
||||||
0.5f);
|
|
||||||
int b = color1.getBlue() +
|
int b = color1.getBlue() +
|
||||||
(int) ((color2.getBlue() - color1.getBlue()) * midPoint + 0.5f);
|
Math.round((color2.getBlue() - color1.getBlue()) * midPoint);
|
||||||
int a = color1.getAlpha() +
|
int a = color1.getAlpha() +
|
||||||
(int) ((color2.getAlpha() - color1.getAlpha()) * midPoint +
|
Math.round((color2.getAlpha() - color1.getAlpha()) * midPoint);
|
||||||
0.5f);
|
|
||||||
return ((a & 0xFF) << 24) |
|
return ((a & 0xFF) << 24) |
|
||||||
((r & 0xFF) << 16) |
|
((r & 0xFF) << 16) |
|
||||||
((g & 0xFF) << 8) |
|
((g & 0xFF) << 8) |
|
||||||
|
73
jdk/test/javax/swing/plaf/nimbus/Test6849805.java
Normal file
73
jdk/test/javax/swing/plaf/nimbus/Test6849805.java
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* @test
|
||||||
|
@bug 6849805
|
||||||
|
@summary Tests NimbusLookAndFeel.deriveColor()
|
||||||
|
@author Peter Zhelezniakov
|
||||||
|
@run main Test6849805
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.awt.Color;
|
||||||
|
|
||||||
|
|
||||||
|
public class Test6849805 {
|
||||||
|
|
||||||
|
static boolean pass = true;
|
||||||
|
|
||||||
|
static class Minimbus extends javax.swing.plaf.nimbus.NimbusLookAndFeel {
|
||||||
|
|
||||||
|
public void test(Color c1, Color c2, float f) {
|
||||||
|
Color r = getDerivedColor(c1, c2, f);
|
||||||
|
Color test = (f > 0 ? c2 : c1);
|
||||||
|
System.out.printf("Got %s, need %s ", r, test);
|
||||||
|
|
||||||
|
if (r.getRGB() == test.getRGB() &&
|
||||||
|
r.getAlpha() == test.getAlpha()) {
|
||||||
|
|
||||||
|
System.out.println("Ok");
|
||||||
|
} else {
|
||||||
|
System.out.println("FAIL");
|
||||||
|
pass = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Minimbus laf = new Minimbus();
|
||||||
|
laf.test(Color.WHITE, Color.BLACK, 0f);
|
||||||
|
laf.test(Color.WHITE, Color.BLACK, 1f);
|
||||||
|
laf.test(Color.BLACK, Color.WHITE, 0f);
|
||||||
|
laf.test(Color.BLACK, Color.WHITE, 1f);
|
||||||
|
laf.test(Color.RED, Color.GREEN, 0f);
|
||||||
|
laf.test(Color.RED, Color.GREEN, 1f);
|
||||||
|
laf.test(new Color(127, 127, 127), new Color(51, 151, 212), 0f);
|
||||||
|
laf.test(new Color(127, 127, 127), new Color(51, 151, 212), 1f);
|
||||||
|
laf.test(new Color(221, 63, 189), new Color(112, 200, 89), 0f);
|
||||||
|
laf.test(new Color(221, 63, 189), new Color(112, 200, 89), 1f);
|
||||||
|
|
||||||
|
if (! pass) {
|
||||||
|
throw new RuntimeException("Some testcases failed, see above");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user