Galileo Computing :: Java 7 - Mehr als eine Insel - 9 Grafische Oberflächen mit Swing
Galileo Computing < openbook > Galileo Computing - Professionelle Bücher. Auch für Einsteiger.
Professionelle Bücher. Auch für Einsteiger.

Inhaltsverzeichnis
Vorwort
1 Neues in Java 7
2 Threads und nebenläufige Programmierung
3 Datenstrukturen und Algorithmen
4 Raum und Zeit
5 Dateien, Verzeichnisse und Dateizugriffe
6 Datenströme
7 Die eXtensible Markup Language (XML)
8 Dateiformate
9 Grafische Oberflächen mit Swing
10 Grafikprogrammierung
11 Netzwerkprogrammierung
12 Verteilte Programmierung mit RMI
13 RESTful und SOAP Web-Services
14 JavaServer Pages und Servlets
15 Applets
16 Datenbankmanagement mit JDBC
17 Technologien für die Infrastruktur
18 Reflection und Annotationen
19 Dynamische Übersetzung und Skriptsprachen
20 Logging und Monitoring
21 Java Native Interface (JNI)
22 Sicherheitskonzepte
23 Dienstprogramme für die Java-Umgebung
Stichwort

Download:
- openbook, ca. 21,3 MB
Buch bestellen
Ihre Meinung?

Spacer
Java 7 - Mehr als eine Insel von Christian Ullenboom
Das Handbuch zu den Java SE-Bibliotheken
Buch: Java 7 - Mehr als eine Insel

