KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jfree > chart > title > ImageTitle


1 /* ===========================================================
2  * JFreeChart : a free chart library for the Java(tm) platform
3  * ===========================================================
4  *
5  * (C) Copyright 2000-2005, by Object Refinery Limited and Contributors.
6  *
7  * Project Info: http://www.jfree.org/jfreechart/index.html
8  *
9  * This library is free software; you can redistribute it and/or modify it
10  * under the terms of the GNU Lesser General Public License as published by
11  * the Free Software Foundation; either version 2.1 of the License, or
12  * (at your option) any later version.
13  *
14  * This library is distributed in the hope that it will be useful, but
15  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16  * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
17  * License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with this library; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
22  * USA.
23  *
24  * [Java is a trademark or registered trademark of Sun Microsystems, Inc.
25  * in the United States and other countries.]
26  *
27  * ---------------
28  * ImageTitle.java
29  * ---------------
30  * (C) Copyright 2000-2005, by David Berry and Contributors;
31  *
32  * Original Author: David Berry;
33  * Contributor(s): David Gilbert (for Object Refinery Limited);
34  *
35  * $Id: ImageTitle.java,v 1.8.2.2 2005/11/01 21:39:53 mungady Exp $
36  *
37  * Changes (from 18-Sep-2001)
38  * --------------------------
39  * 18-Sep-2001 : Added standard header (DG);
40  * 07-Nov-2001 : Separated the JCommon Class Library classes, JFreeChart now
41  * requires jcommon.jar (DG);
42  * 09-Jan-2002 : Updated Javadoc comments (DG);
43  * 07-Feb-2002 : Changed blank space around title from Insets --> Spacer, to
44  * allow for relative or absolute spacing (DG);
45  * 25-Jun-2002 : Updated import statements (DG);
46  * 23-Sep-2002 : Fixed errors reported by Checkstyle (DG);
47  * 26-Nov-2002 : Added method for drawing images at left or right (DG);
48  * 22-Sep-2003 : Added checks that the Image can never be null (TM).
49  * 11-Jan-2005 : Removed deprecated code in preparation for the 1.0.0
50  * release (DG);
51  * 02-Feb-2005 : Changed padding mechanism for all titles (DG);
52  * 20-Apr-2005 : Added new draw() method (DG);
53  *
54  */

55
56 package org.jfree.chart.title;
57
58 import java.awt.Graphics2D JavaDoc;
59 import java.awt.Image JavaDoc;
60 import java.awt.geom.Rectangle2D JavaDoc;
61
62 import org.jfree.chart.event.TitleChangeEvent;
63 import org.jfree.ui.HorizontalAlignment;
64 import org.jfree.ui.RectangleEdge;
65 import org.jfree.ui.RectangleInsets;
66 import org.jfree.ui.Size2D;
67 import org.jfree.ui.VerticalAlignment;
68
69 /**
70  * A chart title that displays an image. This is useful, for example, if you
71  * have an image of your corporate logo and want to use as a footnote or part
72  * of a title in a chart you create.
73  * <P>
74  * ImageTitle needs an image passed to it in the constructor. For ImageTitle
75  * to work, you must have already loaded this image from its source (disk or
76  * URL). It is recomended you use something like
77  * Toolkit.getDefaultToolkit().getImage() to get the image. Then, use
78  * MediaTracker or some other message to make sure the image is fully loaded
79  * from disk.
80  *
81  * @author David Berry
82  */

