// Public Members and State Variables /////////////////////////////////////////////////////////
- /** this is the box on this surface which the mouse was inside at the time that the currently-executing event was enqueued */
- public Box boxContainingMouse = null;
-
/** false if the surface has never been rendered; used to determine if the surface should be repositioned to be centered on the screen */
public boolean centerSurfaceOnRender = true;
else if (button == 3) {
final Box who = root.whoIs(mousex, mousey);
MessageQueue.add(new Message() { public void perform() {
- Surface.this.boxContainingMouse = who;
Platform.clipboardReadEnabled = true;
- root.put("Press3", null, Boolean.TRUE);
+ root.put("Press3", Boolean.TRUE);
Platform.clipboardReadEnabled = false;
}});
}
Box b = (Box)keywatchers.elementAt(i);
for(Box cur = b; cur != null; cur = cur.getParent())
if (cur.invisible) continue outer;
- b.put("KeyPressed", null, key);
+ b.put("KeyPressed", key);
}
Platform.clipboardReadEnabled = false;
}
Box b = (Box)keywatchers.elementAt(i);
for(Box cur = b; cur != null; cur = cur.getParent())
if (cur.invisible) continue outer;
- b.put("KeyReleased", null, key);
+ b.put("KeyReleased", key);
}
}});
}
// Root gets motion events outside itself (if trapped, of course)
if (root.is_trapped("Move") && !root.inside(oldmousex, oldmousey) && !root.inside(mousex, mousey) && (button1 || button2 || button3))
- root.put("Move", null, Boolean.TRUE);
+ root.put("Move", Boolean.TRUE);
root.Move(oldmousex, oldmousey, mousex, mousey);
if (!cursor.equals(oldcursor)) syncCursor();
protected final void PosChange(int x, int y) {
root.set(Box.abs, 0, x);
root.set(Box.abs, 1, y);
- new SimpleMessage("PosChange", Boolean.TRUE, null);
+ new SimpleMessage("PosChange", Boolean.TRUE, root);
}
- protected final void Close() { new SimpleMessage("Close", Boolean.TRUE, null); }
- protected final void Minimized(boolean b) { minimized = b; new SimpleMessage("Minimized", b ? Boolean.TRUE : Boolean.FALSE, null); }
- protected final void Maximized(boolean b) { maximized = b; new SimpleMessage("Maximized", b ? Boolean.TRUE : Boolean.FALSE, null); }
- protected final void Focused(boolean b) { new SimpleMessage("Focused", b ? Boolean.TRUE : Boolean.FALSE, null); }
+ protected final void Close() { new SimpleMessage("Close", Boolean.TRUE, root); }
+ protected final void Minimized(boolean b) { minimized = b; new SimpleMessage("Minimized", b ? Boolean.TRUE : Boolean.FALSE, root); }
+ protected final void Maximized(boolean b) { maximized = b; new SimpleMessage("Maximized", b ? Boolean.TRUE : Boolean.FALSE, root); }
+ protected final void Focused(boolean b) { new SimpleMessage("Focused", b ? Boolean.TRUE : Boolean.FALSE, root); }
public static void Refresh() { MessageQueue.refresh(); }
// the following value is split into two int's to work around GCJ bug java/6393
_dispose();
// quit when all windows are closed
- if (allSurfaces.size() == 0 && quitIfAllSurfacesGone) {
+ if (allSurfaces.size() == 0 && quitIfAllSurfacesGone && Main.doneInitializing) {
if (Log.on) {
if (refreshableSurfaceWasCreated) Log.log(this, "exiting because last remaining surface was disposed");
else Log.log(this, "exiting because no surface was ever created");
scarPicture.getWidth(), scarPicture.getHeight());
// sort of ugly; we can't use set() here because it will cause an infinite mutual recursion
- root._size_0 = (short)width;
- root._size_1 = (short)height;
+ root._size_0 = (int)width;
+ root._size_1 = (int)height;
root.mark_for_prerender();
- root.put("SizeChange", null, Boolean.TRUE);
+ root.put("SizeChange", Boolean.TRUE);
}
while (root.needs_prerender || abort) {
MessageQueue.add(this);
}
- public void perform() {
- Surface.this.boxContainingMouse = this.boxContainingMouse;
- root.put(name, root, value);
- }
-
- public String toString() {
- return "SimpleMessage [name=" + name + ", value=" + value + "]";
- }
+ public void perform() { boxContainingMouse.put(name, value); }
+ public String toString() { return "SimpleMessage [name=" + name + ", value=" + value + "]"; }
}