Java 7 - Mehr als eine Insel
Galileo Computing
1433 S., 2012, geb.
49,90 Euro, ISBN 978-3-8362-1507-7
Pfeil 9 Grafische Oberflächen mit Swing
Pfeil 9.1 Fenster zur Welt
Pfeil 9.1.1 Swing-Fenster mit javax.swing.JFrame darstellen
Pfeil 9.1.2 Fenster schließbar machen – setDefaultCloseOperation()
Pfeil 9.1.3 Sichtbarkeit des Fensters
Pfeil 9.1.4 Größe und Position des Fensters verändern
Pfeil 9.1.5 Fenster- und Dialog-Dekoration, Transparenz *
Pfeil 9.1.6 Die Klasse Toolkit *
Pfeil 9.1.7 Dynamisches Layout während einer Größenänderung *
Pfeil 9.1.8 Zum Vergleich: AWT-Fenster darstellen *
Pfeil 9.2 Beschriftungen (JLabel)
Pfeil 9.2.1 Mehrzeiliger Text, HTML in der Darstellung
Pfeil 9.3 Icon und ImageIcon für Bilder auf Swing-Komponenten
Pfeil 9.3.1 Die Klasse ImageIcon
Pfeil 9.3.2 Die Schnittstelle Icon und eigene Icons zeichnen *
Pfeil 9.4 Es tut sich was – Ereignisse beim AWT
Pfeil 9.4.1 Die Ereignisquellen und Horcher (Listener) von Swing
Pfeil 9.4.2 Listener implementieren
Pfeil 9.4.3 Listener bei dem Ereignisauslöser anmelden/abmelden
Pfeil 9.4.4 Adapterklassen nutzen
Pfeil 9.4.5 Innere Mitgliedsklassen und innere anonyme Klassen
Pfeil 9.4.6 Aufrufen der Listener im AWT-Event-Thread
Pfeil 9.4.7 Ereignisse, etwas genauer betrachtet *
Pfeil 9.5 Schaltflächen
Pfeil 9.5.1 Normale Schaltflächen (JButton)
Pfeil 9.5.2 Der aufmerksame ActionListener
Pfeil 9.5.3 Schaltflächen-Ereignisse vom Typ ActionEvent
Pfeil 9.5.4 Basisklasse AbstractButton
Pfeil 9.5.5 Wechselknopf (JToggleButton)
Pfeil 9.6 Textkomponenten
Pfeil 9.6.1 Text in einer Eingabezeile
Pfeil 9.6.2 Die Oberklasse der Text-Komponenten (JTextComponent)
Pfeil 9.6.3 Geschützte Eingaben (JPasswordField)
Pfeil 9.6.4 Validierende Eingabefelder (JFormattedTextField)
Pfeil 9.6.5 Einfache mehrzeilige Textfelder (JTextArea)
Pfeil 9.6.6 Editor-Klasse (JEditorPane) *
Pfeil 9.7 Swing Action *
Pfeil 9.8 JComponent und Component als Basis aller Komponenten
Pfeil 9.8.1 Hinzufügen von Komponenten
Pfeil 9.8.2 Tooltips (Kurzhinweise)
Pfeil 9.8.3 Rahmen (Border) *
Pfeil 9.8.4 Fokus und Navigation *
Pfeil 9.8.5 Ereignisse jeder Komponente *
Pfeil 9.8.6 Die Größe und Position einer Komponente *
Pfeil 9.8.7 Komponenten-Ereignisse *
Pfeil 9.8.8 UI-Delegate – der wahre Zeichner *
Pfeil 9.8.9 Undurchsichtige (opake) Komponente *
Pfeil 9.8.10 Properties und Listener für Änderungen *
Pfeil 9.9 Container
Pfeil 9.9.1 Standardcontainer (JPanel)
Pfeil 9.9.2 Bereich mit automatischen Rollbalken (JScrollPane)
Pfeil 9.9.3 Reiter (JTabbedPane)
Pfeil 9.9.4 Teilungskomponente (JSplitPane)
Pfeil 9.10 Alles Auslegungssache: die Layoutmanager
Pfeil 9.10.1 Übersicht über Layoutmanager
Pfeil 9.10.2 Zuweisen eines Layoutmanagers
Pfeil 9.10.3 Im Fluss mit FlowLayout
Pfeil 9.10.4 BoxLayout
Pfeil 9.10.5 Mit BorderLayout in alle Himmelsrichtungen
Pfeil 9.10.6 Rasteranordnung mit GridLayout
Pfeil 9.10.7 Der GridBagLayoutmanager *
Pfeil 9.10.8 Null-Layout *
Pfeil 9.10.9 Weitere Layoutmanager
Pfeil 9.11 Rollbalken und Schieberegler
Pfeil 9.11.1 Schieberegler (JSlider)
Pfeil 9.11.2 Rollbalken (JScrollBar) *
Pfeil 9.12 Kontrollfelder, Optionsfelder, Kontrollfeldgruppen
Pfeil 9.12.1 Kontrollfelder (JCheckBox)
Pfeil 9.12.2 ItemSelectable, ItemListener und das ItemEvent
Pfeil 9.12.3 Sich gegenseitig ausschließende Optionen (JRadioButton)
Pfeil 9.13 Fortschritte bei Operationen überwachen *
Pfeil 9.13.1 Fortschrittsbalken (JProgressBar)
Pfeil 9.13.2 Dialog mit Fortschrittsanzeige (ProgressMonitor)
Pfeil 9.14 Menüs und Symbolleisten
Pfeil 9.14.1 Die Menüleisten und die Einträge
Pfeil 9.14.2 Menüeinträge definieren
Pfeil 9.14.3 Einträge durch Action-Objekte beschreiben
Pfeil 9.14.4 Mit der Tastatur: Mnemonics und Shortcut
Pfeil 9.14.5 Der Tastatur-Shortcut (Accelerator)
Pfeil 9.14.6 Tastenkürzel (Mnemonics)
Pfeil 9.14.7 Symbolleisten alias Toolbars
Pfeil 9.14.8 Popup-Menüs
Pfeil 9.14.9 System-Tray nutzen *
Pfeil 9.15 Das Model-View-Controller-Konzept
Pfeil 9.16 Auswahlmenüs, Listen und Spinner
Pfeil 9.16.1 Listen (JList)
Pfeil 9.16.2 Auswahlmenü (JComboBox)
Pfeil 9.16.3 Drehfeld (JSpinner) *
Pfeil 9.16.4 Datumsauswahl *
Pfeil 9.17 Tabellen (JTable)
Pfeil 9.17.1 Ein eigenes Tabellen-Model
Pfeil 9.17.2 Basisklasse für eigene Modelle (AbstractTableModel)
Pfeil 9.17.3 Ein vorgefertigtes Standard-Modell (DefaultTableModel)
Pfeil 9.17.4 Ein eigener Renderer für Tabellen
Pfeil 9.17.5 Zell-Editoren
Pfeil 9.17.6 Größe und Umrandung der Zellen *
Pfeil 9.17.7 Spalteninformationen *
Pfeil 9.17.8 Tabellenkopf von Swing-Tabellen *
Pfeil 9.17.9 Selektionen einer Tabelle *
Pfeil 9.17.10 Automatisches Sortieren und Filtern mit RowSorter *
Pfeil 9.18 Bäume (JTree)
Pfeil 9.18.1 JTree und sein TreeModel und TreeNode
Pfeil 9.18.2 Selektionen bemerken
Pfeil 9.18.3 Das TreeModel von JTree *
Pfeil 9.19 JRootPane und JDesktopPane *
Pfeil 9.19.1 Wurzelkomponente der Top-Level-Komponenten (JRootPane)
Pfeil 9.19.2 JDesktopPane und die Kinder von JInternalFrame
Pfeil 9.19.3 JLayeredPane
Pfeil 9.20 Dialoge und Window-Objekte
Pfeil 9.20.1 JWindow und JDialog
Pfeil 9.20.2 Modal oder nicht-modal?
Pfeil 9.20.3 Standarddialoge mit JOptionPane
Pfeil 9.20.4 Der Dateiauswahldialog
Pfeil 9.20.5 Der Farbauswahldialog JColorChooser *
Pfeil 9.21 Flexibles Java-Look-and-Feel
Pfeil 9.21.1 Look and Feel global setzen
Pfeil 9.21.2 UIManager
Pfeil 9.21.3 Die Windows-Optik mit JGoodies Looks verbessern *
Pfeil 9.22 Swing-Komponenten neu erstellen oder verändern *
Pfeil 9.22.1 Überlagerungen mit dem Swing-Komponenten-Dekorator JLayer
Pfeil 9.23 Die Zwischenablage (Clipboard)
Pfeil 9.23.1 Clipboard-Objekte
Pfeil 9.23.2 Mit Transferable auf den Inhalt zugreifen
Pfeil 9.23.3 DataFlavor ist das Format der Daten in der Zwischenablage
Pfeil 9.23.4 Einfügungen in der Zwischenablage erkennen
Pfeil 9.23.5 Drag & Drop
Pfeil 9.24 Undo durchführen *
Pfeil 9.25 AWT, Swing und die Threads
Pfeil 9.25.1 Ereignisschlange (EventQueue) und AWT-Event-Thread
Pfeil 9.25.2 Swing ist nicht thread-sicher
Pfeil 9.25.3 invokeLater() und invokeAndWait()
Pfeil 9.25.4 SwingWorker
Pfeil 9.25.5 Eigene Ereignisse in die Queue setzen *
Pfeil 9.25.6 Auf alle Ereignisse hören *
Pfeil 9.26 Barrierefreiheit mit der Java Accessibility API
Pfeil 9.27 Zeitliches Ausführen mit dem javax.swing.Timer
Pfeil 9.28 Die Zusatzkomponentenbibliothek SwingX
Pfeil 9.28.1 Im Angebot: Erweiterte und neue Swing-Komponenten
Pfeil 9.28.2 Überblick über erweiterte Standard-Swing-Klassen
Pfeil 9.28.3 Neue Swing-Klassen
Pfeil 9.28.4 Weitere SwingX-Klassen
Pfeil 9.28.5 SwingX-Installation
Pfeil 9.29 Alternativen zu programmierten Oberflächen, AWT und Swing *
Pfeil 9.29.1 Deklarative Beschreibungen der Oberfläche: Swing JavaBuilder, Swixml
Pfeil 9.29.2 SWT (Standard Widget Toolkit)
Pfeil 9.30 Zum Weiterlesen

