From a2cd723c26d9999b752ca5474f7a24de952b5fdb Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Mon, 26 May 2008 19:12:29 +0000 Subject: All abstract classes now have an Abstract in it's name --- sources/prefs/VSPrefs.java | 2 +- sources/prefs/editors/VSAbstractBetterEditor.java | 116 +++ sources/prefs/editors/VSAbstractEditor.java | 938 ++++++++++++++++++++++ sources/prefs/editors/VSBetterEditor.java | 116 --- sources/prefs/editors/VSEditor.java | 938 ---------------------- sources/prefs/editors/VSEditorFrame.java | 4 +- sources/prefs/editors/VSProcessEditor.java | 8 +- sources/prefs/editors/VSSimulatorEditor.java | 6 +- 8 files changed, 1064 insertions(+), 1064 deletions(-) create mode 100644 sources/prefs/editors/VSAbstractBetterEditor.java create mode 100644 sources/prefs/editors/VSAbstractEditor.java delete mode 100644 sources/prefs/editors/VSBetterEditor.java delete mode 100644 sources/prefs/editors/VSEditor.java (limited to 'sources/prefs') diff --git a/sources/prefs/VSPrefs.java b/sources/prefs/VSPrefs.java index 915d8e3..f8beb66 100644 --- a/sources/prefs/VSPrefs.java +++ b/sources/prefs/VSPrefs.java @@ -11,7 +11,7 @@ import java.util.*; /** * The Class VSPrefs. */ -public abstract class VSPrefs implements Serializable { +public class VSPrefs implements Serializable { /** The Constant BOOLEAN_PREFIX. */ public static final String BOOLEAN_PREFIX = "Boolean: "; diff --git a/sources/prefs/editors/VSAbstractBetterEditor.java b/sources/prefs/editors/VSAbstractBetterEditor.java new file mode 100644 index 0000000..1f448f7 --- /dev/null +++ b/sources/prefs/editors/VSAbstractBetterEditor.java @@ -0,0 +1,116 @@ +/* + * VS is (c) 2008 by Paul C. Buetow + * vs@dev.buetow.org + */ +package prefs.editors; + +import java.awt.*; +import java.awt.event.*; +import javax.swing.*; + +import prefs.*; +import utils.*; + +// TODO: Auto-generated Javadoc +/** + * The Class VSAbstractBetterEditor. + */ +public abstract class VSAbstractBetterEditor extends VSAbstractEditor { + private static final long serialVersionUID = 1L; + + /** The content pane. */ + private Container contentPane; + + /** The info area. */ + private VSInfoArea infoArea; + + /** The title. */ + private String title; + + /** + * Instantiates a new lang.process.removebetter editor. + * + * @param prefs the prefs + * @param prefsToEdit the prefs to edit + * @param title the title + */ + public VSAbstractBetterEditor(VSPrefs prefs, VSPrefs prefsToEdit, String title) { + super(prefs, prefsToEdit); + this.title = title; + this.contentPane = createContentPane(); + } + + /** + * Gets the title. + * + * @return the title + */ + public String getTitle() { + return title; + } + + /** + * Gets the content pane. + * + * @return the content pane + */ + public Container getContentPane() { + contentPane.setBackground(Color.WHITE); + return contentPane; + } + + /** + * Creates the content pane. + * + * @return the j panel + */ + private JPanel createContentPane() { + JPanel panel = new JPanel(); + panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS)); + + infoArea = new VSInfoArea(); + JPanel editPanel = getEditPanel(); + JPanel buttonPanel = getButtonPanel(); + + JScrollPane scrollPane = new JScrollPane(editPanel); + panel.add(editPanel); + //panel.add(infoArea); + panel.add(buttonPanel); + + return panel; + } + + /* (non-Javadoc) + * @see prefs.editors.VSAbstractEditor#addToButtonPanelFront(javax.swing.JPanel) + */ + protected void addToButtonPanelFront(JPanel buttonPanel) { } + + /* (non-Javadoc) + * @see prefs.editors.VSAbstractEditor#addToButtonPanelLast(javax.swing.JPanel) + */ + protected void addToButtonPanelLast(JPanel buttonPanel) { } + + /* (non-Javadoc) + * @see prefs.editors.VSAbstractEditor#addToEditTableLast() + */ + protected void addToEditTableLast() { } + + /* (non-Javadoc) + * @see prefs.editors.VSAbstractEditor#actionPerformed(java.awt.event.ActionEvent) + */ + public void actionPerformed(ActionEvent e) { + //String actionCommand = e.getActionCommand(); + + /* More action in the super class!!! */ + super.actionPerformed(e); + } + + /** + * Gets the info area. + * + * @return the info area + */ + protected VSInfoArea getInfoArea() { + return infoArea; + } +} diff --git a/sources/prefs/editors/VSAbstractEditor.java b/sources/prefs/editors/VSAbstractEditor.java new file mode 100644 index 0000000..9ae98be --- /dev/null +++ b/sources/prefs/editors/VSAbstractEditor.java @@ -0,0 +1,938 @@ +/* + * VS is (c) 2008 by Paul C. Buetow + * vs@dev.buetow.org + */ +package prefs.editors; + +import java.awt.*; +import java.awt.event.*; +import javax.swing.*; +import java.util.*; + +import utils.*; +import prefs.VSPrefs; + +// TODO: Auto-generated Javadoc +/** + * The Class VSAbstractEditor. + */ +public abstract class VSAbstractEditor implements ActionListener { + private static final long serialVersionUID = 1L; + + /** The boolean keys. */ + private ArrayList booleanKeys; + + /** The color keys. */ + private ArrayList colorKeys; + + /** The float keys. */ + private ArrayList floatKeys; + + /** The integer keys. */ + private ArrayList integerKeys; + + /** The vector keys. */ + private ArrayList vectorKeys; + + /** The long keys. */ + private ArrayList longKeys; + + /** The string keys. */ + private ArrayList stringKeys; + + /** The boolean fields. */ + private HashMap booleanFields; + + /** The integer fields. */ + private HashMap integerFields; + + /** The vector fields. */ + private HashMap vectorFields; + + /** The color fields. */ + private HashMap colorFields; + + /** The float fields. */ + private HashMap floatFields; + + /** The long fields. */ + private HashMap longFields; + + /** The string fields. */ + private HashMap stringFields; + + /** The prefs to edit map. */ + private HashMap prefsToEditMap; + + /** The button panel. */ + private JPanel buttonPanel; + + /** The edit panel. */ + private JPanel editPanel; + + /** The edit table. */ + private VSEditorTable editTable; + + /** The frame. */ + private VSFrame frame; + + /** The expert mode changed. */ + private boolean expertModeChanged; + + /** The prefs. */ + protected VSPrefs prefs; + + /** The prefs to edit. */ + protected VSPrefs prefsToEdit; + + /** The Constant MIN_UNIT_LENGTH. */ + protected static final int MIN_UNIT_LENGTH = 5; + + /** The Constant VALUE_FIELD_COLS. */ + protected static final int VALUE_FIELD_COLS = 9; + + /** The Constant ALL_PREFERENCES. */ + public static final int ALL_PREFERENCES = 0; + + /** The Constant SIMULATION_PREFERENCES. */ + public static final int SIMULATION_PREFERENCES = 1; + + /** + * Instantiates a new lang.process.removeeditor. + * + * @param prefs the prefs + * @param prefsToEdit the prefs to edit + */ + public VSAbstractEditor(VSPrefs prefs, VSPrefs prefsToEdit) { + init(prefs, prefsToEdit); + } + + /** + * Adds the to button panel front. + * + * @param buttonPanel the button panel + */ + abstract protected void addToButtonPanelFront(JPanel buttonPanel); + + /** + * Adds the to button panel last. + * + * @param buttonPanel the button panel + */ + abstract protected void addToButtonPanelLast(JPanel buttonPanel); + + /** + * Adds the to edit table last. + */ + abstract protected void addToEditTableLast(); + + /** + * Sets the prefs. + * + * @param prefs the new prefs + */ + public void setPrefs(VSPrefs prefs) { + this.prefs = prefs; + } + + /** + * Sets the prefs to edit. + * + * @param prefsToEdit the new prefs to edit + */ + public void setPrefsToEdit(VSPrefs prefsToEdit) { + this.prefsToEdit = prefsToEdit; + } + + /** + * Sets the frame. + * + * @param frame the new frame + */ + public void setFrame(VSFrame frame) { + this.frame = frame; + } + + /** + * Gets the frame. + * + * @return the frame + */ + public VSFrame getFrame() { + return frame; + } + + /** + * Dispose frame if exists. + */ + protected void disposeFrameIfExists() { + if (frame != null) + frame.dispose(); + } + + /** + * Dispose frame with parent if exists. + */ + protected void disposeFrameWithParentIfExists() { + if (frame != null) + frame.disposeWithParent(); + } + + /** + * Inits the. + * + * @param prefs the prefs + * @param prefsToEdit the prefs to edit + */ + private void init(VSPrefs prefs, VSPrefs prefsToEdit) { + this.prefs = prefs; + this.prefsToEdit = prefsToEdit; + + editPanel = createEditPanel(); + buttonPanel = createButtonPanel(); + + prefsToEditMap = new HashMap(); + + colorFields = new HashMap(); + floatFields = new HashMap(); + integerFields = new HashMap(); + vectorFields = new HashMap(); + longFields = new HashMap(); + booleanFields = new HashMap(); + stringFields = new HashMap(); + + colorKeys = filterKeys(prefsToEdit.getColorKeySet()); + floatKeys = filterKeys(prefsToEdit.getFloatKeySet()); + integerKeys = filterKeys(prefsToEdit.getIntegerKeySet()); + vectorKeys = filterKeys(prefsToEdit.getVectorKeySet()); + longKeys = filterKeys(prefsToEdit.getLongKeySet()); + booleanKeys = filterKeys(prefsToEdit.getBooleanKeySet()); + stringKeys = filterKeys(prefsToEdit.getStringKeySet()); + + fillEditPanel(prefsToEdit); + } + + /** + * Filter keys. + * + * @param set the set + * + * @return the array list< string> + */ + private ArrayList filterKeys(Set set) { + ArrayList filtered = new ArrayList(); + boolean expertMode = prefs.getBoolean("sim.mode.expert"); + + for (String elem : set) { + if (!elem.startsWith("lang.") && !elem.startsWith("keyevent")) { + if (expertMode) + filtered.add(elem); + else if (!elem.startsWith("col.") && (!elem.startsWith("div."))) + filtered.add(elem); + } + } + + return filtered; + } + + /** + * Creates the button panel. + * + * @return the j panel + */ + private JPanel createButtonPanel() { + JPanel buttonPanel = new JPanel(); + buttonPanel.setBackground(Color.WHITE); + addToButtonPanelFront(buttonPanel); + + JButton resetButton = new JButton( + prefs.getString("lang.reset")); + resetButton.setMnemonic(prefs.getInteger("keyevent.reset")); + resetButton.addActionListener(this); + buttonPanel.add(resetButton); + + addToButtonPanelLast(buttonPanel); + + return buttonPanel; + } + + /** + * Creates the unit panel. + * + * @param comp the comp + * @param key the key + * + * @return the j panel + */ + private JPanel createUnitPanel(VSPrefs prefsToEdit, Component comp, String fullKey) { + JPanel unitPanel = new JPanel(new GridBagLayout()); + unitPanel.setBackground(Color.WHITE); + unitPanel.setBorder(null); + + String unitText = prefsToEdit.getUnit(fullKey); + if (unitText == null) + unitText = ""; + + unitText = " " + unitText; + while (unitText.length() < MIN_UNIT_LENGTH) + unitText = unitText + " "; + JLabel unitLabel = new JLabel(unitText); + + unitPanel.setLayout(new BoxLayout(unitPanel, BoxLayout.X_AXIS)); + unitPanel.add(comp); + unitPanel.add(unitLabel); + + return unitPanel; + } + + /** + * Creates the edit panel. + * + * @return the j panel + */ + private JPanel createEditPanel() { + JPanel editPanel = new JPanel(); + editPanel.setLayout(new BoxLayout(editPanel, BoxLayout.Y_AXIS)); + editPanel.setBackground(Color.WHITE); + + editTable = new VSEditorTable(prefs); + JScrollPane scrollPane = new JScrollPane(editTable); + editPanel.add(scrollPane); + + return editPanel; + } + + /** + * Creates the integer component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + * + * @return the lang.process.removetupel< string, component, j combo box> + */ + protected VSTupel createIntegerComponent(String fullKey, String key, VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + Integer integer = prefsToEdit.getInteger(key); + Integer initialSelection[] = { integer }; + JComboBox valComboBox = new JComboBox(initialSelection); + VSPrefs.VSPrefRestriction settingRestriction = prefsToEdit.getRestriction(fullKey); + + int minValue, maxValue; + if (settingRestriction != null) { + VSPrefs.VSIntegerPrefRestriction integerVSPrefRestriction = + (VSPrefs.VSIntegerPrefRestriction) settingRestriction; + minValue = integerVSPrefRestriction.getMinValue(); + maxValue = integerVSPrefRestriction.getMaxValue(); + + } else { + minValue = 0; + maxValue = 100; + } + + for (int i = minValue; i <= maxValue; ++i) + valComboBox.addItem(new Integer(i)); + valComboBox.setBorder(null); + + return new VSTupel(label, + createUnitPanel(prefsToEdit, valComboBox, fullKey), valComboBox); + } + + /** + * Creates the vector component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + */ + protected VSTupel createVectorComponent(String fullKey, String key, VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + + Vector vec = prefsToEdit.getVector(key); + JTextField valField = new JTextField(); + valField.setBorder(null); + valField.setText(vec.toString()); + + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Creates the boolean component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + */ + protected VSTupel createBooleanComponent(String fullKey, String key, VSPrefs prefsToEdit) { + final String activated = prefs.getString("lang.activated"); + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + JCheckBox valField = new JCheckBox(activated, prefsToEdit.getBoolean(key)); + valField.setBackground(Color.WHITE); + valField.setBorder(null); + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Creates the long component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + * + * @return the lang.process.removetupel< string, component, j text field> + */ + protected VSTupel createLongComponent(String fullKey, String key, VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + JTextField valField = new JTextField(VALUE_FIELD_COLS); + valField.addKeyListener(new java.awt.event.KeyAdapter() { + public void keyTyped(java.awt.event.KeyEvent e) { + JTextField valField = (JTextField)e.getSource(); + if (valField.getText().length() >= valField.getColumns() + 10) + e.consume(); + } + }); + valField.setText(""+prefsToEdit.getLong(key)); + valField.setBorder(null); + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Creates the float component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + * + * @return the lang.process.removetupel< string, component, j text field> + */ + protected VSTupel createFloatComponent(String fullKey, String key, VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + JTextField valField = new JTextField(VALUE_FIELD_COLS); + valField.addKeyListener(new java.awt.event.KeyAdapter() { + public void keyTyped(java.awt.event.KeyEvent e) { + JTextField valField = (JTextField)e.getSource(); + if (valField.getText().length() >= valField.getColumns() + 10) + e.consume(); + } + }); + valField.setText(""+prefsToEdit.getFloat(key)); + valField.setBorder(null); + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Creates the color component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + * + * @return the lang.process.removetupel< string, component, j text field> + */ + protected VSTupel createColorComponent(String fullKey, String key, final VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + final JTextField valField = new JTextField(VALUE_FIELD_COLS); + Color color = prefsToEdit.getColor(key); + valField.setBackground(color); + valField.setEditable(false); + valField.addMouseListener(new MouseListener() { + public void mouseExited(MouseEvent e) { } + public void mouseReleased(MouseEvent e) { } + public void mouseEntered(MouseEvent e) { } + public void mousePressed(MouseEvent e) { } + public void mouseClicked(MouseEvent e) { + JFrame parentFrame = getFrame(); + JFrame frame = new VSFrame( + prefs.getString("lang.name") + " - " + + prefs.getString( + "lang.colorchooser"),parentFrame); + frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); + + JComponent colorChooserPane = new VSColorChooser(prefs, valField); + colorChooserPane.setOpaque(true); + + frame.setContentPane(colorChooserPane); + frame.pack(); + frame.setVisible(true); + } + }); + valField.setBorder(null); + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Creates the string component. + * + * @param fullKey the full key + * @param key the key + * @param prefsToEdit the prefs to edit + * + * @return the lang.process.removetupel< string, component, j text field> + */ + protected VSTupel createStringComponent(String fullKey, String key, VSPrefs prefsToEdit) { + String descr = prefsToEdit.getDescription(fullKey); + String label = descr == null ? fullKey : descr; + JTextField valField = new JTextField(VALUE_FIELD_COLS); + valField.addKeyListener(new java.awt.event.KeyAdapter() { + public void keyTyped(java.awt.event.KeyEvent e) { + JTextField valField = (JTextField)e.getSource(); + if (valField.getText().length() >= valField.getColumns() + 10) + e.consume(); + } + }); + valField.setText(prefsToEdit.getString(key)); + valField.setBorder(null); + return new VSTupel(label, + createUnitPanel(prefsToEdit, valField, fullKey), valField); + } + + /** + * Fill edit panel. + * + * @param prefsToEdit the prefs to edit + */ + private void fillEditPanel(VSPrefs prefsToEdit) { + HashMap components = new HashMap(); + HashMap labels = new HashMap(); + + for (String key : integerKeys) { + String fullKey = VSPrefs.INTEGER_PREFIX + key; + VSTupel tupel = + createIntegerComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + integerFields.put(key, tupel.getC()); + } + + for (String key : vectorKeys) { + String fullKey = VSPrefs.VECTOR_PREFIX + key; + VSTupel tupel = + createVectorComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + vectorFields.put(key, tupel.getC()); + } + + for (String key : booleanKeys) { + String fullKey = VSPrefs.BOOLEAN_PREFIX + key; + VSTupel tupel = createBooleanComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + booleanFields.put(key, tupel.getC()); + } + + for (String key : longKeys) { + String fullKey = VSPrefs.LONG_PREFIX + key; + VSTupel tupel = createLongComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + longFields.put(key, tupel.getC()); + } + + + for (String key : floatKeys) { + String fullKey = VSPrefs.FLOAT_PREFIX + key; + VSTupel tupel = createFloatComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + floatFields.put(key, tupel.getC()); + } + + + for (String key : colorKeys) { + String fullKey = VSPrefs.COLOR_PREFIX + key; + VSTupel tupel = createColorComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + colorFields.put(key, tupel.getC()); + } + + for (String key : stringKeys) { + String fullKey = VSPrefs.STRING_PREFIX + key; + VSTupel tupel = createStringComponent(fullKey, key, prefsToEdit); + labels.put(fullKey, tupel.getA()); + components.put(fullKey, tupel.getB()); + stringFields.put(key, tupel.getC()); + } + + ArrayList fullKeys = new ArrayList(); + fullKeys.addAll(components.keySet()); + Collections.sort(fullKeys); + + boolean flag = false; + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(' ')+1); + if (key.startsWith("sim.")) { + if (!flag) { + flag = true; + addSeparator(prefs.getString("lang.prefs.simulation")); + } + addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); + } + } + + flag = false; + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(' ')+1); + if (key.startsWith("process.")) { + if (!flag) { + flag = true; + addSeparator(prefs.getString("lang.prefs.process")); + } + addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); + } + } + + flag = false; + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(' ')+1); + if (key.startsWith("message.")) { + if (!flag) { + flag = true; + addSeparator(prefs.getString("lang.prefs.message")); + } + addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); + } + } + + flag = false; + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(' ')+1); + if (key.startsWith("col.")) { + if (!flag) { + flag = true; + addSeparator(prefs.getString("lang.prefs.color")); + } + addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); + } + } + + flag = false; + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(' ')+1); + if (key.startsWith("div.")) { + if (!flag) { + flag = true; + addSeparator(prefs.getString("lang.prefs.diverse")); + } + addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); + } + } + + addToEditTableLast(); + editTable.fireTableDataChanged(); + } + + /** + * Adds the to editor. + * + * @param label the label + * @param prefsKey the prefs key + * @param prefsToAdd the prefs to add + */ + protected void addToEditor(String label, String prefsKey, VSPrefs prefsToAdd) { + addSeparator(label); + prefsKey = "(" + prefsKey + ")"; + + ArrayList fullKeys = new ArrayList(); + + Set integerKeys = prefsToAdd.getIntegerKeySet(); + Set vectorKeys = prefsToAdd.getVectorKeySet(); + Set floatKeys = prefsToAdd.getFloatKeySet(); + Set longKeys = prefsToAdd.getLongKeySet(); + Set booleanKeys = prefsToAdd.getBooleanKeySet(); + Set stringKeys = prefsToAdd.getStringKeySet(); + + for (String key : integerKeys) fullKeys.add(VSPrefs.INTEGER_PREFIX + key); + for (String key : vectorKeys) fullKeys.add(VSPrefs.VECTOR_PREFIX + key); + for (String key : floatKeys) fullKeys.add(VSPrefs.FLOAT_PREFIX + key); + for (String key : longKeys) fullKeys.add(VSPrefs.LONG_PREFIX + key); + for (String key : booleanKeys) fullKeys.add(VSPrefs.BOOLEAN_PREFIX + key); + for (String key : stringKeys) fullKeys.add(VSPrefs.STRING_PREFIX + key); + + Collections.sort(fullKeys); + + for (String fullKey : fullKeys) { + String key = fullKey.substring(fullKey.indexOf(": ") + 2); + if (fullKey.startsWith(VSPrefs.INTEGER_PREFIX)) { + VSTupel tupel = + createIntegerComponent(fullKey, key, prefsToAdd); + this.integerKeys.add(prefsKey+key); + this.integerFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + + } else if (fullKey.startsWith(VSPrefs.VECTOR_PREFIX)) { + VSTupel tupel = + createVectorComponent(fullKey, key, prefsToAdd); + this.vectorKeys.add(prefsKey+key); + this.vectorFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + + } else if (fullKey.startsWith(VSPrefs.BOOLEAN_PREFIX)) { + VSTupel tupel = + createBooleanComponent(fullKey, key, prefsToAdd); + this.booleanKeys.add(prefsKey + key); + this.booleanFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + + } else if (fullKey.startsWith(VSPrefs.LONG_PREFIX)) { + VSTupel tupel = + createLongComponent(fullKey, key, prefsToAdd); + this.longKeys.add(prefsKey+key); + this.longFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + + } else if (fullKey.startsWith(VSPrefs.FLOAT_PREFIX)) { + VSTupel tupel = + createFloatComponent(fullKey, key, prefsToAdd); + this.floatKeys.add(prefsKey + key); + this.floatFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + + } else if (fullKey.startsWith(VSPrefs.STRING_PREFIX)) { + VSTupel tupel = + createStringComponent(fullKey, key, prefsToAdd); + this.stringKeys.add(prefsKey + key); + this.stringFields.put(prefsKey+key, tupel.getC()); + addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); + } + + } + } + + /** + * Adds the separator. + * + * @param label the label + */ + private void addSeparator(String label) { + editTable.addSeparator(label); + } + + /** + * Adds the variable. + * + * @param label the label + * @param component the component + * @param prefs the prefs + */ + private void addVariable(String label, Component component, VSPrefs prefs) { + addVariable("", label, component, prefs); + } + + /** + * Adds the variable. + * + * @param prefsKey the prefs key + * @param label the label + * @param component the component + * @param prefs the prefs + */ + private void addVariable(String prefsKey, String label, Component component, VSPrefs prefs) { + prefsToEditMap.put(prefsKey, prefs); + editTable.addVariable(label, component); + } + + /** + * Reset edit panel. + */ + protected void resetPrefs() { + for (String key : integerKeys) { + JComboBox valComboBox = integerFields.get(key); + valComboBox.setSelectedIndex(0); + } + + for (String key : booleanKeys) { + String keys[] = getKeys(key); + JCheckBox valField = booleanFields.get(key); + valField.setSelected(prefsToEditMap.get(keys[1]).getBoolean(keys[0])); + } + + for (String key : vectorKeys) { + String keys[] = getKeys(key); + JTextField valField = vectorFields.get(key); + valField.setText(""+prefsToEditMap.get(keys[1]).getVector(keys[0])); + } + + for (String key : floatKeys) { + String keys[] = getKeys(key); + JTextField valField = floatFields.get(key); + valField.setText(""+prefsToEditMap.get(keys[1]).getFloat(keys[0])); + } + + for (String key : longKeys) { + String keys[] = getKeys(key); + JTextField valField = longFields.get(key); + valField.setText(""+prefsToEditMap.get(keys[1]).getLong(keys[0])); + } + + for (String key : colorKeys) { + String keys[] = getKeys(key); + JTextField valField = colorFields.get(key); + valField.setBackground(prefsToEditMap.get(keys[1]).getColor(keys[0])); + } + + for (String key : stringKeys) { + String keys[] = getKeys(key); + JTextField valField = stringFields.get(keys); + valField.setText(prefsToEditMap.get(keys[1]).getString(keys[0])); + } + } + + /** + * Gets the keys. + * + * @param key the key + * + * @return [0] := key, [1] := prefsKey + */ + private String[] getKeys(String key) { + String keys[] = { key, "" }; + + if (key.startsWith("(")) { + keys[1] = key.substring(0, key.indexOf(")") + 1); + keys[0] = key.substring(key.indexOf(")")+1); + } + + return keys; + } + + /** + * Save prefs. + */ + protected void savePrefs() { + boolean expertMode = prefs.getBoolean("sim.mode.expert"); + + for (String key : integerKeys) { + String keys[] = getKeys(key); + JComboBox valComboBox = integerFields.get(key); + prefsToEditMap.get(keys[1]).setInteger(keys[0], (Integer) valComboBox.getSelectedItem()); + } + + for (String key : vectorKeys) { + String keys[] = getKeys(key); + JTextField valField = vectorFields.get(key); + + try { + String val = valField.getText(); + Vector vec = utils.VSTools.parseIntegerVector(val); + prefsToEditMap.get(keys[1]).setVector(keys[0], vec); + } catch (exceptions.ParseIntegerVectorException e) { + } + + valField.setText(""+prefsToEditMap.get(keys[1]).getVector(keys[0])); + } + + for (String key : booleanKeys) { + String keys[] = getKeys(key); + JCheckBox valField = booleanFields.get(key); + prefsToEditMap.get(keys[1]).setBoolean(keys[0], valField.isSelected()); + } + + for (String key : floatKeys) { + String keys[] = getKeys(key); + JTextField valField = floatFields.get(key); + + try { + Float val = Float.valueOf(valField.getText()); + prefsToEditMap.get(keys[1]).setFloat(keys[0], val); + + } catch (NumberFormatException e) { + valField.setText(""+prefsToEditMap.get(keys[1]).getFloat(keys[0])); + } + } + + for (String key : longKeys) { + String keys[] = getKeys(key); + JTextField valField = longFields.get(key); + + try { + Long val = Long.valueOf(valField.getText()); + prefsToEditMap.get(keys[1]).setLong(keys[0], val); + + } catch (NumberFormatException e) { + valField.setText(""+prefsToEditMap.get(keys[1]).getLong(keys[0])); + } + } + + for (String key : colorKeys) { + String keys[] = getKeys(key); + JTextField valField = colorFields.get(key); + prefsToEditMap.get(keys[1]).setColor(keys[0], valField.getBackground()); + } + + for (String key : stringKeys) { + String keys[] = getKeys(key); + JTextField valField = stringFields.get(key); + prefsToEditMap.get(keys[1]).setString(keys[0], valField.getText()); + } + + expertModeChanged = expertMode != prefs.getBoolean("sim.mode.expert"); + } + + /** + * Expert mode changed. + * + * @return true, if successful + */ + public boolean expertModeChanged() { + boolean ret = expertModeChanged; + + if (expertModeChanged) + expertModeChanged = false; + + return ret; + } + + /* (non-Javadoc) + * @see java.awt.event.ActionListener#actionPerformed(java.awt.event.ActionEvent) + */ + public void actionPerformed(ActionEvent e) { + String actionCommand = e.getActionCommand(); + + if (actionCommand.equals(prefs.getString("lang.takeover"))) { + savePrefs(); + + } else if (actionCommand.equals(prefs.getString("lang.reset"))) { + resetPrefs(); + } + } + + /** + * Gets the edits the panel. + * + * @return the edits the panel + */ + public JPanel getEditPanel() { + return editPanel; + } + + /** + * Gets the edits the table. + * + * @return the edits the table + */ + public VSEditorTable getEditTable() { + return editTable; + } + + /** + * Gets the button panel. + * + * @return the button panel + */ + public JPanel getButtonPanel() { + return buttonPanel; + } +} diff --git a/sources/prefs/editors/VSBetterEditor.java b/sources/prefs/editors/VSBetterEditor.java deleted file mode 100644 index ba15672..0000000 --- a/sources/prefs/editors/VSBetterEditor.java +++ /dev/null @@ -1,116 +0,0 @@ -/* - * VS is (c) 2008 by Paul C. Buetow - * vs@dev.buetow.org - */ -package prefs.editors; - -import java.awt.*; -import java.awt.event.*; -import javax.swing.*; - -import prefs.*; -import utils.*; - -// TODO: Auto-generated Javadoc -/** - * The Class VSBetterEditor. - */ -public abstract class VSBetterEditor extends VSEditor { - private static final long serialVersionUID = 1L; - - /** The content pane. */ - private Container contentPane; - - /** The info area. */ - private VSInfoArea infoArea; - - /** The title. */ - private String title; - - /** - * Instantiates a new lang.process.removebetter editor. - * - * @param prefs the prefs - * @param prefsToEdit the prefs to edit - * @param title the title - */ - public VSBetterEditor(VSPrefs prefs, VSPrefs prefsToEdit, String title) { - super(prefs, prefsToEdit); - this.title = title; - this.contentPane = createContentPane(); - } - - /** - * Gets the title. - * - * @return the title - */ - public String getTitle() { - return title; - } - - /** - * Gets the content pane. - * - * @return the content pane - */ - public Container getContentPane() { - contentPane.setBackground(Color.WHITE); - return contentPane; - } - - /** - * Creates the content pane. - * - * @return the j panel - */ - private JPanel createContentPane() { - JPanel panel = new JPanel(); - panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS)); - - infoArea = new VSInfoArea(); - JPanel editPanel = getEditPanel(); - JPanel buttonPanel = getButtonPanel(); - - JScrollPane scrollPane = new JScrollPane(editPanel); - panel.add(editPanel); - //panel.add(infoArea); - panel.add(buttonPanel); - - return panel; - } - - /* (non-Javadoc) - * @see prefs.editors.VSEditor#addToButtonPanelFront(javax.swing.JPanel) - */ - protected void addToButtonPanelFront(JPanel buttonPanel) { } - - /* (non-Javadoc) - * @see prefs.editors.VSEditor#addToButtonPanelLast(javax.swing.JPanel) - */ - protected void addToButtonPanelLast(JPanel buttonPanel) { } - - /* (non-Javadoc) - * @see prefs.editors.VSEditor#addToEditTableLast() - */ - protected void addToEditTableLast() { } - - /* (non-Javadoc) - * @see prefs.editors.VSEditor#actionPerformed(java.awt.event.ActionEvent) - */ - public void actionPerformed(ActionEvent e) { - //String actionCommand = e.getActionCommand(); - - /* More action in the super class!!! */ - super.actionPerformed(e); - } - - /** - * Gets the info area. - * - * @return the info area - */ - protected VSInfoArea getInfoArea() { - return infoArea; - } -} diff --git a/sources/prefs/editors/VSEditor.java b/sources/prefs/editors/VSEditor.java deleted file mode 100644 index c98434e..0000000 --- a/sources/prefs/editors/VSEditor.java +++ /dev/null @@ -1,938 +0,0 @@ -/* - * VS is (c) 2008 by Paul C. Buetow - * vs@dev.buetow.org - */ -package prefs.editors; - -import java.awt.*; -import java.awt.event.*; -import javax.swing.*; -import java.util.*; - -import utils.*; -import prefs.VSPrefs; - -// TODO: Auto-generated Javadoc -/** - * The Class VSEditor. - */ -public abstract class VSEditor implements ActionListener { - private static final long serialVersionUID = 1L; - - /** The boolean keys. */ - private ArrayList booleanKeys; - - /** The color keys. */ - private ArrayList colorKeys; - - /** The float keys. */ - private ArrayList floatKeys; - - /** The integer keys. */ - private ArrayList integerKeys; - - /** The vector keys. */ - private ArrayList vectorKeys; - - /** The long keys. */ - private ArrayList longKeys; - - /** The string keys. */ - private ArrayList stringKeys; - - /** The boolean fields. */ - private HashMap booleanFields; - - /** The integer fields. */ - private HashMap integerFields; - - /** The vector fields. */ - private HashMap vectorFields; - - /** The color fields. */ - private HashMap colorFields; - - /** The float fields. */ - private HashMap floatFields; - - /** The long fields. */ - private HashMap longFields; - - /** The string fields. */ - private HashMap stringFields; - - /** The prefs to edit map. */ - private HashMap prefsToEditMap; - - /** The button panel. */ - private JPanel buttonPanel; - - /** The edit panel. */ - private JPanel editPanel; - - /** The edit table. */ - private VSEditorTable editTable; - - /** The frame. */ - private VSFrame frame; - - /** The expert mode changed. */ - private boolean expertModeChanged; - - /** The prefs. */ - protected VSPrefs prefs; - - /** The prefs to edit. */ - protected VSPrefs prefsToEdit; - - /** The Constant MIN_UNIT_LENGTH. */ - protected static final int MIN_UNIT_LENGTH = 5; - - /** The Constant VALUE_FIELD_COLS. */ - protected static final int VALUE_FIELD_COLS = 9; - - /** The Constant ALL_PREFERENCES. */ - public static final int ALL_PREFERENCES = 0; - - /** The Constant SIMULATION_PREFERENCES. */ - public static final int SIMULATION_PREFERENCES = 1; - - /** - * Instantiates a new lang.process.removeeditor. - * - * @param prefs the prefs - * @param prefsToEdit the prefs to edit - */ - public VSEditor(VSPrefs prefs, VSPrefs prefsToEdit) { - init(prefs, prefsToEdit); - } - - /** - * Adds the to button panel front. - * - * @param buttonPanel the button panel - */ - abstract protected void addToButtonPanelFront(JPanel buttonPanel); - - /** - * Adds the to button panel last. - * - * @param buttonPanel the button panel - */ - abstract protected void addToButtonPanelLast(JPanel buttonPanel); - - /** - * Adds the to edit table last. - */ - abstract protected void addToEditTableLast(); - - /** - * Sets the prefs. - * - * @param prefs the new prefs - */ - public void setPrefs(VSPrefs prefs) { - this.prefs = prefs; - } - - /** - * Sets the prefs to edit. - * - * @param prefsToEdit the new prefs to edit - */ - public void setPrefsToEdit(VSPrefs prefsToEdit) { - this.prefsToEdit = prefsToEdit; - } - - /** - * Sets the frame. - * - * @param frame the new frame - */ - public void setFrame(VSFrame frame) { - this.frame = frame; - } - - /** - * Gets the frame. - * - * @return the frame - */ - public VSFrame getFrame() { - return frame; - } - - /** - * Dispose frame if exists. - */ - protected void disposeFrameIfExists() { - if (frame != null) - frame.dispose(); - } - - /** - * Dispose frame with parent if exists. - */ - protected void disposeFrameWithParentIfExists() { - if (frame != null) - frame.disposeWithParent(); - } - - /** - * Inits the. - * - * @param prefs the prefs - * @param prefsToEdit the prefs to edit - */ - private void init(VSPrefs prefs, VSPrefs prefsToEdit) { - this.prefs = prefs; - this.prefsToEdit = prefsToEdit; - - editPanel = createEditPanel(); - buttonPanel = createButtonPanel(); - - prefsToEditMap = new HashMap(); - - colorFields = new HashMap(); - floatFields = new HashMap(); - integerFields = new HashMap(); - vectorFields = new HashMap(); - longFields = new HashMap(); - booleanFields = new HashMap(); - stringFields = new HashMap(); - - colorKeys = filterKeys(prefsToEdit.getColorKeySet()); - floatKeys = filterKeys(prefsToEdit.getFloatKeySet()); - integerKeys = filterKeys(prefsToEdit.getIntegerKeySet()); - vectorKeys = filterKeys(prefsToEdit.getVectorKeySet()); - longKeys = filterKeys(prefsToEdit.getLongKeySet()); - booleanKeys = filterKeys(prefsToEdit.getBooleanKeySet()); - stringKeys = filterKeys(prefsToEdit.getStringKeySet()); - - fillEditPanel(prefsToEdit); - } - - /** - * Filter keys. - * - * @param set the set - * - * @return the array list< string> - */ - private ArrayList filterKeys(Set set) { - ArrayList filtered = new ArrayList(); - boolean expertMode = prefs.getBoolean("sim.mode.expert"); - - for (String elem : set) { - if (!elem.startsWith("lang.") && !elem.startsWith("keyevent")) { - if (expertMode) - filtered.add(elem); - else if (!elem.startsWith("col.") && (!elem.startsWith("div."))) - filtered.add(elem); - } - } - - return filtered; - } - - /** - * Creates the button panel. - * - * @return the j panel - */ - private JPanel createButtonPanel() { - JPanel buttonPanel = new JPanel(); - buttonPanel.setBackground(Color.WHITE); - addToButtonPanelFront(buttonPanel); - - JButton resetButton = new JButton( - prefs.getString("lang.reset")); - resetButton.setMnemonic(prefs.getInteger("keyevent.reset")); - resetButton.addActionListener(this); - buttonPanel.add(resetButton); - - addToButtonPanelLast(buttonPanel); - - return buttonPanel; - } - - /** - * Creates the unit panel. - * - * @param comp the comp - * @param key the key - * - * @return the j panel - */ - private JPanel createUnitPanel(VSPrefs prefsToEdit, Component comp, String fullKey) { - JPanel unitPanel = new JPanel(new GridBagLayout()); - unitPanel.setBackground(Color.WHITE); - unitPanel.setBorder(null); - - String unitText = prefsToEdit.getUnit(fullKey); - if (unitText == null) - unitText = ""; - - unitText = " " + unitText; - while (unitText.length() < MIN_UNIT_LENGTH) - unitText = unitText + " "; - JLabel unitLabel = new JLabel(unitText); - - unitPanel.setLayout(new BoxLayout(unitPanel, BoxLayout.X_AXIS)); - unitPanel.add(comp); - unitPanel.add(unitLabel); - - return unitPanel; - } - - /** - * Creates the edit panel. - * - * @return the j panel - */ - private JPanel createEditPanel() { - JPanel editPanel = new JPanel(); - editPanel.setLayout(new BoxLayout(editPanel, BoxLayout.Y_AXIS)); - editPanel.setBackground(Color.WHITE); - - editTable = new VSEditorTable(prefs); - JScrollPane scrollPane = new JScrollPane(editTable); - editPanel.add(scrollPane); - - return editPanel; - } - - /** - * Creates the integer component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - * - * @return the lang.process.removetupel< string, component, j combo box> - */ - protected VSTupel createIntegerComponent(String fullKey, String key, VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - Integer integer = prefsToEdit.getInteger(key); - Integer initialSelection[] = { integer }; - JComboBox valComboBox = new JComboBox(initialSelection); - VSPrefs.VSPrefRestriction settingRestriction = prefsToEdit.getRestriction(fullKey); - - int minValue, maxValue; - if (settingRestriction != null) { - VSPrefs.VSIntegerPrefRestriction integerVSPrefRestriction = - (VSPrefs.VSIntegerPrefRestriction) settingRestriction; - minValue = integerVSPrefRestriction.getMinValue(); - maxValue = integerVSPrefRestriction.getMaxValue(); - - } else { - minValue = 0; - maxValue = 100; - } - - for (int i = minValue; i <= maxValue; ++i) - valComboBox.addItem(new Integer(i)); - valComboBox.setBorder(null); - - return new VSTupel(label, - createUnitPanel(prefsToEdit, valComboBox, fullKey), valComboBox); - } - - /** - * Creates the vector component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - */ - protected VSTupel createVectorComponent(String fullKey, String key, VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - - Vector vec = prefsToEdit.getVector(key); - JTextField valField = new JTextField(); - valField.setBorder(null); - valField.setText(vec.toString()); - - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Creates the boolean component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - */ - protected VSTupel createBooleanComponent(String fullKey, String key, VSPrefs prefsToEdit) { - final String activated = prefs.getString("lang.activated"); - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - JCheckBox valField = new JCheckBox(activated, prefsToEdit.getBoolean(key)); - valField.setBackground(Color.WHITE); - valField.setBorder(null); - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Creates the long component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - * - * @return the lang.process.removetupel< string, component, j text field> - */ - protected VSTupel createLongComponent(String fullKey, String key, VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - JTextField valField = new JTextField(VALUE_FIELD_COLS); - valField.addKeyListener(new java.awt.event.KeyAdapter() { - public void keyTyped(java.awt.event.KeyEvent e) { - JTextField valField = (JTextField)e.getSource(); - if (valField.getText().length() >= valField.getColumns() + 10) - e.consume(); - } - }); - valField.setText(""+prefsToEdit.getLong(key)); - valField.setBorder(null); - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Creates the float component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - * - * @return the lang.process.removetupel< string, component, j text field> - */ - protected VSTupel createFloatComponent(String fullKey, String key, VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - JTextField valField = new JTextField(VALUE_FIELD_COLS); - valField.addKeyListener(new java.awt.event.KeyAdapter() { - public void keyTyped(java.awt.event.KeyEvent e) { - JTextField valField = (JTextField)e.getSource(); - if (valField.getText().length() >= valField.getColumns() + 10) - e.consume(); - } - }); - valField.setText(""+prefsToEdit.getFloat(key)); - valField.setBorder(null); - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Creates the color component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - * - * @return the lang.process.removetupel< string, component, j text field> - */ - protected VSTupel createColorComponent(String fullKey, String key, final VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - final JTextField valField = new JTextField(VALUE_FIELD_COLS); - Color color = prefsToEdit.getColor(key); - valField.setBackground(color); - valField.setEditable(false); - valField.addMouseListener(new MouseListener() { - public void mouseExited(MouseEvent e) { } - public void mouseReleased(MouseEvent e) { } - public void mouseEntered(MouseEvent e) { } - public void mousePressed(MouseEvent e) { } - public void mouseClicked(MouseEvent e) { - JFrame parentFrame = getFrame(); - JFrame frame = new VSFrame( - prefs.getString("lang.name") + " - " + - prefs.getString( - "lang.colorchooser"),parentFrame); - frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); - - JComponent colorChooserPane = new VSColorChooser(prefs, valField); - colorChooserPane.setOpaque(true); - - frame.setContentPane(colorChooserPane); - frame.pack(); - frame.setVisible(true); - } - }); - valField.setBorder(null); - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Creates the string component. - * - * @param fullKey the full key - * @param key the key - * @param prefsToEdit the prefs to edit - * - * @return the lang.process.removetupel< string, component, j text field> - */ - protected VSTupel createStringComponent(String fullKey, String key, VSPrefs prefsToEdit) { - String descr = prefsToEdit.getDescription(fullKey); - String label = descr == null ? fullKey : descr; - JTextField valField = new JTextField(VALUE_FIELD_COLS); - valField.addKeyListener(new java.awt.event.KeyAdapter() { - public void keyTyped(java.awt.event.KeyEvent e) { - JTextField valField = (JTextField)e.getSource(); - if (valField.getText().length() >= valField.getColumns() + 10) - e.consume(); - } - }); - valField.setText(prefsToEdit.getString(key)); - valField.setBorder(null); - return new VSTupel(label, - createUnitPanel(prefsToEdit, valField, fullKey), valField); - } - - /** - * Fill edit panel. - * - * @param prefsToEdit the prefs to edit - */ - private void fillEditPanel(VSPrefs prefsToEdit) { - HashMap components = new HashMap(); - HashMap labels = new HashMap(); - - for (String key : integerKeys) { - String fullKey = VSPrefs.INTEGER_PREFIX + key; - VSTupel tupel = - createIntegerComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - integerFields.put(key, tupel.getC()); - } - - for (String key : vectorKeys) { - String fullKey = VSPrefs.VECTOR_PREFIX + key; - VSTupel tupel = - createVectorComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - vectorFields.put(key, tupel.getC()); - } - - for (String key : booleanKeys) { - String fullKey = VSPrefs.BOOLEAN_PREFIX + key; - VSTupel tupel = createBooleanComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - booleanFields.put(key, tupel.getC()); - } - - for (String key : longKeys) { - String fullKey = VSPrefs.LONG_PREFIX + key; - VSTupel tupel = createLongComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - longFields.put(key, tupel.getC()); - } - - - for (String key : floatKeys) { - String fullKey = VSPrefs.FLOAT_PREFIX + key; - VSTupel tupel = createFloatComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - floatFields.put(key, tupel.getC()); - } - - - for (String key : colorKeys) { - String fullKey = VSPrefs.COLOR_PREFIX + key; - VSTupel tupel = createColorComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - colorFields.put(key, tupel.getC()); - } - - for (String key : stringKeys) { - String fullKey = VSPrefs.STRING_PREFIX + key; - VSTupel tupel = createStringComponent(fullKey, key, prefsToEdit); - labels.put(fullKey, tupel.getA()); - components.put(fullKey, tupel.getB()); - stringFields.put(key, tupel.getC()); - } - - ArrayList fullKeys = new ArrayList(); - fullKeys.addAll(components.keySet()); - Collections.sort(fullKeys); - - boolean flag = false; - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(' ')+1); - if (key.startsWith("sim.")) { - if (!flag) { - flag = true; - addSeparator(prefs.getString("lang.prefs.simulation")); - } - addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); - } - } - - flag = false; - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(' ')+1); - if (key.startsWith("process.")) { - if (!flag) { - flag = true; - addSeparator(prefs.getString("lang.prefs.process")); - } - addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); - } - } - - flag = false; - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(' ')+1); - if (key.startsWith("message.")) { - if (!flag) { - flag = true; - addSeparator(prefs.getString("lang.prefs.message")); - } - addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); - } - } - - flag = false; - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(' ')+1); - if (key.startsWith("col.")) { - if (!flag) { - flag = true; - addSeparator(prefs.getString("lang.prefs.color")); - } - addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); - } - } - - flag = false; - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(' ')+1); - if (key.startsWith("div.")) { - if (!flag) { - flag = true; - addSeparator(prefs.getString("lang.prefs.diverse")); - } - addVariable(labels.get(fullKey), components.get(fullKey), prefsToEdit); - } - } - - addToEditTableLast(); - editTable.fireTableDataChanged(); - } - - /** - * Adds the to editor. - * - * @param label the label - * @param prefsKey the prefs key - * @param prefsToAdd the prefs to add - */ - protected void addToEditor(String label, String prefsKey, VSPrefs prefsToAdd) { - addSeparator(label); - prefsKey = "(" + prefsKey + ")"; - - ArrayList fullKeys = new ArrayList(); - - Set integerKeys = prefsToAdd.getIntegerKeySet(); - Set vectorKeys = prefsToAdd.getVectorKeySet(); - Set floatKeys = prefsToAdd.getFloatKeySet(); - Set longKeys = prefsToAdd.getLongKeySet(); - Set booleanKeys = prefsToAdd.getBooleanKeySet(); - Set stringKeys = prefsToAdd.getStringKeySet(); - - for (String key : integerKeys) fullKeys.add(VSPrefs.INTEGER_PREFIX + key); - for (String key : vectorKeys) fullKeys.add(VSPrefs.VECTOR_PREFIX + key); - for (String key : floatKeys) fullKeys.add(VSPrefs.FLOAT_PREFIX + key); - for (String key : longKeys) fullKeys.add(VSPrefs.LONG_PREFIX + key); - for (String key : booleanKeys) fullKeys.add(VSPrefs.BOOLEAN_PREFIX + key); - for (String key : stringKeys) fullKeys.add(VSPrefs.STRING_PREFIX + key); - - Collections.sort(fullKeys); - - for (String fullKey : fullKeys) { - String key = fullKey.substring(fullKey.indexOf(": ") + 2); - if (fullKey.startsWith(VSPrefs.INTEGER_PREFIX)) { - VSTupel tupel = - createIntegerComponent(fullKey, key, prefsToAdd); - this.integerKeys.add(prefsKey+key); - this.integerFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - - } else if (fullKey.startsWith(VSPrefs.VECTOR_PREFIX)) { - VSTupel tupel = - createVectorComponent(fullKey, key, prefsToAdd); - this.vectorKeys.add(prefsKey+key); - this.vectorFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - - } else if (fullKey.startsWith(VSPrefs.BOOLEAN_PREFIX)) { - VSTupel tupel = - createBooleanComponent(fullKey, key, prefsToAdd); - this.booleanKeys.add(prefsKey + key); - this.booleanFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - - } else if (fullKey.startsWith(VSPrefs.LONG_PREFIX)) { - VSTupel tupel = - createLongComponent(fullKey, key, prefsToAdd); - this.longKeys.add(prefsKey+key); - this.longFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - - } else if (fullKey.startsWith(VSPrefs.FLOAT_PREFIX)) { - VSTupel tupel = - createFloatComponent(fullKey, key, prefsToAdd); - this.floatKeys.add(prefsKey + key); - this.floatFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - - } else if (fullKey.startsWith(VSPrefs.STRING_PREFIX)) { - VSTupel tupel = - createStringComponent(fullKey, key, prefsToAdd); - this.stringKeys.add(prefsKey + key); - this.stringFields.put(prefsKey+key, tupel.getC()); - addVariable(prefsKey, tupel.getA(), tupel.getB(), prefsToAdd); - } - - } - } - - /** - * Adds the separator. - * - * @param label the label - */ - private void addSeparator(String label) { - editTable.addSeparator(label); - } - - /** - * Adds the variable. - * - * @param label the label - * @param component the component - * @param prefs the prefs - */ - private void addVariable(String label, Component component, VSPrefs prefs) { - addVariable("", label, component, prefs); - } - - /** - * Adds the variable. - * - * @param prefsKey the prefs key - * @param label the label - * @param component the component - * @param prefs the prefs - */ - private void addVariable(String prefsKey, String label, Component component, VSPrefs prefs) { - prefsToEditMap.put(prefsKey, prefs); - editTable.addVariable(label, component); - } - - /** - * Reset edit panel. - */ - protected void resetPrefs() { - for (String key : integerKeys) { - JComboBox valComboBox = integerFields.get(key); - valComboBox.setSelectedIndex(0); - } - - for (String key : booleanKeys) { - String keys[] = getKeys(key); - JCheckBox valField = booleanFields.get(key); - valField.setSelected(prefsToEditMap.get(keys[1]).getBoolean(keys[0])); - } - - for (String key : vectorKeys) { - String keys[] = getKeys(key); - JTextField valField = vectorFields.get(key); - valField.setText(""+prefsToEditMap.get(keys[1]).getVector(keys[0])); - } - - for (String key : floatKeys) { - String keys[] = getKeys(key); - JTextField valField = floatFields.get(key); - valField.setText(""+prefsToEditMap.get(keys[1]).getFloat(keys[0])); - } - - for (String key : longKeys) { - String keys[] = getKeys(key); - JTextField valField = longFields.get(key); - valField.setText(""+prefsToEditMap.get(keys[1]).getLong(keys[0])); - } - - for (String key : colorKeys) { - String keys[] = getKeys(key); - JTextField valField = colorFields.get(key); - valField.setBackground(prefsToEditMap.get(keys[1]).getColor(keys[0])); - } - - for (String key : stringKeys) { - String keys[] = getKeys(key); - JTextField valField = stringFields.get(keys); - valField.setText(prefsToEditMap.get(keys[1]).getString(keys[0])); - } - } - - /** - * Gets the keys. - * - * @param key the key - * - * @return [0] := key, [1] := prefsKey - */ - private String[] getKeys(String key) { - String keys[] = { key, "" }; - - if (key.startsWith("(")) { - keys[1] = key.substring(0, key.indexOf(")") + 1); - keys[0] = key.substring(key.indexOf(")")+1); - } - - return keys; - } - - /** - * Save prefs. - */ - protected void savePrefs() { - boolean expertMode = prefs.getBoolean("sim.mode.expert"); - - for (String key : integerKeys) { - String keys[] = getKeys(key); - JComboBox valComboBox = integerFields.get(key); - prefsToEditMap.get(keys[1]).setInteger(keys[0], (Integer) valComboBox.getSelectedItem()); - } - - for (String key : vectorKeys) { - String keys[] = getKeys(key); - JTextField valField = vectorFields.get(key); - - try { - String val = valField.getText(); - Vector vec = utils.VSTools.parseIntegerVector(val); - prefsToEditMap.get(keys[1]).setVector(keys[0], vec); - } catch (exceptions.ParseIntegerVectorException e) { - } - - valField.setText(""+prefsToEditMap.get(keys[1]).getVector(keys[0])); - } - - for (String key : booleanKeys) { - String keys[] = getKeys(key); - JCheckBox valField = booleanFields.get(key); - prefsToEditMap.get(keys[1]).setBoolean(keys[0], valField.isSelected()); - } - - for (String key : floatKeys) { - String keys[] = getKeys(key); - JTextField valField = floatFields.get(key); - - try { - Float val = Float.valueOf(valField.getText()); - prefsToEditMap.get(keys[1]).setFloat(keys[0], val); - - } catch (NumberFormatException e) { - valField.setText(""+prefsToEditMap.get(keys[1]).getFloat(keys[0])); - } - } - - for (String key : longKeys) { - String keys[] = getKeys(key); - JTextField valField = longFields.get(key); - - try { - Long val = Long.valueOf(valField.getText()); - prefsToEditMap.get(keys[1]).setLong(keys[0], val); - - } catch (NumberFormatException e) { - valField.setText(""+prefsToEditMap.get(keys[1]).getLong(keys[0])); - } - } - - for (String key : colorKeys) { - String keys[] = getKeys(key); - JTextField valField = colorFields.get(key); - prefsToEditMap.get(keys[1]).setColor(keys[0], valField.getBackground()); - } - - for (String key : stringKeys) { - String keys[] = getKeys(key); - JTextField valField = stringFields.get(key); - prefsToEditMap.get(keys[1]).setString(keys[0], valField.getText()); - } - - expertModeChanged = expertMode != prefs.getBoolean("sim.mode.expert"); - } - - /** - * Expert mode changed. - * - * @return true, if successful - */ - public boolean expertModeChanged() { - boolean ret = expertModeChanged; - - if (expertModeChanged) - expertModeChanged = false; - - return ret; - } - - /* (non-Javadoc) - * @see java.awt.event.ActionListener#actionPerformed(java.awt.event.ActionEvent) - */ - public void actionPerformed(ActionEvent e) { - String actionCommand = e.getActionCommand(); - - if (actionCommand.equals(prefs.getString("lang.takeover"))) { - savePrefs(); - - } else if (actionCommand.equals(prefs.getString("lang.reset"))) { - resetPrefs(); - } - } - - /** - * Gets the edits the panel. - * - * @return the edits the panel - */ - public JPanel getEditPanel() { - return editPanel; - } - - /** - * Gets the edits the table. - * - * @return the edits the table - */ - public VSEditorTable getEditTable() { - return editTable; - } - - /** - * Gets the button panel. - * - * @return the button panel - */ - public JPanel getButtonPanel() { - return buttonPanel; - } -} diff --git a/sources/prefs/editors/VSEditorFrame.java b/sources/prefs/editors/VSEditorFrame.java index 268afd3..de3f8fa 100644 --- a/sources/prefs/editors/VSEditorFrame.java +++ b/sources/prefs/editors/VSEditorFrame.java @@ -19,7 +19,7 @@ public class VSEditorFrame extends VSFrame implements ActionListener { private static final long serialVersionUID = 1L; /** The editor. */ - private VSBetterEditor editor; + private VSAbstractBetterEditor editor; /** The prefs. */ private VSPrefs prefs; @@ -31,7 +31,7 @@ public class VSEditorFrame extends VSFrame implements ActionListener { * @param relativeTo the relative to * @param editor the editor */ - public VSEditorFrame(VSPrefs prefs, Component relativeTo, VSBetterEditor editor) { + public VSEditorFrame(VSPrefs prefs, Component relativeTo, VSAbstractBetterEditor editor) { super(editor.getTitle(), relativeTo); this.prefs = prefs; this.editor = editor; diff --git a/sources/prefs/editors/VSProcessEditor.java b/sources/prefs/editors/VSProcessEditor.java index 664cafa..8666fbe 100644 --- a/sources/prefs/editors/VSProcessEditor.java +++ b/sources/prefs/editors/VSProcessEditor.java @@ -17,7 +17,7 @@ import prefs.VSPrefs; /** * The Class VSProcessEditor. */ -public class VSProcessEditor extends VSBetterEditor { +public class VSProcessEditor extends VSAbstractBetterEditor { private static final long serialVersionUID = 1L; /** The process. */ @@ -40,7 +40,7 @@ public class VSProcessEditor extends VSBetterEditor { } /* (non-Javadoc) - * @see prefs.editors.VSBetterEditor#addToButtonPanelFront(javax.swing.JPanel) + * @see prefs.editors.VSAbstractBetterEditor#addToButtonPanelFront(javax.swing.JPanel) */ protected void addToButtonPanelFront(JPanel buttonPanel) { JButton takeoverButton = new JButton( @@ -60,13 +60,13 @@ public class VSProcessEditor extends VSBetterEditor { String protocolString = " " + prefs.getString("lang.protocol"); for (String protocolClassname : editableProtocolsClassnames) { String protocolShortname = VSRegisteredEvents.getShortname(protocolClassname); - VSProtocol protocol = process.getProtocolObject(protocolClassname); + VSAbstractProtocol protocol = process.getProtocolObject(protocolClassname); addToEditor(protocolShortname + protocolString, protocolShortname, protocol); } } /* (non-Javadoc) - * @see prefs.editors.VSBetterEditor#actionPerformed(java.awt.event.ActionEvent) + * @see prefs.editors.VSAbstractBetterEditor#actionPerformed(java.awt.event.ActionEvent) */ public void actionPerformed(ActionEvent e) { String actionCommand = e.getActionCommand(); diff --git a/sources/prefs/editors/VSSimulatorEditor.java b/sources/prefs/editors/VSSimulatorEditor.java index 615a8ff..326ca95 100644 --- a/sources/prefs/editors/VSSimulatorEditor.java +++ b/sources/prefs/editors/VSSimulatorEditor.java @@ -14,7 +14,7 @@ import prefs.*; /** * The Class VSSimulatorEditor. */ -public class VSSimulatorEditor extends VSBetterEditor { +public class VSSimulatorEditor extends VSAbstractBetterEditor { private static final long serialVersionUID = 1L; /** The simulator frame. */ @@ -57,7 +57,7 @@ public class VSSimulatorEditor extends VSBetterEditor { } /* (non-Javadoc) - * @see prefs.editors.VSBetterEditor#addToButtonPanelFront(javax.swing.JPanel) + * @see prefs.editors.VSAbstractBetterEditor#addToButtonPanelFront(javax.swing.JPanel) */ protected void addToButtonPanelFront(JPanel buttonPanel) { if (TAKEOVER_BUTTON) { @@ -71,7 +71,7 @@ public class VSSimulatorEditor extends VSBetterEditor { } /* (non-Javadoc) - * @see prefs.editors.VSBetterEditor#actionPerformed(java.awt.event.ActionEvent) + * @see prefs.editors.VSAbstractBetterEditor#actionPerformed(java.awt.event.ActionEvent) */ public void actionPerformed(ActionEvent e) { String actionCommand = e.getActionCommand(); -- cgit v1.2.3