- Replaced console outputs by the standard java logging concept and removed obsolete Sysout-Calls.

- No functional changes.
- added missing override tags.
define_list_fix
Markus Uhlig 9 years ago
parent 46891b32c6
commit eaa9858b18
  1. 183
      jme3-desktop/src/main/java/com/jme3/system/awt/AwtPanel.java

@ -51,11 +51,13 @@ import java.nio.IntBuffer;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import java.util.logging.Level;
import java.util.logging.Logger;
public class AwtPanel extends Canvas implements SceneProcessor { public class AwtPanel extends Canvas implements SceneProcessor {
private boolean attachAsMain = false; private boolean attachAsMain = false;
private BufferedImage img; private BufferedImage img;
private FrameBuffer fb; private FrameBuffer fb;
private boolean srgb = false; private boolean srgb = false;
@ -63,148 +65,137 @@ public class AwtPanel extends Canvas implements SceneProcessor {
private IntBuffer intBuf; private IntBuffer intBuf;
private RenderManager rm; private RenderManager rm;
private PaintMode paintMode; private PaintMode paintMode;
private ArrayList<ViewPort> viewPorts = new ArrayList<ViewPort>(); private ArrayList<ViewPort> viewPorts = new ArrayList<ViewPort>();
// Visibility/drawing vars // Visibility/drawing vars
private BufferStrategy strategy; private BufferStrategy strategy;
private AffineTransformOp transformOp; private AffineTransformOp transformOp;
private AtomicBoolean hasNativePeer = new AtomicBoolean(false); private AtomicBoolean hasNativePeer = new AtomicBoolean(false);
private AtomicBoolean showing = new AtomicBoolean(false); private AtomicBoolean showing = new AtomicBoolean(false);
private AtomicBoolean repaintRequest = new AtomicBoolean(false); private AtomicBoolean repaintRequest = new AtomicBoolean(false);
// Reshape vars // Reshape vars
private int newWidth = 1; private int newWidth = 1;
private int newHeight = 1; private int newHeight = 1;
private AtomicBoolean reshapeNeeded = new AtomicBoolean(false); private AtomicBoolean reshapeNeeded = new AtomicBoolean(false);
private final Object lock = new Object(); private final Object lock = new Object();
public AwtPanel(PaintMode paintMode){ public AwtPanel(PaintMode paintMode) {
this(paintMode, false); this(paintMode, false);
} }
public AwtPanel(PaintMode paintMode, boolean srgb){ public AwtPanel(PaintMode paintMode, boolean srgb) {
this.paintMode = paintMode; this.paintMode = paintMode;
this.srgb = srgb; this.srgb = srgb;
if (paintMode == PaintMode.Accelerated){ if (paintMode == PaintMode.Accelerated) {
setIgnoreRepaint(true); setIgnoreRepaint(true);
} }
addComponentListener(new ComponentAdapter(){ addComponentListener(new ComponentAdapter() {
@Override @Override
public void componentResized(ComponentEvent e) { public void componentResized(ComponentEvent e) {
synchronized (lock){ synchronized (lock) {
int newWidth2 = Math.max(getWidth(), 1); int newWidth2 = Math.max(getWidth(), 1);
int newHeight2 = Math.max(getHeight(), 1); int newHeight2 = Math.max(getHeight(), 1);
if (newWidth != newWidth2 || newHeight != newHeight2){ if (newWidth != newWidth2 || newHeight != newHeight2) {
newWidth = newWidth2; newWidth = newWidth2;
newHeight = newHeight2; newHeight = newHeight2;
reshapeNeeded.set(true); reshapeNeeded.set(true);
System.out.println("EDT: componentResized " + newWidth + ", " + newHeight);
} }
} }
} }
}); });
} }
@Override @Override
public void addNotify(){ public void addNotify() {
super.addNotify(); super.addNotify();
synchronized (lock){ synchronized (lock) {
hasNativePeer.set(true); hasNativePeer.set(true);
System.out.println("EDT: addNotify");
} }
requestFocusInWindow(); requestFocusInWindow();
} }
@Override @Override
public void removeNotify(){ public void removeNotify() {
synchronized (lock){ synchronized (lock) {
hasNativePeer.set(false); hasNativePeer.set(false);
System.out.println("EDT: removeNotify");
} }
super.removeNotify(); super.removeNotify();
} }
@Override @Override
public void paint(Graphics g){ public void paint(Graphics g) {
Graphics2D g2d = (Graphics2D) g; Graphics2D g2d = (Graphics2D) g;
synchronized (lock){ synchronized (lock) {
g2d.drawImage(img, transformOp, 0, 0); g2d.drawImage(img, transformOp, 0, 0);
} }
} }
public boolean checkVisibilityState(){ public boolean checkVisibilityState() {
if (!hasNativePeer.get()){ if (!hasNativePeer.get()) {
if (strategy != null){ if (strategy != null) {
// strategy.dispose(); // strategy.dispose();
strategy = null; strategy = null;
System.out.println("OGL: Not visible. Destroy strategy.");
} }
return false; return false;
} }
boolean currentShowing = isShowing(); boolean currentShowing = isShowing();
if (showing.getAndSet(currentShowing) != currentShowing){ showing.set(currentShowing);
if (currentShowing){
System.out.println("OGL: Enter showing state.");
}else{
System.out.println("OGL: Exit showing state.");
}
}
return currentShowing; return currentShowing;
} }
public void repaintInThread(){ public void repaintInThread() {
// Convert screenshot. // Convert screenshot.
byteBuf.clear(); byteBuf.clear();
rm.getRenderer().readFrameBuffer(fb, byteBuf); rm.getRenderer().readFrameBuffer(fb, byteBuf);
synchronized (lock){ synchronized (lock) {
// All operations on img must be synchronized // All operations on img must be synchronized
// as it is accessed from EDT. // as it is accessed from EDT.
Screenshots.convertScreenShot2(intBuf, img); Screenshots.convertScreenShot2(intBuf, img);
repaint(); repaint();
} }
} }
public void drawFrameInThread(){ public void drawFrameInThread() {
// Convert screenshot. // Convert screenshot.
byteBuf.clear(); byteBuf.clear();
rm.getRenderer().readFrameBuffer(fb, byteBuf); rm.getRenderer().readFrameBuffer(fb, byteBuf);
Screenshots.convertScreenShot2(intBuf, img); Screenshots.convertScreenShot2(intBuf, img);
synchronized (lock){ synchronized (lock) {
// All operations on strategy should be synchronized (?) // All operations on strategy should be synchronized (?)
if (strategy == null){ if (strategy == null) {
try { try {
createBufferStrategy(1, createBufferStrategy(1,
new BufferCapabilities( new BufferCapabilities(
new ImageCapabilities(true), new ImageCapabilities(true),
new ImageCapabilities(true), new ImageCapabilities(true),
BufferCapabilities.FlipContents.UNDEFINED) BufferCapabilities.FlipContents.UNDEFINED)
); );
} catch (AWTException ex) { } catch (AWTException ex) {
ex.printStackTrace(); ex.printStackTrace();
} }
strategy = getBufferStrategy(); strategy = getBufferStrategy();
System.out.println("OGL: Visible. Create strategy.");
} }
// Draw screenshot. // Draw screenshot.
do { do {
do { do {
Graphics2D g2d = (Graphics2D) strategy.getDrawGraphics(); Graphics2D g2d = (Graphics2D) strategy.getDrawGraphics();
if (g2d == null){ if (g2d == null) {
System.out.println("OGL: DrawGraphics was null."); Logger.getLogger(AwtPanel.class.getName()).log(Level.WARNING, "OGL: DrawGraphics was null.");
return; return;
} }
g2d.setRenderingHint(RenderingHints.KEY_RENDERING, g2d.setRenderingHint(RenderingHints.KEY_RENDERING,
RenderingHints.VALUE_RENDER_SPEED); RenderingHints.VALUE_RENDER_SPEED);
g2d.drawImage(img, transformOp, 0, 0); g2d.drawImage(img, transformOp, 0, 0);
g2d.dispose(); g2d.dispose();
strategy.show(); strategy.show();
@ -212,27 +203,28 @@ public class AwtPanel extends Canvas implements SceneProcessor {
} while (strategy.contentsLost()); } while (strategy.contentsLost());
} }
} }
public boolean isActiveDrawing(){ public boolean isActiveDrawing() {
return paintMode != PaintMode.OnRequest && showing.get(); return paintMode != PaintMode.OnRequest && showing.get();
} }
public void attachTo(boolean overrideMainFramebuffer, ViewPort ... vps){ public void attachTo(boolean overrideMainFramebuffer, ViewPort... vps) {
if (viewPorts.size() > 0){ if (viewPorts.size() > 0) {
for (ViewPort vp : viewPorts){ for (ViewPort vp : viewPorts) {
vp.setOutputFrameBuffer(null); vp.setOutputFrameBuffer(null);
} }
viewPorts.get(viewPorts.size()-1).removeProcessor(this); viewPorts.get(viewPorts.size() - 1).removeProcessor(this);
} }
viewPorts.addAll(Arrays.asList(vps)); viewPorts.addAll(Arrays.asList(vps));
viewPorts.get(viewPorts.size()-1).addProcessor(this); viewPorts.get(viewPorts.size() - 1).addProcessor(this);
this.attachAsMain = overrideMainFramebuffer; this.attachAsMain = overrideMainFramebuffer;
} }
@Override
public void initialize(RenderManager rm, ViewPort vp) { public void initialize(RenderManager rm, ViewPort vp) {
if (this.rm == null){ if (this.rm == null) {
// First time called in OGL thread // First time called in OGL thread
this.rm = rm; this.rm = rm;
reshapeInThread(1, 1); reshapeInThread(1, 1);
@ -242,59 +234,61 @@ public class AwtPanel extends Canvas implements SceneProcessor {
private void reshapeInThread(int width, int height) { private void reshapeInThread(int width, int height) {
byteBuf = BufferUtils.ensureLargeEnough(byteBuf, width * height * 4); byteBuf = BufferUtils.ensureLargeEnough(byteBuf, width * height * 4);
intBuf = byteBuf.asIntBuffer(); intBuf = byteBuf.asIntBuffer();
if (fb != null) { if (fb != null) {
fb.dispose(); fb.dispose();
fb = null; fb = null;
} }
fb = new FrameBuffer(width, height, 1); fb = new FrameBuffer(width, height, 1);
fb.setDepthBuffer(Format.Depth); fb.setDepthBuffer(Format.Depth);
fb.setColorBuffer(Format.RGB8); fb.setColorBuffer(Format.RGB8);
fb.setSrgb(srgb); fb.setSrgb(srgb);
if (attachAsMain){ if (attachAsMain) {
rm.getRenderer().setMainFrameBufferOverride(fb); rm.getRenderer().setMainFrameBufferOverride(fb);
} }
synchronized (lock){ synchronized (lock) {
img = new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR); img = new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR);
} }
// synchronized (lock){ // synchronized (lock){
// img = (BufferedImage) getGraphicsConfiguration().createCompatibleImage(width, height); // img = (BufferedImage) getGraphicsConfiguration().createCompatibleImage(width, height);
// } // }
AffineTransform tx = AffineTransform.getScaleInstance(1, -1); AffineTransform tx = AffineTransform.getScaleInstance(1, -1);
tx.translate(0, -img.getHeight()); tx.translate(0, -img.getHeight());
transformOp = new AffineTransformOp(tx, AffineTransformOp.TYPE_NEAREST_NEIGHBOR); transformOp = new AffineTransformOp(tx, AffineTransformOp.TYPE_NEAREST_NEIGHBOR);
for (ViewPort vp : viewPorts){ for (ViewPort vp : viewPorts) {
if (!attachAsMain){ if (!attachAsMain) {
vp.setOutputFrameBuffer(fb); vp.setOutputFrameBuffer(fb);
} }
vp.getCamera().resize(width, height, true); vp.getCamera().resize(width, height, true);
// NOTE: Hack alert. This is done ONLY for custom framebuffers. // NOTE: Hack alert. This is done ONLY for custom framebuffers.
// Main framebuffer should use RenderManager.notifyReshape(). // Main framebuffer should use RenderManager.notifyReshape().
for (SceneProcessor sp : vp.getProcessors()){ for (SceneProcessor sp : vp.getProcessors()) {
sp.reshape(vp, width, height); sp.reshape(vp, width, height);
} }
} }
} }
@Override
public boolean isInitialized() { public boolean isInitialized() {
return fb != null; return fb != null;
} }
@Override
public void preFrame(float tpf) { public void preFrame(float tpf) {
} }
@Override
public void postQueue(RenderQueue rq) { public void postQueue(RenderQueue rq) {
} }
@Override @Override
public void invalidate(){ public void invalidate() {
// For "PaintMode.OnDemand" only. // For "PaintMode.OnDemand" only.
repaintRequest.set(true); repaintRequest.set(true);
} }
@ -322,18 +316,21 @@ public class AwtPanel extends Canvas implements SceneProcessor {
} }
} }
} }
@Override
public void postFrame(FrameBuffer out) { public void postFrame(FrameBuffer out) {
if (!attachAsMain && out != fb){ if (!attachAsMain && out != fb) {
throw new IllegalStateException("Why did you change the output framebuffer?"); throw new IllegalStateException("Why did you change the output framebuffer?");
} }
// onFrameEnd(); // onFrameEnd();
} }
@Override
public void reshape(ViewPort vp, int w, int h) { public void reshape(ViewPort vp, int w, int h) {
} }
@Override
public void cleanup() { public void cleanup() {
} }
} }

Loading…
Cancel
Save