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#getCurrentTitlePainter()} API.
*
* @author Kirill Grouchnikov
* @see SubstanceLookAndFeel#getCurrentTitlePainter()
*/
public class GetCurrentTitlePainter extends JFrame {
/**
* Creates the main frame for <code>this</code> sample.
*/
public GetCurrentTitlePainter() {
super("Get current title painter");
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(GetCurrentTitlePainter.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 getTitlePainter = new JButton("Get current title painter");
getTitlePainter.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
JOptionPane.showMessageDialog(GetCurrentTitlePainter.this,
"Current title painter is of class "
+ SubstanceLookAndFeel
.getCurrentTitlePainter().getClass()
.getName());
}
});
controls.add(getTitlePainter);
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 GetCurrentTitlePainter().setVisible(true);
}
});
}
}
The screenshot below shows the result of calling this API
on the default (glass) title painter. Note the class 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 class name and the title pane fill:
|