Galileo Computing - Zum Seitenanfang

9.20 Dialoge und Window-ObjekteZur nächsten Überschrift

Seit den ersten Swing-Tagen besitzt Swing Standard-Dialoge, wie einen Dateiauswahl-, Druck- oder Farbauswahldialog. Auf diese Dialogboxen soll dieser Abschnitt eingehen. Allerdings muss fairerweise gesagt werden, dass die Swing-Standarddialoge nur absolutes Minimim sind. Es lohnt sich, auf quelloffene Komponenten zurückzugreifen. Dazu zählen:


Galileo Computing - Zum Seitenanfang

9.20.1 JWindow und JDialogZur nächsten ÜberschriftZur vorigen Überschrift

Ein JFrame ist ein Fenster, das standardmäßig eine Dekoration besitzt. Ein java.awt.Window hat diese Dekoration nicht, sodass sich diese Fläche als Willkommensbildschirm oder als komplette Zeichenfläche nutzen lässt. javax.swing.JWindow ist die Swing-Unterklasse von Window.

Die folgende Tabelle gibt die Unterschiede zwischen Fenster, Window und Dialog an:

Tabelle 9.11: Unterschiede zwischen Frame, Window und Dialog

Eigenschaft Frame Window Dialog

Modal

nein

nein

möglich