83 public class ImageTitle extends Title {
84
85     /** The title image. */
86     private Image JavaDoc image;
87
88     /**
89      * Creates a new image title.
90      *
91      * @param image the image (<code>null</code> not permitted).
92      */

93     public ImageTitle(Image JavaDoc image) {
94         this(image, image.getHeight(null), image.getWidth(null),
95                 Title.DEFAULT_POSITION, Title.DEFAULT_HORIZONTAL_ALIGNMENT,
96                 Title.DEFAULT_VERTICAL_ALIGNMENT, Title.DEFAULT_PADDING);
97     }
98
99     /**
100      * Creates a new image title.
101      *
102      * @param image the image (<code>null</code> not permitted).
103      * @param position the title position.
104      * @param horizontalAlignment the horizontal alignment.
105      * @param verticalAlignment the vertical alignment.
106      */

107     public ImageTitle(Image JavaDoc image, RectangleEdge position,
108                       HorizontalAlignment horizontalAlignment,
109                       VerticalAlignment verticalAlignment) {
110
111         this(image, image.getHeight(null), image.getWidth(null),
112                 position, horizontalAlignment, verticalAlignment,
113                 Title.DEFAULT_PADDING);
114     }
115
116     /**
117      * Creates a new image title with the given image scaled to the given
118      * width and height in the given location.
119      *
120      * @param image the image (<code>null</code> not permitted).
121      * @param height the height used to draw the image.
122      * @param width the width used to draw the image.
123      * @param position the title position.
124      * @param horizontalAlignment the horizontal alignment.
125      * @param verticalAlignment the vertical alignment.
126      * @param padding the amount of space to leave around the outside of the
127      * title.
128      */

129     public ImageTitle(Image JavaDoc image, int height, int width,
130                       RectangleEdge position,
131                       HorizontalAlignment horizontalAlignment,
132                       VerticalAlignment verticalAlignment,
133                       RectangleInsets padding) {
134
135         super(position, horizontalAlignment, verticalAlignment, padding);
136         if (image == null) {
137             throw new NullPointerException JavaDoc("Null 'image' argument.");
138         }
139         this.image = image;
140         setHeight(height);
141         setWidth(width);
142
143     }
144
145     /**
146      * Returns the image for the title.
147      *
148      * @return The image for the title (never <code>null</code>).
149      */

150     public Image JavaDoc getImage() {
151         return this.image;
152     }
153
154     /**
155      * Sets the image for the title and notifies registered listeners that the
156      * title has been modified.
157      *
158      * @param image the new image (<code>null</code> not permitted).
159      */

160     public void setImage(Image JavaDoc image) {
161         if (image == null) {
162             throw new NullPointerException JavaDoc("Null 'image' argument.");
163         }
164         this.image = image;
165         notifyListeners(new TitleChangeEvent(this));
166     }
167
168     /**
169      * Draws the title on a Java 2D graphics device (such as the screen or a
170      * printer).
171      *
172      * @param g2 the graphics device.
173      * @param titleArea the area within which the title (and plot) should be
174      * drawn.
175      */

176     public void draw(Graphics2D JavaDoc g2, Rectangle2D JavaDoc titleArea) {
177
178         RectangleEdge position = getPosition();
179         if (position == RectangleEdge.TOP || position == RectangleEdge.BOTTOM) {
180             drawHorizontal(g2, titleArea);
181         }
182         else if (position == RectangleEdge.LEFT
183                      || position == RectangleEdge.RIGHT) {
184             drawVertical(g2, titleArea);
185         }
186         else {
187             throw new RuntimeException JavaDoc("Invalid title position.");
188         }
189     }
190
191     /**
192      * Draws the title on a Java 2D graphics device (such as the screen or a
193      * printer).
194      *
195      * @param g2 the graphics device.
196      * @param chartArea the area within which the title (and plot) should be
197      * drawn.
198      *
199      * @return The size of the area used by the title.
200      */

201     protected Size2D drawHorizontal(Graphics2D JavaDoc g2, Rectangle2D JavaDoc chartArea) {
202
203         double startY = 0.0;
204         double topSpace = 0.0;
205         double bottomSpace = 0.0;
206         double leftSpace = 0.0;
207         double rightSpace = 0.0;
208
209         double w = getWidth();
210         double h = getHeight();
211         RectangleInsets padding = getPadding();
212         topSpace = padding.calculateTopOutset(h);
213         bottomSpace = padding.calculateBottomOutset(h);
214         leftSpace = padding.calculateLeftOutset(w);
215         rightSpace = padding.calculateRightOutset(w);
216
217         if (getPosition() == RectangleEdge.TOP) {
218             startY = chartArea.getY() + topSpace;
219         }
220         else {
221             startY = chartArea.getY() + chartArea.getHeight() - bottomSpace - h;
222         }
223
224         // what is our alignment?
225
HorizontalAlignment horizontalAlignment = getHorizontalAlignment();
226         double startX = 0.0;
227         if (horizontalAlignment == HorizontalAlignment.CENTER) {
228             startX = chartArea.getX() + leftSpace + chartArea.getWidth() / 2.0
229                      - w / 2.0;
230         }
231         else if (horizontalAlignment == HorizontalAlignment.LEFT) {
232             startX = chartArea.getX() + leftSpace;
233         }
234         else if (horizontalAlignment == HorizontalAlignment.RIGHT) {
235             startX = chartArea.getX() + chartArea.getWidth() - rightSpace - w;
236         }
237         g2.drawImage(this.image, (int) startX, (int) startY, (int) w, (int) h,
238                 null);
239
240         return new Size2D(chartArea.getWidth() + leftSpace + rightSpace,
241             h + topSpace + bottomSpace);
242
243     }
244
245     /**
246      * Draws the title on a Java 2D graphics device (such as the screen or a
247      * printer).
248      *
249      * @param g2 the graphics device.
250      * @param chartArea the area within which the title (and plot) should be
251      * drawn.
252      *
253      * @return The size of the area used by the title.
254      */

255     protected Size2D drawVertical(Graphics2D JavaDoc g2, Rectangle2D JavaDoc chartArea) {
256
257         double startX = 0.0;
258         double topSpace = 0.0;
259         double bottomSpace = 0.0;
260         double leftSpace = 0.0;
261         double rightSpace = 0.0;
262
263         double w = getWidth();
264         double h = getHeight();
265         
266         RectangleInsets padding = getPadding();
267         if (padding != null) {
268             topSpace = padding.calculateTopOutset(h);
269             bottomSpace = padding.calculateBottomOutset(h);
270             leftSpace = padding.calculateLeftOutset(w);
271             rightSpace = padding.calculateRightOutset(w);
272         }
273
274         if (getPosition() == RectangleEdge.LEFT) {
275             startX = chartArea.getX() + leftSpace;
276         }
277         else {
278             startX = chartArea.getMaxX() - rightSpace - w;
279         }
280
281         // what is our alignment?
282
VerticalAlignment alignment = getVerticalAlignment();
283         double startY = 0.0;
284         if (alignment == VerticalAlignment.CENTER) {
285             startY = chartArea.getMinY() + topSpace
286                      + chartArea.getHeight() / 2.0 - h / 2.0;
287         }
288         else if (alignment == VerticalAlignment.TOP) {
289             startY = chartArea.getMinY() + topSpace;
290         }
291         else if (alignment == VerticalAlignment.BOTTOM) {
292             startY = chartArea.getMaxY() - bottomSpace - h;
293         }
294
295         g2.drawImage(this.image, (int) startX, (int) startY, (int) w, (int) h,
296                 null);
297
298         return new Size2D(chartArea.getWidth() + leftSpace + rightSpace,
299             h + topSpace + bottomSpace);
300
301     }
302     
303     /**
304      * Draws the block within the specified area.
305      *
306      * @param g2 the graphics device.
307      * @param area the area.
308      * @param params ignored (<code>null</code> permitted).
309      *
310      * @return Always <code>null</code>.
311      */

312     public Object JavaDoc draw(Graphics2D JavaDoc g2, Rectangle2D JavaDoc area, Object JavaDoc params) {
313         draw(g2, area);
314         return null;
315     }
316
317 }
318
Popular Tags