[fix][partial] Addresses some instances of #329 in NoseCones and Transitions

This commit is contained in:
Daniel_M_Williams 2018-10-15 21:12:04 -04:00
parent f5d786fab6
commit 2ac764b4c3
2 changed files with 180 additions and 197 deletions

View File

@ -44,105 +44,99 @@ public class NoseConeConfig extends RocketComponentConfig {
public NoseConeConfig(OpenRocketDocument d, RocketComponent c) { public NoseConeConfig(OpenRocketDocument d, RocketComponent c) {
super(d, c); super(d, c);
DoubleModel m; final JPanel panel = new JPanel(new MigLayout("", "[][65lp::][30lp::]"));
JPanel panel = new JPanel(new MigLayout("", "[][65lp::][30lp::]"));
//// Shape selection //// Shape selection
//// Nose cone shape: {//// Nose cone shape:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Noseconeshape"))); panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Noseconeshape")));
Transition.Shape selected = ((NoseCone) component).getType(); Transition.Shape selected = ((NoseCone) component).getType();
Transition.Shape[] typeList = Transition.Shape.values(); Transition.Shape[] typeList = Transition.Shape.values();
final JComboBox<Transition.Shape> typeBox = new JComboBox<Transition.Shape>(typeList); final JComboBox<Transition.Shape> typeBox = new JComboBox<Transition.Shape>(typeList);
typeBox.setEditable(false); typeBox.setEditable(false);
typeBox.setSelectedItem(selected); typeBox.setSelectedItem(selected);
typeBox.addActionListener(new ActionListener() { typeBox.addActionListener(new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
Transition.Shape s = (Transition.Shape) typeBox.getSelectedItem(); Transition.Shape s = (Transition.Shape) typeBox.getSelectedItem();
((NoseCone) component).setType(s); ((NoseCone) component).setType(s);
description.setText(PREDESC + s.getNoseConeDescription()); description.setText(PREDESC + s.getNoseConeDescription());
updateEnabled(); updateEnabled();
} }
}); });
panel.add(typeBox, "span, wrap rel"); panel.add(typeBox, "span, wrap rel");
//// Shape parameter:
this.shapeLabel = new JLabel(trans.get("NoseConeCfg.lbl.Shapeparam"));
panel.add(shapeLabel);
final DoubleModel parameterModel = new DoubleModel(component, "ShapeParameter");
this.shapeSpinner = new JSpinner(parameterModel.getSpinnerModel());
shapeSpinner.setEditor(new SpinnerEditor(shapeSpinner));
panel.add(shapeSpinner, "growx");
DoubleModel min = new DoubleModel(component, "ShapeParameterMin");
DoubleModel max = new DoubleModel(component, "ShapeParameterMax");
this.shapeSlider = new BasicSlider(parameterModel.getSliderModel(min, max));
panel.add(shapeSlider, "skip, w 100lp, wrap para");
updateEnabled();
}
{ /// Nose cone length:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Noseconelength")));
final DoubleModel lengthModel = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0);
JSpinner spin = new JSpinner(lengthModel.getSpinnerModel());
spin.setEditor(new SpinnerEditor(spin));
panel.add(spin, "growx");
panel.add(new UnitSelector(lengthModel), "growx");
panel.add(new BasicSlider(lengthModel.getSliderModel(0, 0.1, 0.7)), "w 100lp, wrap");
}
{
/// Base diameter:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Basediam")));
final DoubleModel aftRadiusModel = new DoubleModel(component, "AftRadius", 2.0, UnitGroup.UNITS_LENGTH, 0); // Diameter = 2*Radius
component.addChangeListener(aftRadiusModel);
final JSpinner radiusSpinner = new JSpinner(aftRadiusModel.getSpinnerModel());
radiusSpinner.setEditor(new SpinnerEditor(radiusSpinner));
panel.add(radiusSpinner, "growx");
panel.add(new UnitSelector(aftRadiusModel), "growx");
panel.add(new BasicSlider(aftRadiusModel.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px");
JCheckBox check = new JCheckBox(aftRadiusModel.getAutomaticAction());
//// Automatic
check.setText(trans.get("NoseConeCfg.checkbox.Automatic"));
panel.add(check, "skip, span 2, wrap");
}
{//// Wall thickness:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Wallthickness")));
final DoubleModel thicknessModel = new DoubleModel(component, "Thickness", UnitGroup.UNITS_LENGTH, 0);
component.addChangeListener(thicknessModel);
final JSpinner thicknessSpinner = new JSpinner(thicknessModel.getSpinnerModel());
thicknessSpinner.setEditor(new SpinnerEditor(thicknessSpinner));
panel.add(thicknessSpinner, "growx");
panel.add(new UnitSelector(thicknessModel), "growx");
panel.add(new BasicSlider(thicknessModel.getSliderModel(0, 0.01)), "w 100lp, wrap 0px");
final JCheckBox filledCheckbox = new JCheckBox(new BooleanModel(component, "Filled"));
//// Filled
//// Shape parameter filledCheckbox .setText(trans.get("NoseConeCfg.checkbox.Filled"));
//// Shape parameter: panel.add(filledCheckbox, "skip, span 2, wrap");
shapeLabel = new JLabel(trans.get("NoseConeCfg.lbl.Shapeparam")); }
panel.add(shapeLabel);
m = new DoubleModel(component, "ShapeParameter");
shapeSpinner = new JSpinner(m.getSpinnerModel());
shapeSpinner.setEditor(new SpinnerEditor(shapeSpinner));
panel.add(shapeSpinner, "growx");
DoubleModel min = new DoubleModel(component, "ShapeParameterMin");
DoubleModel max = new DoubleModel(component, "ShapeParameterMax");
shapeSlider = new BasicSlider(m.getSliderModel(min, max));
panel.add(shapeSlider, "skip, w 100lp, wrap para");
updateEnabled();
//// Length
//// Nose cone length:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Noseconelength")));
m = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0);
JSpinner 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(0, 0.1, 0.7)), "w 100lp, wrap");
//// Diameter
//// Base diameter:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Basediam")));
m = new DoubleModel(component, "AftRadius", 2.0, UnitGroup.UNITS_LENGTH, 0); // Diameter = 2*Radius
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(0, 0.04, 0.2)), "w 100lp, wrap 0px");
JCheckBox check = new JCheckBox(m.getAutomaticAction());
//// Automatic
check.setText(trans.get("NoseConeCfg.checkbox.Automatic"));
panel.add(check, "skip, span 2, wrap");
//// Wall thickness:
panel.add(new JLabel(trans.get("NoseConeCfg.lbl.Wallthickness")));
m = new DoubleModel(component, "Thickness", 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(0, 0.01)), "w 100lp, wrap 0px");
check = new JCheckBox(new BooleanModel(component, "Filled"));
//// Filled
check.setText(trans.get("NoseConeCfg.checkbox.Filled"));
panel.add(check, "skip, span 2, wrap");
panel.add(new JLabel(""), "growy"); panel.add(new JLabel(""), "growy");
//// Description //// Description
JPanel panel2 = new JPanel(new MigLayout("ins 0")); JPanel panel2 = new JPanel(new MigLayout("ins 0"));
@ -153,8 +147,6 @@ public class NoseConeConfig extends RocketComponentConfig {
//// Material //// Material
panel2.add(materialPanel( Material.Type.BULK), "span, wrap"); panel2.add(materialPanel( Material.Type.BULK), "span, wrap");
panel.add(panel2, "cell 4 0, gapleft paragraph, aligny 0%, spany"); panel.add(panel2, "cell 4 0, gapleft paragraph, aligny 0%, spany");

View File

@ -45,13 +45,7 @@ public class TransitionConfig extends RocketComponentConfig {
public TransitionConfig(OpenRocketDocument d, RocketComponent c) { public TransitionConfig(OpenRocketDocument d, RocketComponent c) {
super(d, c); super(d, c);
DoubleModel m; final JPanel panel = new JPanel(new MigLayout("gap rel unrel", "[][65lp::][30lp::]", ""));
JSpinner spin;
JCheckBox checkbox;
JPanel panel = new JPanel(new MigLayout("gap rel unrel", "[][65lp::][30lp::]", ""));
//// Shape selection //// Shape selection
//// Transition shape: //// Transition shape:
@ -74,107 +68,106 @@ public class TransitionConfig extends RocketComponentConfig {
}); });
panel.add(typeBox, "span, split 2"); panel.add(typeBox, "span, split 2");
//// Clipped {//// Clipped
checkbox = new JCheckBox(new BooleanModel(component, "Clipped")); final JCheckBox checkbox = new JCheckBox(new BooleanModel(component, "Clipped"));
//// Clipped checkbox.setText(trans.get("TransitionCfg.checkbox.Clipped"));
checkbox.setText(trans.get("TransitionCfg.checkbox.Clipped")); panel.add(checkbox, "wrap");
panel.add(checkbox, "wrap");
//// Shape parameter:
this.shapeLabel = new JLabel(trans.get("TransitionCfg.lbl.Shapeparam"));
panel.add(shapeLabel);
}
//// Shape parameter: {
shapeLabel = new JLabel(trans.get("TransitionCfg.lbl.Shapeparam")); final DoubleModel shapeModel = new DoubleModel(component, "ShapeParameter");
panel.add(shapeLabel);
m = new DoubleModel(component, "ShapeParameter"); this.shapeSpinner = new JSpinner(shapeModel.getSpinnerModel());
shapeSpinner.setEditor(new SpinnerEditor(shapeSpinner));
panel.add(shapeSpinner, "growx");
shapeSpinner = new JSpinner(m.getSpinnerModel()); DoubleModel min = new DoubleModel(component, "ShapeParameterMin");
shapeSpinner.setEditor(new SpinnerEditor(shapeSpinner)); DoubleModel max = new DoubleModel(component, "ShapeParameterMax");
panel.add(shapeSpinner, "growx"); this.shapeSlider = new BasicSlider(shapeModel.getSliderModel(min, max));
panel.add(shapeSlider, "skip, w 100lp, wrap");
DoubleModel min = new DoubleModel(component, "ShapeParameterMin"); updateEnabled();
DoubleModel max = new DoubleModel(component, "ShapeParameterMax"); }
shapeSlider = new BasicSlider(m.getSliderModel(min, max));
panel.add(shapeSlider, "skip, w 100lp, wrap");
updateEnabled(); {/// Transition length:
panel.add(new JLabel(trans.get("TransitionCfg.lbl.Transitionlength")));
//// Length final DoubleModel lengthModel = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0);
//// Transition length:
panel.add(new JLabel(trans.get("TransitionCfg.lbl.Transitionlength")));
m = new DoubleModel(component, "Length", UnitGroup.UNITS_LENGTH, 0); final JSpinner lengthSpinner = new JSpinner(lengthModel.getSpinnerModel());
lengthSpinner.setEditor(new SpinnerEditor(lengthSpinner));
panel.add(lengthSpinner, "growx");
spin = new JSpinner(m.getSpinnerModel()); panel.add(new UnitSelector(lengthModel), "growx");
spin.setEditor(new SpinnerEditor(spin)); panel.add(new BasicSlider(lengthModel.getSliderModel(0, 0.05, 0.3)), "w 100lp, wrap");
panel.add(spin, "growx"); }
panel.add(new UnitSelector(m), "growx"); { /// Fore diameter:
panel.add(new BasicSlider(m.getSliderModel(0, 0.05, 0.3)), "w 100lp, wrap"); panel.add(new JLabel(trans.get("TransitionCfg.lbl.Forediam")));
final DoubleModel foreRadiusModel = new DoubleModel(component, "ForeRadius", 2, UnitGroup.UNITS_LENGTH, 0);
// Diameter = 2*Radius
component.addChangeListener(foreRadiusModel );
//// Transition diameter 1 final JSpinner foreRadiusSpinner = new JSpinner(foreRadiusModel.getSpinnerModel());
//// Fore diameter: foreRadiusSpinner.setEditor(new SpinnerEditor(foreRadiusSpinner));
panel.add(new JLabel(trans.get("TransitionCfg.lbl.Forediam"))); panel.add(foreRadiusSpinner, "growx");
DoubleModel od = new DoubleModel(component, "ForeRadius", 2, UnitGroup.UNITS_LENGTH, 0); panel.add(new UnitSelector(foreRadiusModel), "growx");
// Diameter = 2*Radius panel.add(new BasicSlider(foreRadiusModel.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px");
spin = new JSpinner(od.getSpinnerModel()); final JCheckBox checkbox = new JCheckBox(foreRadiusModel.getAutomaticAction());
spin.setEditor(new SpinnerEditor(spin)); //// Automatic
panel.add(spin, "growx"); checkbox.setText(trans.get("TransitionCfg.checkbox.Automatic"));
panel.add(checkbox, "skip, span 2, wrap");
}
panel.add(new UnitSelector(od), "growx"); { //// Aft diameter:
panel.add(new BasicSlider(od.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px"); panel.add(new JLabel(trans.get("TransitionCfg.lbl.Aftdiam")));
checkbox = new JCheckBox(od.getAutomaticAction()); final DoubleModel aftRadiusModel = new DoubleModel(component, "AftRadius", 2, UnitGroup.UNITS_LENGTH, 0);
//// Automatic // Diameter = 2*Radius
checkbox.setText(trans.get("TransitionCfg.checkbox.Automatic")); component.addChangeListener(aftRadiusModel);
panel.add(checkbox, "skip, span 2, wrap");
final JSpinner aftRadiusSpinner = new JSpinner(aftRadiusModel .getSpinnerModel());
aftRadiusSpinner.setEditor(new SpinnerEditor(aftRadiusSpinner));
panel.add(aftRadiusSpinner, "growx");
//// Transition diameter 2 panel.add(new UnitSelector(aftRadiusModel), "growx");
//// Aft diameter: panel.add(new BasicSlider(aftRadiusModel.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px");
panel.add(new JLabel(trans.get("TransitionCfg.lbl.Aftdiam")));
od = new DoubleModel(component, "AftRadius", 2, UnitGroup.UNITS_LENGTH, 0); final JCheckBox aftRadiusCheckbox = new JCheckBox(aftRadiusModel.getAutomaticAction());
// Diameter = 2*Radius //// Automatic
aftRadiusCheckbox.setText(trans.get("TransitionCfg.checkbox.Automatic"));
panel.add(aftRadiusCheckbox, "skip, span 2, wrap");
}
spin = new JSpinner(od.getSpinnerModel()); { /// Wall thickness:
spin.setEditor(new SpinnerEditor(spin)); panel.add(new JLabel(trans.get("TransitionCfg.lbl.Wallthickness")));
panel.add(spin, "growx");
panel.add(new UnitSelector(od), "growx"); final DoubleModel thicknessModel = new DoubleModel(component, "Thickness", UnitGroup.UNITS_LENGTH, 0);
panel.add(new BasicSlider(od.getSliderModel(0, 0.04, 0.2)), "w 100lp, wrap 0px"); component.addChangeListener(thicknessModel);
checkbox = new JCheckBox(od.getAutomaticAction()); final JSpinner thicknessSpinner = new JSpinner(thicknessModel.getSpinnerModel());
//// Automatic thicknessSpinner.setEditor(new SpinnerEditor(thicknessSpinner));
checkbox.setText(trans.get("TransitionCfg.checkbox.Automatic")); panel.add(thicknessSpinner, "growx");
panel.add(checkbox, "skip, span 2, wrap");
//// Wall thickness:
panel.add(new JLabel(trans.get("TransitionCfg.lbl.Wallthickness")));
m = new DoubleModel(component, "Thickness", 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(0, 0.01)), "w 100lp, wrap 0px");
//// Filled
checkbox = new JCheckBox(new BooleanModel(component, "Filled"));
//// Filled
checkbox.setText(trans.get("TransitionCfg.checkbox.Filled"));
panel.add(checkbox, "skip, span 2, wrap");
panel.add(new UnitSelector(thicknessModel), "growx");
panel.add(new BasicSlider(thicknessModel.getSliderModel(0, 0.01)), "w 100lp, wrap 0px");
//// Filled
final JCheckBox thicknessCheckbox = new JCheckBox(new BooleanModel(component, "Filled"));
//// Filled
thicknessCheckbox.setText(trans.get("TransitionCfg.checkbox.Filled"));
panel.add(thicknessCheckbox, "skip, span 2, wrap");
}
//// Description //// Description
JPanel panel2 = new JPanel(new MigLayout("ins 0")); JPanel panel2 = new JPanel(new MigLayout("ins 0"));
description = new DescriptionArea(5); description = new DescriptionArea(5);
@ -184,8 +177,6 @@ public class TransitionConfig extends RocketComponentConfig {
//// Material //// Material
panel2.add(materialPanel(Material.Type.BULK), "span, wrap"); panel2.add(materialPanel(Material.Type.BULK), "span, wrap");
panel.add(panel2, "cell 4 0, gapleft paragraph, aligny 0%, spany"); panel.add(panel2, "cell 4 0, gapleft paragraph, aligny 0%, spany");