Größenveränderbar

ja

nein

ja

Titel

ja

nein

ja

Rahmen

ja

nein

ja

Menü

ja

nein

unüblich, bei JDialog aber möglich

Symbol-Icon

ja

ja

ja


Galileo Computing - Zum Seitenanfang

9.20.2 Modal oder nicht-modal?Zur nächsten ÜberschriftZur vorigen Überschrift

Bildet eine Java-Applikation zwei Fenster, so kann der Anwender zwischen beiden Fenstern hin- und herschalten. Es ist nicht möglich, ein Fenster aufzubauen und dort Eingaben zu erzwingen, während das andere Fenster gesperrt ist. Dafür gibt es in Java spezielle Fenster, die Dialoge, die Swing mit javax.swing.JDialog angeht. JDialog ist eine Unterklasse von der AWT-Klasse Dialog, und Dialog ist wiederum eine Spezialisierung von Window. Ist ein Dialog im Zustand modal, muss erst der Dialog beendet werden, damit es in einem anderen Fenster weitergehen kann – alle Benutzereingaben an andere Fenster der Java-Anwendung sind so lange gesperrt. Sind mehrere Fenster gleichzeitig offen und können sie Eingaben annehmen, so nennt sich dieser Zustand nicht-modal.

Soll der Dialog modal sein, sind ein übergeordnetes Fenster und ein Wahrheitswert true für den Modalitätstyp einzusetzen:

JDialog d = new JDialog( owner, true );
...
d.setVisible( true );
// Hier geht’s erst nach dem Schließen des Dialogs weiter.

Der owner kann ein anderer Dialog, ein Frame oder ein Window sein. Da bei modalen Dialogen alle Eingaben zu anderen Fenstern blockiert sind, nehmen erst nach dem Schließen des Dialogs andere Fenster die Eingaben wieder an. Ob der Dialog modal ist oder nicht, lässt sich auch nach dem Erzeugen mit setModal(boolean) setzen.


Galileo Computing - Zum Seitenanfang

9.20.3 Standarddialoge mit JOptionPaneZur nächsten ÜberschriftZur vorigen Überschrift

Die Klasse JOptionPane erlaubt einfache Meldedialoge, Eingabedialoge, Bestätigungsdialoge und Optionsdialoge mit nur einem einfachen statischen Methodenaufruf der Art showXXXDialog():

  • showMessageDialog(): nur Nachricht anzeigen
  • showInputDialog(): Rückgabe ist ein String mit der Benutzereingabe bzw. Auswahl
  • showConfirmDialog(): Frage beantworten mit Möglichkeiten wie ja/nein
  • showOptionDialog(): allgemeinste Funktion

Einige Beispiele:

Listing 9.79: com/tutego/insel/ui/dialog/JOptionPaneDialogDemo.java, main()

// Dialog for a simple message
JOptionPane.showMessageDialog( null, "Wir Kinder aus dem Möwenweg" );

// Dialog for a user input
JOptionPane.showInputDialog( "Bitte Zahl eingeben" );

// Dialog to confirm a choice
JOptionPane.showConfirmDialog( null, "Alles OK?" );

// Dialog with different choices
String[] genderOptions = {
"männlich", "weiblich", "keine Ahnung", "ändert sich ständig" };

String gender = (String) JOptionPane.showInputDialog( null,
"Geschlecht",
"Bitte das Geschlecht wählen (eigenes, nicht gewünschtes)",
JOptionPane.QUESTION_MESSAGE,
null, genderOptions,
genderOptions[1] );

System.out.println( gender );

// Customized option dialog
String[] yesNoOptions = { "Ja", "Nein", "Abbrechen" };

int n = JOptionPane.showOptionDialog( null,
"Ja oder Nein?", // question
"Ja/Nein/Abbrechen", // title
JOptionPane.YES_NO_CANCEL_OPTION,
JOptionPane.QUESTION_MESSAGE, // icon
null, yesNoOptions,yesNoOptions[0] );

if ( n == JOptionPane.YES_OPTION )
System.out.println("Ja gewählt");

System.exit( 0 );

Einige Methoden erwarten als erstes Argument eine Vater-Komponente, die null sein kann. Sie dient zur relativen Ausrichtung des Dialogs und verknüpft den Dialog derart mit einem Fenster, dass, wenn das Fenster versteckt wird, auch der Dialog verschwindet.

Bestätigung einholen

