Frames | No Frames |
1: /* ======================================================================== 2: * JCommon : a free general purpose class 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/jcommon/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: * FontChooserDialog.java 29: * ---------------------- 30: * (C) Copyright 2000-2004, by Object Refinery Limited. 31: * 32: * Original Author: David Gilbert (for Object Refinery Limited); 33: * Contributor(s): -; 34: * 35: * $Id: FontChooserDialog.java,v 1.5 2007/11/02 17:50:36 taqua Exp $ 36: * 37: * Changes (from 26-Oct-2001) 38: * -------------------------- 39: * 26-Oct-2001 : Changed package to com.jrefinery.ui.*; 40: * 14-Oct-2002 : Fixed errors reported by Checkstyle (DG); 41: * 42: */ 43: 44: package org.jfree.ui; 45: 46: import java.awt.BorderLayout; 47: import java.awt.Dialog; 48: import java.awt.Font; 49: import java.awt.Frame; 50: import javax.swing.BorderFactory; 51: import javax.swing.JPanel; 52: 53: /** 54: * A dialog for choosing a font from the available system fonts. 55: * 56: * @author David Gilbert 57: */ 58: public class FontChooserDialog extends StandardDialog { 59: 60: /** The panel within the dialog that contains the font selection controls. */ 61: private FontChooserPanel fontChooserPanel; 62: 63: /** 64: * Standard constructor - builds a font chooser dialog owned by another dialog. 65: * 66: * @param owner the dialog that 'owns' this dialog. 67: * @param title the title for the dialog. 68: * @param modal a boolean that indicates whether or not the dialog is modal. 69: * @param font the initial font displayed. 70: */ 71: public FontChooserDialog(final Dialog owner, final String title, final boolean modal, final Font font) { 72: super(owner, title, modal); 73: setContentPane(createContent(font)); 74: } 75: 76: /** 77: * Standard constructor - builds a font chooser dialog owned by a frame. 78: * 79: * @param owner the frame that 'owns' this dialog. 80: * @param title the title for the dialog. 81: * @param modal a boolean that indicates whether or not the dialog is modal. 82: * @param font the initial font displayed. 83: */ 84: public FontChooserDialog(final Frame owner, final String title, final boolean modal, final Font font) { 85: super(owner, title, modal); 86: setContentPane(createContent(font)); 87: } 88: 89: /** 90: * Returns the selected font. 91: * 92: * @return the font. 93: */ 94: public Font getSelectedFont() { 95: return this.fontChooserPanel.getSelectedFont(); 96: } 97: 98: /** 99: * Returns the panel that is the user interface. 100: * 101: * @param font the font. 102: * 103: * @return the panel. 104: */ 105: private JPanel createContent(Font font) { 106: final JPanel content = new JPanel(new BorderLayout()); 107: content.setBorder(BorderFactory.createEmptyBorder(4, 4, 4, 4)); 108: if (font == null) { 109: font = new Font("Dialog", 10, Font.PLAIN); 110: } 111: this.fontChooserPanel = new FontChooserPanel(font); 112: content.add(this.fontChooserPanel); 113: 114: final JPanel buttons = createButtonPanel(); 115: buttons.setBorder(BorderFactory.createEmptyBorder(4, 0, 0, 0)); 116: content.add(buttons, BorderLayout.SOUTH); 117: 118: return content; 119: } 120: 121: }