import net.miginfocom.swing.MigLayout;
import net.sf.openrocket.document.OpenRocketDocument;
import net.sf.openrocket.gui.SpinnerEditor;
-import net.sf.openrocket.gui.adaptors.BodyTubePresetModel;
import net.sf.openrocket.gui.adaptors.BooleanModel;
import net.sf.openrocket.gui.adaptors.DoubleModel;
+import net.sf.openrocket.gui.adaptors.PresetModel;
import net.sf.openrocket.gui.components.BasicSlider;
import net.sf.openrocket.gui.components.UnitSelector;
import net.sf.openrocket.l10n.Translator;
import net.sf.openrocket.material.Material;
import net.sf.openrocket.rocketcomponent.BodyTube;
-import net.sf.openrocket.rocketcomponent.ComponentChangeEvent;
-import net.sf.openrocket.rocketcomponent.ComponentChangeListener;
import net.sf.openrocket.rocketcomponent.RocketComponent;
import net.sf.openrocket.startup.Application;
import net.sf.openrocket.unit.UnitGroup;
public class BodyTubeConfig extends RocketComponentConfig {
- private ComponentChangeListener listener;
private MotorConfig motorConfigPane = null;
+ private DoubleModel maxLength;
+ private JComboBox presetComboBox;
private static final Translator trans = Application.getTranslator();
public BodyTubeConfig(OpenRocketDocument d, RocketComponent c) {
JPanel panel = new JPanel(new MigLayout("gap rel unrel", "[][65lp::][30lp::][]", ""));
+
+
//// Body tube template
- panel.add( new JLabel(trans.get("BodyTubecfg.lbl.Bodytubepreset")) );
- {
- JComboBox combo = new JComboBox(new BodyTubePresetModel(component));
- panel.add(combo, "wrap");
- }
+ // FIXME: Move to proper location
+ panel.add(new JLabel());
+ presetComboBox = new JComboBox(new PresetModel(component));
+ presetComboBox.setEditable(false);
+ panel.add(presetComboBox, "wrap para");
+
+
//// Body tube length
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);
JSpinner spin = new JSpinner(length.getSpinnerModel());
panel.add(new UnitSelector(length), "growx");
panel.add(new BasicSlider(length.getSliderModel(0, 0.5, maxLength)), "w 100lp, wrap");
-
+
//// Body tube diameter
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Outerdiameter")));
check.setText(trans.get("BodyTubecfg.checkbox.Automatic"));
panel.add(check, "skip, span 2, wrap");
-
+
//// Inner diameter
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Innerdiameter")));
// Diameter = 2*Radius
DoubleModel m = new DoubleModel(component, "InnerRadius", 2, UnitGroup.UNITS_LENGTH, 0);
-
+
spin = new JSpinner(m.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx");
panel.add(new UnitSelector(m), "growx");
panel.add(new BasicSlider(m.getSliderModel(new DoubleModel(0), od)), "w 100lp, wrap");
-
+
//// Wall thickness
panel.add(new JLabel(trans.get("BodyTubecfg.lbl.Wallthickness")));
check.setText(trans.get("BodyTubecfg.checkbox.Filled"));
panel.add(check, "skip, span 2, wrap");
-
+
//// Material
panel.add(materialPanel(new JPanel(new MigLayout()), Material.Type.BULK),
"cell 4 0, gapleft paragraph, aligny 0%, spany");
trans.get("BodyTubecfg.tab.Motormountconf"), 1);
tabbedPane.setSelectedIndex(0);
- // need to work in the max length for body tubes based on presets...
- BodyTube bt = (BodyTube) component;
- if ( bt.getPresetComponent() != null ) {
- BodyTube btPreset = (BodyTube) bt.getPresetComponent().getPrototype();
- maxLength.setValue( btPreset.getLength() );
- }
-
- listener = new ComponentChangeListener() {
-
- @Override
- public void componentChanged(ComponentChangeEvent e) {
- BodyTube bt = (BodyTube) component;
- if ( bt.getPresetComponent() != null ) {
- BodyTube btPreset = (BodyTube) bt.getPresetComponent().getPrototype();
- maxLength.setValue(btPreset.getLength());
- }
-
- }
-
- };
- component.addChangeListener(listener);
}
if (motorConfigPane != null)
motorConfigPane.updateFields();
}
-
- @Override
- public void invalidateModels() {
- super.invalidateModels();
- component.removeChangeListener(listener);
- }
+
+
}