Die statische Methode showConfirmDialog() gibt es in vier Varianten, denn sie erlaubt die Angabe für ein Icon, eine Überschrift, Fragetext und die Auswahl unterschiedlicher Schaltflächen.

class javax.swing.JOptionPane
extends JComponent
implements Accessible
  • static int showConfirmDialog(Component parentComponent, Object message)
    Dialog mit eigener Nachricht und mit Ja/Nein/Abbrechen-Schaltfächen sowie vordefiniertem Titel.
  • static int showConfirmDialog(Component parentComponent, Object message, String title,
    int optionType)

    Dialog mit eigener Nachricht sowie Dialogtitel, und der letzte Parameter kann JOptionPane.YES_NO_OPTION oder JOptionPane.YES_NO_CANCEL_OPTION sein, um entweder Ja/Nein-Schaltflächen darzustellen, oder auch Ja/Nein/Abbrechen-Schaltflächen.

Rückgaben der Methode zeigen Auswahl

Bei den statischen Methoden

  • String showInputDialog() (eine Methode liefert auch Object als Rückgabe)
  • int showConfirmDialog()
  • int showOptionDialog()

zeigt eine Rückgabe an, was der Benutzer gewählt bzw. geschrieben hat (showMessageDialog() liefert keine Rückgabe, sondern void). Mögliche Rückgaben sind bei showConfirmDialog() und showOptionDialog() Ganzzahlen, die die Konstanten YES_OPTION, NO_OPTION, CANCEL_OPTION, OK_OPTION oder CLOSED_OPTION benennen. showInputDialog() liefert einen String oder null, wenn der Benutzer den Dialog abgebrochen hat. Die Methode showInputDialog() ist flexibel und zeigt nicht einfach nur ein Eingabefeld an, sondern bei entsprechender Parametrisierung auch eine Auswahlliste.

Dialogtyp und Visualisierung mit Icon

Alle vier statischen Dialog-Methoden showMessageDialog(), showConfirmDialog(), showOption-Dialog() und showInputDialog() erlauben zusätzlich die Angabe eines Nachrichtentyps; mögliche Konstanten sind ERROR_MESSAGE, INFORMATION_MESSAGE, WARNING_MESSAGE, QUESTION_MESSAGE und PLAIN_MESSAGE. Sie bestimmen im Allgemeinen ein Standard-Icon, das vom Look and Feel abhängig ist. Ein eigenes Icon kann ebenfalls zugewiesen werden.

  • static int showConfirmDialog(Component parentComponent, Object message, String title,
    int optionType,
    int messageType)
  • static int showConfirmDialog(Component parentComponent, Object message, String title,
    int optionType,
    int messageType, Icon icon)
  • static String showInputDialog(Component parentComponent, Object message, String title,
    int messageType
    )
  • static Object showInputDialog(Component parentComponent, Object message, String title,
    int messageType, Icon icon
    , Object[] selectionValues, Object initialSelectionValue)
  • static void showMessageDialog(Component parentComponent, Object message, String title,
    int messageType
    )
  • static void showMessageDialog(Component parentComponent, Object message, String title,
    int messageType, Icon icon
    )
  • showOptionDialog(Component parentComponent, Object message, String title, int optionType, int messageType, Icon icon, Object[] options, Object initialValue)

Exemplare vom JOptionPane erzeugen

Selten gibt es die Notwendigkeit, andere als die statischen Methoden von showXXXDialog() einzusetzen. Erforderlich kann ein in einem solchen Fall genutztes Exemplar der Klasse JOptionPane aber zum Beispiel dann sein, wenn beim Klick auf das × vom Dialog-Fenster der Dialog nicht verschwinden soll oder wenn gewisse Werte im Textfeld bei showInputDialog() nicht erwünscht sind, wie Folgen von Leerzeichen. Grundsätzlich sieht der Aufbau eines eigenen Dialogs dann so aus:

JOptionPane pane = new JOptionPane( ... );
JDialog dialog = new JDialog();
dialog.setContentPane( pane );

oder:

JOptionPane pane = new JOptionPane( ... );
JDialog dialog = pane.createDialog( parent, title );

Galileo Computing - Zum Seitenanfang

9.20.4 Der DateiauswahldialogZur nächsten ÜberschriftZur vorigen Überschrift

