package ca.ubc.cs.spl.aspectPatterns.examples.factoryMethod.java; /* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- * * This file is part of the design patterns project at UBC * * The contents of this file are subject to the Mozilla Public License * Version 1.1 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/. * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is ca.ubc.cs.spl.aspectPatterns. * * For more details and the latest version of this code, please see: * http://www.cs.ubc.ca/labs/spl/projects/aodps.html * * Contributor(s): */ import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.JComponent; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import java.awt.Point; /** * Defines the <i>GUIComponentCreator</i> interface with the * <i>factoryMethod()</i> method signature and the <i>anOperation()</i> * method that uses it. For details, see GoF, page 108.<p> * * The factory method is <code>createComponent</code> and it creates * A JComponent (a button or a label, in this case). The <i>anOperation()</i> * method <code>showFrame()</code> uses the factory method to show a small * GUI. * * @author Jan Hannemann * @author Gregor Kiczales * @version 1.1, 02/11/04 * * @see ButtonCreator * @see LabelCreator */ public abstract class GUIComponentCreator { /** * The factory method to be concretized by subclasses. * * @returns the created <i>ConcreteProduct</i> */ public abstract JComponent createComponent(); /** * Another factory method to create a title for the GUI frame created * by this class. * * @returns the title for the GUI frame */ public abstract String getTitle(); /** * the position for the next frame to be created (on the screen). This * variable is used to make sure new frames appear staggered and don't * entirely overlap with existing frames. */ private static Point lastFrameLocation = new Point(0, 0); /** * Creates a <code>JFrame</code>, puts the <code>JComponent</code> that * is created by the factory method into it and displays the frame. This * Method also provides a <code>WindowListener</code>. */ public final void showFrame() { JFrame frame = new JFrame(getTitle()); frame.addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) {System.exit(0);} }); JPanel panel = new JPanel(); panel.add(createComponent()); frame.getContentPane().add(panel); frame.pack(); frame.setLocation(lastFrameLocation); lastFrameLocation.translate(75, 75); frame.setVisible(true); } }