Make the preset combo box display empty when the preset is lost due to changes in parameters.

This commit is contained in:
Kevin Ruland 2012-03-30 21:09:52 +00:00
parent 03209f5e75
commit 35d96f3d53
2 changed files with 65 additions and 70 deletions

View File

@ -4,16 +4,12 @@ import java.util.List;
import javax.swing.AbstractListModel; import javax.swing.AbstractListModel;
import javax.swing.ComboBoxModel; import javax.swing.ComboBoxModel;
import javax.swing.event.ListDataListener;
import net.sf.openrocket.preset.ComponentPreset; import net.sf.openrocket.preset.ComponentPreset;
import net.sf.openrocket.rocketcomponent.ComponentChangeEvent;
import net.sf.openrocket.rocketcomponent.ComponentChangeListener;
import net.sf.openrocket.rocketcomponent.RocketComponent; import net.sf.openrocket.rocketcomponent.RocketComponent;
import net.sf.openrocket.startup.Application; import net.sf.openrocket.startup.Application;
public class BodyTubePresetModel extends AbstractListModel implements public class BodyTubePresetModel extends AbstractListModel implements ComboBoxModel {
ComboBoxModel, ComponentChangeListener {
private final RocketComponent component; private final RocketComponent component;
@ -25,13 +21,18 @@ public class BodyTubePresetModel extends AbstractListModel implements
} }
public static class BodyTubePresetAdapter { public static class BodyTubePresetAdapter {
// If the ComponentPreset bt is null, then no preset is selected.
private ComponentPreset bt; private ComponentPreset bt;
private BodyTubePresetAdapter( ComponentPreset bt ) { private BodyTubePresetAdapter( ComponentPreset bt ) {
this.bt = bt; this.bt = bt;
} }
@Override @Override
public String toString() { public String toString() {
return bt.getManufacturer() + " " + bt.getPartNo(); if ( bt != null ) {
return bt.getManufacturer() + " " + bt.getPartNo();
} else {
return "";
}
} }
@Override @Override
public int hashCode() { public int hashCode() {
@ -65,31 +66,20 @@ public class BodyTubePresetModel extends AbstractListModel implements
@Override @Override
public Object getElementAt(int index) { public Object getElementAt(int index) {
if ( index < 0 ) {
return null;
}
return new BodyTubePresetAdapter(presets.get(index)); return new BodyTubePresetAdapter(presets.get(index));
} }
@Override
public void addListDataListener(ListDataListener l) {
// TODO Auto-generated method stub
}
@Override
public void removeListDataListener(ListDataListener l) {
// TODO Auto-generated method stub
}
@Override
public void componentChanged(ComponentChangeEvent e) {
// TODO Auto-generated method stub
}
@Override @Override
public void setSelectedItem(Object anItem) { public void setSelectedItem(Object anItem) {
BodyTubePresetAdapter selected = (BodyTubePresetAdapter) anItem; BodyTubePresetAdapter selected = (BodyTubePresetAdapter) anItem;
component.loadPreset(selected.bt); if ( selected == null ) {
component.loadPreset(null);
} else {
component.loadPreset(selected.bt);
}
} }
@Override @Override

View File

@ -25,93 +25,93 @@ import net.sf.openrocket.startup.Application;
import net.sf.openrocket.unit.UnitGroup; import net.sf.openrocket.unit.UnitGroup;
public class BodyTubeConfig extends RocketComponentConfig { public class BodyTubeConfig extends RocketComponentConfig {
private ComponentChangeListener listener; private ComponentChangeListener listener;
private MotorConfig motorConfigPane = null; private MotorConfig motorConfigPane = null;
private DoubleModel maxLength;
private JComboBox presetComboBox;
private static final Translator trans = Application.getTranslator(); private static final Translator trans = Application.getTranslator();
public BodyTubeConfig(OpenRocketDocument d, RocketComponent c) { public BodyTubeConfig(OpenRocketDocument d, RocketComponent c) {
super(d, c); super(d, c);
JPanel panel = new JPanel(new MigLayout("gap rel unrel", "[][65lp::][30lp::][]", "")); JPanel panel = new JPanel(new MigLayout("gap rel unrel", "[][65lp::][30lp::][]", ""));
//// Body tube template //// Body tube template
panel.add( new JLabel(trans.get("BodyTubecfg.lbl.Bodytubepreset")) ); panel.add( new JLabel(trans.get("BodyTubecfg.lbl.Bodytubepreset")) );
{ presetComboBox = new JComboBox(new BodyTubePresetModel(component));
JComboBox combo = new JComboBox(new BodyTubePresetModel(component)); panel.add(presetComboBox, "wrap");
panel.add(combo, "wrap");
}
//// Body tube length //// Body tube length
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Bodytubelength"))); panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Bodytubelength")));
final DoubleModel maxLength = new DoubleModel(2.0); maxLength = new DoubleModel(2.0);
DoubleModel length = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0); DoubleModel length = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0);
JSpinner spin = new JSpinner(length.getSpinnerModel()); JSpinner spin = new JSpinner(length.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin)); spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx"); panel.add(spin, "growx");
panel.add(new UnitSelector(length), "growx"); panel.add(new UnitSelector(length), "growx");
panel.add(new BasicSlider(length.getSliderModel(0, 0.5, maxLength)), "w 100lp, wrap"); panel.add(new BasicSlider(length.getSliderModel(0, 0.5, maxLength)), "w 100lp, wrap");
//// Body tube diameter //// Body tube diameter
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Outerdiameter"))); panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Outerdiameter")));
DoubleModel od = new DoubleModel(component, "OuterRadius", 2, UnitGroup.UNITS_LENGTH, 0); DoubleModel od = new DoubleModel(component, "OuterRadius", 2, UnitGroup.UNITS_LENGTH, 0);
// Diameter = 2*Radius // Diameter = 2*Radius
spin = new JSpinner(od.getSpinnerModel()); spin = new JSpinner(od.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin)); spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx"); panel.add(spin, "growx");
panel.add(new UnitSelector(od), "growx"); panel.add(new UnitSelector(od), "growx");
panel.add(new BasicSlider(od.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px"); panel.add(new BasicSlider(od.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px");
JCheckBox check = new JCheckBox(od.getAutomaticAction()); JCheckBox check = new JCheckBox(od.getAutomaticAction());
//// Automatic //// Automatic
check.setText(trans.get("BodyTubecfg.checkbox.Automatic")); check.setText(trans.get("BodyTubecfg.checkbox.Automatic"));
panel.add(check, "skip, span 2, wrap"); panel.add(check, "skip, span 2, wrap");
//// Inner diameter //// Inner diameter
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Innerdiameter"))); panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Innerdiameter")));
// Diameter = 2*Radius // Diameter = 2*Radius
DoubleModel m = new DoubleModel(component, "InnerRadius", 2, UnitGroup.UNITS_LENGTH, 0); DoubleModel m = new DoubleModel(component, "InnerRadius", 2, UnitGroup.UNITS_LENGTH, 0);
spin = new JSpinner(m.getSpinnerModel()); spin = new JSpinner(m.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin)); spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx"); panel.add(spin, "growx");
panel.add(new UnitSelector(m), "growx"); panel.add(new UnitSelector(m), "growx");
panel.add(new BasicSlider(m.getSliderModel(new DoubleModel(0), od)), "w 100lp, wrap"); panel.add(new BasicSlider(m.getSliderModel(new DoubleModel(0), od)), "w 100lp, wrap");
//// Wall thickness //// Wall thickness
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Wallthickness"))); panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Wallthickness")));
m = new DoubleModel(component, "Thickness", UnitGroup.UNITS_LENGTH, 0); m = new DoubleModel(component, "Thickness", UnitGroup.UNITS_LENGTH, 0);
spin = new JSpinner(m.getSpinnerModel()); spin = new JSpinner(m.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin)); spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx"); panel.add(spin, "growx");
panel.add(new UnitSelector(m), "growx"); panel.add(new UnitSelector(m), "growx");
panel.add(new BasicSlider(m.getSliderModel(0, 0.01)), "w 100lp, wrap 0px"); panel.add(new BasicSlider(m.getSliderModel(0, 0.01)), "w 100lp, wrap 0px");
//// Filled //// Filled
check = new JCheckBox(new BooleanModel(component, "Filled")); check = new JCheckBox(new BooleanModel(component, "Filled"));
check.setText(trans.get("BodyTubecfg.checkbox.Filled")); check.setText(trans.get("BodyTubecfg.checkbox.Filled"));
panel.add(check, "skip, span 2, wrap"); panel.add(check, "skip, span 2, wrap");
//// Material //// Material
panel.add(materialPanel(new JPanel(new MigLayout()), Material.Type.BULK), panel.add(materialPanel(new JPanel(new MigLayout()), Material.Type.BULK),
"cell 4 0, gapleft paragraph, aligny 0%, spany"); "cell 4 0, gapleft paragraph, aligny 0%, spany");
//// General and General properties //// General and General properties
tabbedPane.insertTab(trans.get("BodyTubecfg.tab.General"), null, panel, tabbedPane.insertTab(trans.get("BodyTubecfg.tab.General"), null, panel,
trans.get("BodyTubecfg.tab.Generalproperties"), 0); trans.get("BodyTubecfg.tab.Generalproperties"), 0);
@ -120,31 +120,22 @@ public class BodyTubeConfig extends RocketComponentConfig {
tabbedPane.insertTab(trans.get("BodyTubecfg.tab.Motor"), null, motorConfigPane, tabbedPane.insertTab(trans.get("BodyTubecfg.tab.Motor"), null, motorConfigPane,
trans.get("BodyTubecfg.tab.Motormountconf"), 1); trans.get("BodyTubecfg.tab.Motormountconf"), 1);
tabbedPane.setSelectedIndex(0); tabbedPane.setSelectedIndex(0);
// need to work in the max length for body tubes based on presets... // need to work in the max length for body tubes based on presets...
BodyTube bt = (BodyTube) component; adjustPresetState();
if ( bt.getPresetComponent() != null ) {
BodyTube btPreset = (BodyTube) bt.getPresetComponent().getPrototype();
maxLength.setValue( btPreset.getLength() );
}
listener = new ComponentChangeListener() { listener = new ComponentChangeListener() {
@Override @Override
public void componentChanged(ComponentChangeEvent e) { public void componentChanged(ComponentChangeEvent e) {
BodyTube bt = (BodyTube) component; adjustPresetState();
if ( bt.getPresetComponent() != null ) {
BodyTube btPreset = (BodyTube) bt.getPresetComponent().getPrototype();
maxLength.setValue(btPreset.getLength());
}
} }
}; };
component.addChangeListener(listener); component.addChangeListener(listener);
} }
@Override @Override
public void updateFields() { public void updateFields() {
super.updateFields(); super.updateFields();
@ -157,5 +148,19 @@ public class BodyTubeConfig extends RocketComponentConfig {
super.invalidateModels(); super.invalidateModels();
component.removeChangeListener(listener); component.removeChangeListener(listener);
} }
private void adjustPresetState() {
BodyTube bt = (BodyTube) component;
if ( bt.getPresetComponent() != null ) {
BodyTube btPreset = (BodyTube) bt.getPresetComponent().getPrototype();
maxLength.setValue( btPreset.getLength() );
} else {
// here we should be able to force the preset combo box to display empty.
// We set the selected index to -1 (undefined), then force a repaint.
presetComboBox.setSelectedIndex(-1);
presetComboBox.repaint();
maxLength.setValue(2.0);
}
}
} }