Die Klasse JFileChooser (unter AWT heißt die Klasse FileDialog) simuliert einen betriebssystemabhängigen Dialog zur Auswahl von Dateien und Verzeichnissen. Der Selektor ist modal und kann für das Speichern und Öffnen konfiguriert sein. Zudem lassen sich die Pfade und ein Filter zur Auswahl spezieller Dateien setzen. Nach dem Schließen und Beenden mit dem OK-Button stehen ausgewählte Dateien zur Verfügung.

Vollständiges Programm für eine Auswahlbox

Wir können direkt aus dem Hauptprogramm ein Objekt JFrame erzeugen und dann einen Dateiauswahldialog öffnen. Zusätzlich wollen wir ihm einen Filter mitgeben, der Textdateien mit den Endungen .txt, .html und .log zulässt. Die Realisierung des Filterns erfolgt durch eine vorgegebene Implementierung der Schnittstelle FileFilter, durch FileNameExtensionFilter, die erst spät in Java 6 zur API stieß:

Listing 9.80: com/tutego/insel/ui/dialog/JFileChooserDemo.java, main()

JFileChooser fc = new JFileChooser();
FileFilter filter = new FileNameExtensionFilter( "Textdateien",

"xml", "txt", "html", "log" );
fc.setFileFilter( filter );

switch ( fc.showOpenDialog( null ) )
{
case JFileChooser.APPROVE_OPTION:
File file = fc.getSelectedFile();
System.out.println( file.getName() );
break;
default:
System.out.println( "Auswahl abgebrochen" );
}
System.exit( 0 );

Abbildung

Abbildung 9.53: Screenshot der Anwendung JFileChooseDemo

Tipp

Im Speichern-Dialog sollte ein Standardname angegeben sein. Im Idealfall richtet er sich nach dem Inhalt der Datei. Dazu bietet die Klasse JFileChooser die Methode setSelectedFile():

c.setSelectedFile( new File("c:/test.txt") );

class javax.swing.JFileChooser
extends JComponent
implements Accessible

Zum Erzeugen eines Auswahldialogs steht eine Reihe von Konstruktoren zur Auswahl:

  • JFileChooser()
    Erzeugt einen Dateidialog ohne Titel zum Öffnen einer Datei. Zeigt auf das Benutzerverzeichnis.
  • JFileChooser(File currentDirectory)
    Erzeugt wie JFileChooser() einen Dateidialog ohne Titel zum Öffnen einer Datei, zeigt aber beim Start auf das Verzeichnis currentDirectory.
  • JFileChooser(String currentDirectoryPath)
    Äquivalent zu JFileChooser(new File(currentDirectoryPath)).
  • String getDirectory()
    Liefert das Dialogverzeichnis.
  • File getSelectedFile()
    Liefert die ausgewählte Datei.
  • File[] getSelectedFiles()
    Liefert alle ausgewählten Dateien, wenn der Dateiauswahldialog Mehrfachselektion zulässt.
  • void setDialogTitle(String dialogTitle)
    Setzt einen neuen Fenstertitel.
  • void setDialogType(int dialogType)
    Handelt es sich um einen Laden/Speichern-Dialog oder um einen angepassten Dialog? Deklarierte Konstanten sind JFileChooser.OPEN_DIALOG, JFileChooser.SAVE_DIALOG und JFileChooser.CUSTOM_DIALOG.
  • void setFileView(FileView fileView)
    Standardmäßig zeigt der Dialog neben dem Dateinamen ein kleines Bild an. Das lässt sich mit einem FileView-Objekt anpassen.
  • void setAccessory(JComponent newAccessory)
    Setzt eine Komponente für eine mögliche Vorschau.

Filtern der Liste *

Ein Dateiauswahldialog zeigt standardmäßig alle nicht geschützten Dateien und Verzeichnisse an. Dem Dialog lässt sich ein Filter zuweisen, sodass nicht gewünschte Dateien ausgefiltert werden. Standardmäßig beachtet der Dateiauswahldialog drei unterschiedliche Filter:

  • Ob der JFileChooser geschützte Dateien anzeigt oder nicht, setzt setFileHidingEnabled(boolean). So zeigt setFileHidingEnabled(false) alle Dateien, auch die geschützten, an – geschützte Dateien beginnen auf Unix-Systemen mit einem Punkt.
  • Ein eigener Dateifilter lässt sich mit setFileFilter(FileFilter) setzen. Was der Filter nicht akzeptiert, taucht auch später in der Liste nicht auf.
  • Filter-Listen bestehen aus mehreren Filtern, die der Benutzer später auswählen kann. Microsoft Word zeigt zum Beispiel beim Laden Filter-Listen wie »Alle Dateien (*.*)«, »Word Dokumente (*.doc; *.doc*)« usw. an. Ein Filter wird mit addChoosableFileFilter(FileFilter) einem JFileChooser hinzugefügt. Es kann beliebig viele Aufrufe dieser Methode geben, die je einen Filter der Liste hinzufügt.

