summaryrefslogtreecommitdiff
path: root/libjava/java/awt/Container.java
diff options
context:
space:
mode:
authorRolf W. Rasmussen <rolfwr@ii.uib.no>2000-08-16 20:03:48 +0200
committerRolf Rasmussen <rolfwr@gcc.gnu.org>2000-08-16 18:03:48 +0000
commit777e6d799a6db0549568c5dd668a226194486c02 (patch)
treede04aa08682f889d624d5649474e04a30121641f /libjava/java/awt/Container.java
parentcfedbb1f824b2f2d9f48f2ed805808b00fa671b0 (diff)
downloadgcc-777e6d799a6db0549568c5dd668a226194486c02.tar.gz
ComponentDataBlitOp.java: New file.
* gnu/gcj/awt/ComponentDataBlitOp.java: New file. * gnu/gcj/awt/GLightweightPeer.java: New file. * java/awt/BorderLayout.java: Implemented all methods. * java/awt/Button.java (actionListener, actionCommand): Renamed and modifier change. (addNotify): Call super. (dispatchEventImpl): New method. (getListeners): New method. (label): Made package-private, not private. * java/awt/Canvas.java: Implemented class body. * java/awt/Color.java (brighter): New method. (darker): New method. (hashCode): New method. * java/awt/Component.java (visible, enabled, eventMask): Set defaults. (getGraphicsConfiguration): Delegate to getGraphicsConfigurationImpl(). (getGraphicsConfigurationImpl): New method. (getToolkit): Only return value from peer if not null. (isDisplayable): Check with parent. (isShowing): No parent implies not showing. (getForeground): Check parent property if local is null. (getBackground): Likewise. (getFont): Likewise. (setForeground): Inform peer. (setBackground): Likewise (setLocale): Invalidate component. (getColorModel): Implemented. (setLocation): Invalidate, or ignore if no change. (setSize): Invalidate, or ignore if no change. (setBounds): Invalidate, or ignore if no change. (isOpaque): By default, heavyweight implies opaque. (isLightweight): Implemented. (getMaximumSize): Implemented. (doLayout): Implemented, NOP. (validate): Implemented, NOP. (invalidate): Only propagate to parent if parent was valid. (getGraphics): Implemented. (getFontMetrics): Implemented. (update): Implemented. (paintAll): Implemented. (repaint): Implemented all repaint methods. (print): Implemented. (printAll): Implemented. (createImage): Implemented. (dispatchEvent): Give the peer a chance to handle the event. (dispatchEventImpl): Dispatch paint events. (enableEvents): Lightweights enable events on parent component. (coalesceEvents): Coalesce paint events, and select event type using a switch. (coalescePaintEvents): New method. (processEvent): Fix unfortunate ordering of statements, and call correct method for MOUSE_CLICKED. (processPaintEvent): New method. (addNotify): Allow container to notify children before event mask is set in peer. (addNotifyContainerChildren): New method. (removeNotify): Visibility should not change on removeNotify. (paramString): Implemented. (list): Implemented two of the list methods. * Container (myInsets): Removed, insets are managed by peer. (getInsets): Query peer. (addImpl): Fix reparenting, enable events for lightweights, initialize component array. (validate): Call doLayout in validateTree() instead. (validateTree): Do nothing if already valid. Call beginValidate(), endValidate() on peer. Call validateTree() instead of validate() for children that are containers. Mark valid after validation of children. (setFont): Partial implementation. (paint): Implemented. (visitChildren): New method. (visitChild): New method. (update): Implemented. (print): Implemented. (paintComponents): Implemented. (printComponents): Consider translation and clipping. (getComponentAt): Ignore invisible children. Return this if no child match. (addNotify): Call super. (addNotifyContainerChildren): New method. (paramString): Implemented. (list): Implemented. * java/awt/EventQueue (invokeAndWait): Get system event queue the right way. (invokeLater): Likewise. (isDispatchThread): Likewise. * java/awt/FontMetrics (getLeading): Formula change. (getDescent): Consider leading also. (getMaxAscent): Default to getAscent(). (getMaxDescent): Default to getDescent. (getMaxAdvance): Return value signifying unknown. (charWidth): Both methods implemented. (charsWidth): Implemented. (bytesWidth): Implemented. (getWidths): Implemented. * java/awt/Frame.java (NORMAL, ICONIFIED, iconImage, isResizable, state): New fields. (Frame): Rearragend constuctor chaining to disallow null being passed as a graphics configuration. (getTitle): Return empty string if null. (dispose): Removed. (getIconImage): New method. (setIconImage): New method. (finalize): New method. (setMenuBar): Notify peer. (isResizable): New method. (setResizable): New method. (getState): New method. (getFont): Removed. (remove): Implemented. (removeNotify): New method. (getFrames): New method. * java/awt/Graphics.java: Implemented body of class. * java/awt/Graphics2D.java: New file. * java/awt/GraphicsConfiguration.java: Enabled part of the API. * java/awt/Image.java: Implemented body of class. * java/awt/Panel.java (Panel): Call correct super constructor. (addNotify): Implemented. * java/awt/Rectangle.java (isEmpty): Fixed reversed logic. * java/awt/RenderingHints.java: New file. * java/awt/Toolkit.java (createComponent): Implemented. (getSystemEventQueue): Delegate to getSystemEventQueueImpl(). * java/awt/Window.java (Window): Two new constructors. Reordered constructor chaining. (getGraphicsConfigurationImpl): New method. (finalize): Call super. (addNotify): Call super. (pack): Do layout stuff. (show): Ensure that peer exists and that component is valid. (dispose): Dispose owned children. (getOwner): Simplify code, casting null pointers is valid. (getGraphicsConfiguration): Ask peer if local value is null. * java/awt/event/ActionEvent.java (getActionCommand): Renamed from getcmd(). * java/awt/image/BufferedImage.java: New file. * java/awt/image/RasterOp.java: New file. * java/awt/peer/ComponentPeer.java (getGraphicsConfiguration): More powerfull replacement for getColorModel(). (getColorModel) Removed. (setEventMask) New method. * Makefile.am: Added new files. * Makefile.in: Rebuilt. From-SVN: r35748
Diffstat (limited to 'libjava/java/awt/Container.java')
-rw-r--r--libjava/java/awt/Container.java190
1 files changed, 171 insertions, 19 deletions
diff --git a/libjava/java/awt/Container.java b/libjava/java/awt/Container.java
index a315f850ed7..0cb60bae1c2 100644
--- a/libjava/java/awt/Container.java
+++ b/libjava/java/awt/Container.java
@@ -14,8 +14,9 @@ import java.io.PrintWriter;
import java.util.EventListener;
import java.awt.peer.ComponentPeer;
import java.awt.peer.ContainerPeer;
+import java.awt.peer.LightweightPeer;
-/* A very incomplete placeholder. */
+/* A somewhat incomplete class. */
public abstract class Container extends Component
{
@@ -30,9 +31,6 @@ public abstract class Container extends Component
/* Anything else is non-serializable, and should be declared "transient". */
transient ContainerListener containerListener;
- // Insets.
- private transient Insets myInsets;
-
public Container()
{
}
@@ -65,7 +63,10 @@ public abstract class Container extends Component
public Insets getInsets()
{
- return myInsets;
+ if (peer == null)
+ return new Insets(0, 0, 0, 0);
+
+ return ((ContainerPeer) peer).getInsets();
}
/** @deprecated Use getInsets() instead. */
@@ -112,14 +113,22 @@ public abstract class Container extends Component
// Reparent component, and make sure component is instantiated if
// we are.
- if (comp.parent != this)
+ if (comp.parent != null)
comp.parent.remove (comp);
comp.parent = this;
if (peer != null)
- comp.addNotify ();
+ {
+ comp.addNotify ();
+
+ if (comp.isLightweight())
+ enableEvents(comp.eventMask);
+ }
invalidate ();
+ if (component == null)
+ component = new Component[4]; // FIXME, better initial size?
+
// This isn't the most efficient implementation. We could do less
// copying when growing the array. It probably doesn't matter.
if (ncomponents >= component.length)
@@ -228,20 +237,48 @@ public abstract class Container extends Component
{
if (! isValid ())
{
- doLayout ();
validateTree ();
}
}
protected void validateTree()
{
+ if (valid) return;
+
+ ContainerPeer cPeer = null;
+ if ((peer != null) && !(peer instanceof LightweightPeer))
+ {
+ cPeer = (ContainerPeer) peer;
+ cPeer.beginValidate();
+ }
+
+ doLayout ();
for (int i = 0; i < ncomponents; ++i)
- component[i].validate ();
+ {
+ Component comp = component[i];
+ if (comp instanceof Container)
+ {
+ ((Container) comp).validateTree();
+ }
+ else
+ {
+ component[i].validate();
+ }
+ }
+
+ /* children will call invalidate() when they are layed out. It
+ is therefore imporant that valid is not set to true
+ before after the children has been layed out. */
+ valid = true;
+
+ if (cPeer != null)
+ cPeer.endValidate();
}
public void setFont(Font f)
{
- // FIXME
+ super.setFont(f);
+ // FIXME, should invalidate all children with font == null
}
public Dimension getPreferredSize()
@@ -307,28 +344,91 @@ public abstract class Container extends Component
public void paint(Graphics g)
{
- // FIXME
+ if (!isShowing())
+ return;
+ super.paint(g);
+ visitChildren(g, GfxPaintVisitor.INSTANCE, true);
+ }
+
+ /**
+ * Perform a graphics operation on the children of this container.
+ * For each applicable child, the visitChild() method will be called
+ * to perform the graphics operation.
+ *
+ * @param gfx The graphics object that will be used to derive new
+ * graphics objects for the children.
+ *
+ * @param visitor Object encapsulating the graphics operation that
+ * should be performed.
+ *
+ * @param lightweightOnly If true, only lightweight components will
+ * be visited.
+ */
+ private void visitChildren(Graphics gfx, GfxVisitor visitor,
+ boolean lightweightOnly)
+ {
+ // FIXME: do locking
+
+ for (int i = 0; i < ncomponents; ++i)
+ {
+ Component comp = component[i];
+ boolean applicable = comp.isVisible()
+ && (comp.isLightweight() || !lightweightOnly);
+
+ if (applicable)
+ visitChild(gfx, visitor, comp);
+ }
+ }
+
+ /**
+ * Perform a graphics operation on a child. A translated and clipped
+ * graphics object will be created, and the visit() method of the
+ * visitor will be called to perform the operation.
+ *
+ * @param gfx The graphics object that will be used to derive new
+ * graphics objects for the child.
+ *
+ * @param visitor Object encapsulating the graphics operation that
+ * should be performed.
+ *
+ * @param comp The child component that should be visited.
+ */
+ private void visitChild(Graphics gfx, GfxVisitor visitor,
+ Component comp)
+ {
+ Rectangle bounds = comp.getBounds();
+ Rectangle clip = gfx.getClipBounds().intersection(bounds);
+
+ if (clip.isEmpty()) return;
+
+ Graphics gfx2 = gfx.create();
+ gfx2.setClip(clip.x, clip.y, clip.width, clip.height);
+ gfx2.translate(bounds.x, bounds.y);
+
+ visitor.visit(comp, gfx2);
}
public void update(Graphics g)
{
- // FIXME
+ super.update(g);
}
public void print(Graphics g)
{
- // FIXME
+ super.print(g);
+ visitChildren(g, GfxPrintVisitor.INSTANCE, true);
}
public void paintComponents(Graphics g)
{
- // FIXME
+ super.paint(g);
+ visitChildren(g, GfxPaintAllVisitor.INSTANCE, true);
}
public void printComponents(Graphics g)
{
- for (int i = 0; i < ncomponents; ++i)
- component[i].printAll (g);
+ super.paint(g);
+ visitChildren(g, GfxPrintAllVisitor.INSTANCE, true);
}
void dispatchEventImpl(AWTEvent e)
@@ -393,12 +493,16 @@ public abstract class Container extends Component
return null;
for (int i = 0; i < ncomponents; ++i)
{
+ // Ignore invisible children...
+ if (!component[i].isVisible())
+ continue;
+
int x2 = x - component[i].x;
int y2 = y - component[i].y;
if (component[i].contains (x2, y2))
return component[i];
}
- return null;
+ return this;
}
/** @deprecated Use getComponentAt() instead */
@@ -425,8 +529,17 @@ public abstract class Container extends Component
public void addNotify ()
{
+ super.addNotify();
+ }
+
+ void addNotifyContainerChildren()
+ {
for (int i = ncomponents; --i >= 0; )
- component[i].addNotify();
+ {
+ component[i].addNotify();
+ if (component[i].isLightweight())
+ enableEvents(component[i].eventMask);
+ }
}
public void removeNotify()
@@ -450,7 +563,11 @@ public abstract class Container extends Component
protected String paramString()
{
- return "FIXME";
+ String param = super.paramString();
+ if (layoutMgr != null)
+ param = param + "," + layoutMgr.getClass().getName();
+
+ return param;
}
public void list (PrintStream out, int indent)
@@ -470,4 +587,39 @@ public abstract class Container extends Component
for (int i = 0; i < ncomponents; ++i)
component[i].list (out, indent + 2);
}
+
+
+ /* The following classes are used in concert with the
+ visitChildren() method to implement all the graphics operations
+ that requires traversal of the containment hierarchy. */
+
+ abstract static class GfxVisitor
+ {
+ public abstract void visit(Component c, Graphics gfx);
+ }
+
+ static class GfxPaintVisitor extends GfxVisitor
+ {
+ public void visit(Component c, Graphics gfx) { c.paint(gfx); }
+ public static final GfxVisitor INSTANCE = new GfxPaintVisitor();
+ }
+
+ static class GfxPrintVisitor extends GfxVisitor
+ {
+ public void visit(Component c, Graphics gfx) { c.print(gfx); }
+ public static final GfxVisitor INSTANCE = new GfxPrintVisitor();
+ }
+
+ static class GfxPaintAllVisitor extends GfxVisitor
+ {
+ public void visit(Component c, Graphics gfx) { c.paintAll(gfx); }
+ public static final GfxVisitor INSTANCE = new GfxPaintAllVisitor();
+ }
+
+ static class GfxPrintAllVisitor extends GfxVisitor
+ {
+ public void visit(Component c, Graphics gfx) { c.printAll(gfx); }
+ public static final GfxVisitor INSTANCE = new GfxPrintAllVisitor();
+ }
+
}