/*
* Copyright (c) 2013, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8024343 8042098
* @summary Test verifies that accelerated pipelines
* correctly draws primitives in XOR mode.
* @run main/othervm -Dsun.java2d.xrender=True AcceleratedXORModeTest
*/
import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.GraphicsConfiguration;
import java.awt.GraphicsEnvironment;
import java.awt.image.BufferedImage;
import java.awt.image.VolatileImage;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
public class AcceleratedXORModeTest {
public static void main(String argv[]) {
String fileName = argv.length > 0 ? argv[0] : null;
new AcceleratedXORModeTest(fileName).test();
}
static final Color backColor = Color.red;
static final Color color1 = Color.green;
static final Color color2 = Color.yellow;
static final Color xorColor1 = Color.blue;
static final Color xorColor2 = Color.white;
static final int width = 700, height = 300;
VolatileImage vImg = null;
String fileName;
public AcceleratedXORModeTest(String fileName) {
this.fileName = fileName;
}
void draw(Graphics2D g) {
g.setColor(backColor);
g.fillRect(0, 0, width, height);
g.setXORMode(xorColor1);
drawPattern(g, 100);
g.setXORMode(xorColor2);
drawPattern(g, 400);
g.dispose();
}
void test(BufferedImage bi) {
comparePattern(bi, 150, xorColor1.getRGB());
comparePattern(bi, 450, xorColor2.getRGB());
}
void comparePattern(BufferedImage bi, int startX, int xorColor) {
int[] expectedColors = {
backColor.getRGB() ^ color1.getRGB() ^ xorColor,
backColor.getRGB() ^ color1.getRGB() ^ xorColor ^
color2.getRGB() ^ xorColor,
backColor.getRGB() ^ color2.getRGB() ^ xorColor
};
for (int i = 0; i < 3; i++) {
int x = startX + 100 * i;
int rgb = bi.getRGB(x, 150);
if (rgb != expectedColors[i]) {
String msg = "Colors mismatch: x = " + x +
", got " + new Color(rgb) + ", expected " +
new Color(expectedColors[i]);
System.err.println(msg);
write(bi);
throw new RuntimeException("FAILED: " + msg);
}
}
}
void drawPattern(Graphics2D g, int x) {
g.setColor(color1);
g.fillRect(x, 0, 200, 300);
g.setColor(color2);
g.fillRect(x+100, 0, 200, 300);
}
GraphicsConfiguration getDefaultGC() {
return GraphicsEnvironment.getLocalGraphicsEnvironment().
getDefaultScreenDevice().getDefaultConfiguration();
}
void createVImg() {
if (vImg != null) {
vImg.flush();
vImg = null;
}
vImg = getDefaultGC().createCompatibleVolatileImage(width, height);
}
void write(BufferedImage bi) {
if (fileName != null) {
try {
ImageIO.write(bi, "png", new File(fileName));
} catch (IOException e) {
System.err.println("Can't write image file " + fileName);
}
}
}
void test() {
createVImg();
BufferedImage bi = null;
do {
int valCode = vImg.validate(getDefaultGC());
if (valCode == VolatileImage.IMAGE_INCOMPATIBLE) {
createVImg();
}
Graphics2D g = vImg.createGraphics();
draw(g);
bi = vImg.getSnapshot();
} while (vImg.contentsLost());
if (bi != null) {
test(bi);
write(bi);
}
}
}