Einen konkreten Filter implementiert die Schnittstelle javax.swing.filechooser.FileFilter. Achtung! Obwohl wir eine Schnittstelle FileFilter schon kennen, handelt es sich nicht um diejenige aus dem java.io-Paket, sondern um eine Schnittstelle aus dem Paket javax. swing.filechooser.

Die Klassen, die die Schnittstelle FileFilter implementieren, müssen eine accept()-Methode realisieren und eine Methode getDescription(), die eine Zeichenkette für die Dialog-Liste liefert. Für reine Dateiendungen bietet sich die vorgefertigte Klasse javax.swing.filechooser.FileNameExtensionFilter an.

abstract class javax.swing.filechooser.FileFilter
  • abstract boolean accept(File f)
    Akzeptiert der FileFilter die Datei oder nicht?
  • abstract String getDescription()
    Liefert eine Beschreibung für den Filter.
Beispiel

Nur alle Ordner sowie Dateien, die mit der Tilde (»~«) beginnen, sollen angezeigt werden:

fc.setFileFilter( new FileFilter()
{
@Override public boolean accept( File f )
{
return f.isDirectory() ||
f.getName().startsWith( "~" );
}
@Override public String getDescription()
{
return "Benutzerverzeichnisse";
}
} );

class javax.swing.JFileChooser
extends JComponent
implements Accessible
  • void setFileHidingEnabled(boolean b)
    Bestimmt, ob verborgene Dateien angezeigt werden sollen.
  • void setFileFilter(javax.swing.filechooser.FileFilter filter)
    Setzt einen FileFilter zur Anzeige der gewünschten Dateien.
  • void addChoosableFileFilter(javax.swing.filechooser.FileFilter filter)
    Fügt einen Filter hinzu.
Hinweis

Sollen im Dialog nur Verzeichnisse, aber keine Dateien auftauchen, so lässt sich dies mit setFileSelectionMode() und einem passenden Argument einstellen:

fileChooser.setFileSelectionMode( JFileChooser.DIRECTORIES_ONLY );

Insgesamt sind drei Konstanten deklariert: FILES_ONLY, DIRECTORIES_ONLY und FILES_AND_DIRECTORIES. Der Name verrät schon die Bedeutung.

Vorschaubilder *

Die Methode setAccessory() kann eine JComponent für die Vorschau zuweisen, die immer dann aktualisiert wird, wenn der Benutzer im Dialog eine Datei auswählt. Eine Auswahl meldet dabei ein PropertyChangeEvent, das ein Listener abfängt und testet, ob es JFileChooser.SELECTED_FILE_CHANGED_PROPERTY war. Um das Vorgehen kurz zu skizzieren, folgende Ereignisbehandlung:

public void propertyChange( PropertyChangeEvent e )
{
if ( JFileChooser.SELECTED_FILE_CHANGED_PROPERTY.equals(e.getPropertyName()) )
{
File f = (File) e.getNewValue();
// File f laden, etwa mit ImageIcon, dann anzeigen.
}
}

Galileo Computing - Zum Seitenanfang

9.20.5 Der Farbauswahldialog JColorChooser *Zur nächsten ÜberschriftZur vorigen Überschrift

Mit einem JColorChooser lassen sich Farben über drei unterschiedliche Reiter auswählen. Der Benutzer hat die Auswahl zwischen vordefinierten Farben, HSB-Werten und RGB-Werten. Um den Farbauswahldialog auf den Bildschirm zu bekommen, genügt ein Aufruf von JColorChooser.showDialog() mit drei Argumenten: einem Component-Objekt (dem Vater des Dialogs), dem Titel und einer Anfangsfarbe. Beendet der Benutzer den Dialog, wird als Rückgabewert die ausgewählte Farbe geliefert. Wird der Dialog abgebrochen, so ist der Rückgabewert null:

Listing 9.81: com/tutego/insel/ui/dialog/JColorChooserDemo.java, main()

JFrame f = new JFrame();
f.setDefaultCloseOperation( JFrame.EXIT_ON_CLOSE );
JButton b = new JButton( "Farbe ändern" );
f.add( b );
b.addActionListener( new ActionListener() {
@Override public void actionPerformed( ActionEvent e ) {
Component comp = (Component) e.getSource();
Color newColor = JColorChooser.showDialog( null,
"Wähle neue Farbe",
comp.getBackground() );
comp.setBackground( newColor );
}
} );
f.pack();
f.setVisible( true );

