1. /*
  2. * @(#)PaintEvent.java 1.18 03/01/23
  3. *
  4. * Copyright 2003 Sun Microsystems, Inc. All rights reserved.
  5. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
  6. */
  7. package java.awt.event;
  8. import java.awt.Component;
  9. import java.awt.Event;
  10. import java.awt.Rectangle;
  11. /**
  12. * The component-level paint event.
  13. * This event is a special type which is used to ensure that
  14. * paint/update method calls are serialized along with the other
  15. * events delivered from the event queue. This event is not
  16. * designed to be used with the Event Listener model; programs
  17. * should continue to override paint/update methods in order
  18. * render themselves properly.
  19. *
  20. * @author Amy Fowler
  21. * @version 1.18, 01/23/03
  22. * @since 1.1
  23. */
  24. public class PaintEvent extends ComponentEvent {
  25. /**
  26. * Marks the first integer id for the range of paint event ids.
  27. */
  28. public static final int PAINT_FIRST = 800;
  29. /**
  30. * Marks the last integer id for the range of paint event ids.
  31. */
  32. public static final int PAINT_LAST = 801;
  33. /**
  34. * The paint event type.
  35. */
  36. public static final int PAINT = PAINT_FIRST;
  37. /**
  38. * The update event type.
  39. */
  40. public static final int UPDATE = PAINT_FIRST + 1; //801
  41. /**
  42. * This is the rectangle that represents the area on the source
  43. * component that requires a repaint.
  44. * This rectangle should be non null.
  45. *
  46. * @serial
  47. * @see java.awt.Rectangle
  48. * @see #setUpdateRect(Rectangle)
  49. * @see #getUpdateRect()
  50. */
  51. Rectangle updateRect;
  52. /*
  53. * JDK 1.1 serialVersionUID
  54. */
  55. private static final long serialVersionUID = 1267492026433337593L;
  56. /**
  57. * Constructs a <code>PaintEvent</code> object with the specified
  58. * source component and type.
  59. * <p>Note that passing in an invalid <code>id</code> results in
  60. * unspecified behavior.
  61. *
  62. * @param source the object where the event originated
  63. * @param id the event type
  64. * @param updateRect the rectangle area which needs to be repainted
  65. */
  66. public PaintEvent(Component source, int id, Rectangle updateRect) {
  67. super(source, id);
  68. this.updateRect = updateRect;
  69. }
  70. /**
  71. * Returns the rectangle representing the area which needs to be
  72. * repainted in response to this event.
  73. */
  74. public Rectangle getUpdateRect() {
  75. return updateRect;
  76. }
  77. /**
  78. * Sets the rectangle representing the area which needs to be
  79. * repainted in response to this event.
  80. * @param updateRect the rectangle area which needs to be repainted
  81. */
  82. public void setUpdateRect(Rectangle updateRect) {
  83. this.updateRect = updateRect;
  84. }
  85. public String paramString() {
  86. String typeStr;
  87. switch(id) {
  88. case PAINT:
  89. typeStr = "PAINT";
  90. break;
  91. case UPDATE:
  92. typeStr = "UPDATE";
  93. break;
  94. default:
  95. typeStr = "unknown type";
  96. }
  97. return typeStr + ",updateRect="+(updateRect != null ? updateRect.toString() : "null");
  98. }
  99. }