import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.event.*;
import java.util.Vector;
import javax.swing.*;
import org.jvnet.substance.SubstanceLookAndFeel;
import org.jvnet.substance.title.TitlePainterInfo;
/**
* Test application that shows the use of the
* {@link SubstanceLookAndFeel#getCurrentTitlePainterName()} API.
*
* @author Kirill Grouchnikov
* @see SubstanceLookAndFeel#getCurrentTitlePainterName()
*/
public class GetCurrentTitlePainterName extends JFrame {
/**
* Creates the main frame for <code>this</code> sample.
*/
public GetCurrentTitlePainterName() {
super("Get current title painter name");
this.setLayout(new BorderLayout());
JPanel panel = new JPanel(new FlowLayout());
// Get all title painter display names and set the vector as a model
// for combobox.
final JComboBox cb = new JComboBox(new Vector<String>(
SubstanceLookAndFeel.getAllTitlePainters().keySet()));
cb
.setSelectedItem(SubstanceLookAndFeel
.getCurrentTitlePainterName());
cb.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent evt) {
// Get the affected item
final Object item = evt.getItem();
if (evt.getStateChange() == ItemEvent.SELECTED) {
SwingUtilities.invokeLater(new Runnable() {
public void run() {
try {
// Get the title painter info object based on
// the selected title painter display name
TitlePainterInfo painterInfo = SubstanceLookAndFeel
.getAllTitlePainters().get(
(String) item);
// Set the global title painter based on the
// title painter class name.
SubstanceLookAndFeel
.setCurrentTitlePainter(painterInfo
.getClassName());
SwingUtilities
.updateComponentTreeUI(GetCurrentTitlePainterName.this);
} catch (Exception exc) {
}
};
});
}
}
});
panel.add(new JLabel("All title painters:"));
panel.add(cb);
this.add(panel, BorderLayout.CENTER);
JPanel controls = new JPanel(new FlowLayout(FlowLayout.RIGHT));
JButton getTitlePainterName = new JButton(
"Get current title painter name");
getTitlePainterName.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
JOptionPane.showMessageDialog(
GetCurrentTitlePainterName.this,
"Current title painter name is "
+ SubstanceLookAndFeel
.getCurrentTitlePainterName());
}
});
controls.add(getTitlePainterName);
this.add(controls, BorderLayout.SOUTH);
this.setSize(400, 200);
this.setLocationRelativeTo(null);
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
/**
* The main method for <code>this</code> sample. The arguments are
* ignored.
*
* @param args
* Ignored.
* @throws Exception
* If some exception occured. Note that there is no special
* treatment of exception conditions in <code>this</code>
* sample code.
*/
public static void main(String[] args) throws Exception {
UIManager.setLookAndFeel(new SubstanceLookAndFeel());
JFrame.setDefaultLookAndFeelDecorated(true);
JDialog.setDefaultLookAndFeelDecorated(true);
SwingUtilities.invokeLater(new Runnable() {
public void run() {
new GetCurrentTitlePainterName().setVisible(true);
}
});
}
}
The screenshot below shows the result of calling this API
on the default (glass) title painter. Note the display name and the
title pane fill:
The screenshot below shows the result of calling this API
after the classic title painter has been selected in the combobox.
Note the display name and the title pane fill:
|