Den Aufruf mit showDialog() einzuleiten, ist nicht der einzige Weg. Wir können auch den Konstruktor nutzen und dieses Exemplar später mit JColorChooser.createDialog() übergeben und anzeigen.

Abbildung

Abbildung 9.54: Screenshot des Farbauswahldialogs des Demoprogramms JColorChooserDemo

class javax.swing.JColorChooser
extends JComponent implements Accessible
  • JColorChooser()
    Erzeugt einen neuen Farbauswahldialog.
  • JColorChooser(Color c)
    Erzeugt einen neuen Farbauswahldialog mit einer vordefinierten Farbe.
  • static Color showDialog(Component c, String title, Color initialColor)
    Zeigt einen modalen Farbauswahldialog.
  • static JDialog createDialog(Component c, String title, boolean modal,
    JColorChooser chooserPane,
    ActionListener okLis,
    ActionListener cancelLis)
    Erzeugt einen neuen Dialog aufgrund des JColorChooser-Objekts mit Standardschaltflächen zum Bestätigen und Abbrechen.

JColorChooser-Objekte als spezielle Komponenten

Neben der statischen Methode showDialog() lässt sich auch der Konstruktor nutzen, um ein JColorChooser als spezielles JComponent-Objekt aufzubauen. Das bringt den Vorteil mit sich, dass die Farbauswahl nicht zwingend in einem eigenständigen Dialog stattfinden muss, sondern dass im Fall einer Komponente diese zusammen mit anderen Komponenten auf einen Container gesetzt werden kann. Änderungen an der Auswahl registriert ein ChangeListener, der etwa so angewendet wird:

chooser.getSelectionModel().addChangeListener( new ChangeListener() {
public void stateChanged( ChangeEvent e ) {
Color c = ((ColorSelectionModel) e.getSource()).getSelectedColor();
}
} );

Weitere Beispiele finden sich im Java Developers Almanac unter http://www.exampledepot.com/egs/javax.swing.colorchooser/pkg.html. Die Themen sind unter anderem: Anpassen der Anzeige und Umsortierung der Reiter. Üblich sind drei Reiter mit den Aufschriften Muster (auf einer englischsprachigen Oberfläche Swatch), HSB und RGB. Wie ein neuer Reiter mit einer Graustufenanzeige eingebracht wird, zeigt http://www.java2s.com/Code/Java/Swing-JFC/JColorChooserdialogwiththecustomGrayScalePanelpickertab.htm.



Ihr Kommentar

Wie hat Ihnen das <openbook> gefallen? Wir freuen uns immer über Ihre freundlichen und kritischen Rückmeldungen.







<< zurück
  Zum Katalog
Zum Katalog: Java 7 – Mehr als eine Insel
Java 7 – Mehr als eine Insel
Jetzt bestellen


 Ihre Meinung?
Wie hat Ihnen das <openbook> gefallen?
Ihre Meinung

 Buchempfehlungen
Zum Katalog: Java und XML






 Java und XML


Zum Katalog: Einstieg in Eclipse 3.7






 Einstieg in
 Eclipse 3.7


Zum Katalog: Android 3






 Android 3


Zum Katalog: NetBeans Platform 7






 NetBeans Platform 7


Zum Katalog: Java ist auch eine Insel






 Java ist
 auch eine Insel


Zum Katalog: Apps entwickeln für Android 4






 Apps entwickeln
 für Android 4


Zum Katalog: Java 7






 Java 7


 Shopping
Versandkostenfrei bestellen in Deutschland und Österreich
InfoInfo




Copyright © Galileo Press 2012
Für Ihren privaten Gebrauch dürfen Sie die Online-Version natürlich ausdrucken. Ansonsten unterliegt das denselben Bestimmungen, wie die gebundene Ausgabe: Das Werk einschließlich aller seiner Teile ist urheberrechtlich geschützt. Alle Rechte vorbehalten einschließlich der Vervielfältigung, Übersetzung, Mikroverfilmung sowie Einspeicherung und Verarbeitung in elektronischen Systemen.


[Galileo Computing]

Galileo Press, Rheinwerkallee 4, 53227 Bonn, Tel.: 0228.42150.0, Fax 0228.42150.77, info@galileo-press.de