All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.l2fprod.common.swing.UserPreferences Maven / Gradle / Ivy

Go to download

Orbit, a versatile image analysis software for biological image-based quantification

There is a newer version: 3.15
Show newest version
/**
 * $ $ License.
 *
 * Copyright $ L2FProd.com
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.l2fprod.common.swing;

import java.awt.Rectangle;
import java.awt.Window;
import java.awt.event.ComponentAdapter;
import java.awt.event.ComponentEvent;
import java.awt.event.ComponentListener;
import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.io.File;
import java.util.prefs.Preferences;

import javax.swing.JFileChooser;
import javax.swing.JSplitPane;
import javax.swing.event.DocumentListener;
import javax.swing.text.JTextComponent;

import com.l2fprod.common.util.converter.ConverterRegistry;

/**
 * UserPreferences. 
* */ public class UserPreferences { /** * Gets the default file chooser. Its current directory will be tracked and * restored on subsequent calls. * * @return the default file chooser */ public static JFileChooser getDefaultFileChooser() { return getFileChooser("default"); } /** * Gets the default directory chooser. Its current directory will be tracked * and restored on subsequent calls. * * @return the default directory chooser */ public static JFileChooser getDefaultDirectoryChooser() { return getDirectoryChooser("default"); } /** * Gets the file chooser with the given id. Its current directory will be * tracked and restored on subsequent calls. * * @param id * @return the file chooser with the given id */ public static JFileChooser getFileChooser(final String id) { JFileChooser chooser = new JFileChooser(); track(chooser, "FileChooser." + id + ".path"); return chooser; } /** * Gets the directory chooser with the given id. Its current directory will * be tracked and restored on subsequent calls. * * @param id * @return the directory chooser with the given id */ public static JFileChooser getDirectoryChooser(String id) { JFileChooser chooser; try { Class directoryChooserClass = Class.forName("com.l2fprod.common.swing.JDirectoryChooser"); chooser = (JFileChooser)directoryChooserClass.newInstance(); } catch (Exception e) { chooser = new JFileChooser(); chooser.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY); } track(chooser, "DirectoryChooser." + id + ".path"); return chooser; } private static void track(JFileChooser chooser, final String key) { // get the path for the given filechooser String path = node().get(key, null); if (path != null) { File file = new File(path); if (file.exists()) { chooser.setCurrentDirectory(file); } } PropertyChangeListener trackPath = new PropertyChangeListener() { public void propertyChange(PropertyChangeEvent evt) { /* everytime the path change, update the preferences */ if (evt.getNewValue() instanceof File) { node().put(key, ((File)evt.getNewValue()).getAbsolutePath()); } } }; chooser.addPropertyChangeListener( JFileChooser.DIRECTORY_CHANGED_PROPERTY, trackPath); } /** * Restores the window size, position and state if possible. Tracks the * window size, position and state. * * @param window */ public static void track(Window window) { Preferences prefs = node().node("Windows"); String bounds = prefs.get(window.getName() + ".bounds", null); if (bounds != null) { Rectangle rect = (Rectangle)ConverterRegistry.instance().convert( Rectangle.class, bounds); window.setBounds(rect); } window.addComponentListener(windowDimension); } private static ComponentListener windowDimension = new ComponentAdapter() { public void componentMoved(ComponentEvent e) { store((Window)e.getComponent()); } public void componentResized(ComponentEvent e) { store((Window)e.getComponent()); } private void store(Window w) { String bounds = (String)ConverterRegistry.instance().convert( String.class, w.getBounds()); node().node("Windows").put(w.getName() + ".bounds", bounds); } }; /** * Restores the text. Stores the text. * * @param text */ public static void track(JTextComponent text) { new TextListener(text); } private static class TextListener implements DocumentListener { private JTextComponent text; public TextListener(JTextComponent text) { this.text = text; restore(); text.getDocument().addDocumentListener(this); } public void changedUpdate(javax.swing.event.DocumentEvent e) { store(); } public void insertUpdate(javax.swing.event.DocumentEvent e) { store(); } public void removeUpdate(javax.swing.event.DocumentEvent e) { store(); } void restore() { Preferences prefs = node().node("JTextComponent"); text.setText(prefs.get(text.getName(), "")); } void store() { Preferences prefs = node().node("JTextComponent"); prefs.put(text.getName(), text.getText()); } }; public static void track(JSplitPane split) { Preferences prefs = node().node("JSplitPane"); // restore the previous location int dividerLocation = prefs.getInt(split.getName() + ".dividerLocation", -1); if (dividerLocation >= 0) { split.setDividerLocation(dividerLocation); } // track changes split.addPropertyChangeListener( JSplitPane.DIVIDER_LOCATION_PROPERTY, splitPaneListener); } private static PropertyChangeListener splitPaneListener = new PropertyChangeListener() { public void propertyChange(PropertyChangeEvent evt) { JSplitPane split = (JSplitPane)evt.getSource(); node().node("JSplitPane").put( split.getName() + ".dividerLocation", String.valueOf(split.getDividerLocation())); } }; /** * @return the Preference node where User Preferences are stored. */ private static Preferences node() { return Preferences.userNodeForPackage(UserPreferences.class).node( "UserPreferences"); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy