Add scaling option to OBJ export dialog
This commit is contained in:
		
							parent
							
								
									e6a8d1bbf7
								
							
						
					
					
						commit
						467dbce4a1
					
				| @ -1494,13 +1494,15 @@ OBJOptionChooser.checkbox.exportAppearance = Export appearance | |||||||
| OBJOptionChooser.checkbox.exportAppearance.ttip = If true, export the component appearances to an MTL file. | OBJOptionChooser.checkbox.exportAppearance.ttip = If true, export the component appearances to an MTL file. | ||||||
| OBJOptionChooser.checkbox.exportAsSeparateFiles = Export as separate files | OBJOptionChooser.checkbox.exportAsSeparateFiles = Export as separate files | ||||||
| OBJOptionChooser.checkbox.exportAsSeparateFiles.ttip = If true, export each component as a separate OBJ file. | OBJOptionChooser.checkbox.exportAsSeparateFiles.ttip = If true, export each component as a separate OBJ file. | ||||||
| OBJOptionChooser.checkbox.removeOffset = Remove offset | OBJOptionChooser.checkbox.removeOffset = Remove origin offset | ||||||
| OBJOptionChooser.checkbox.removeOffset.ttip = <html>If true, remove the offset of the component from the origin.<br>If false, the component is exported at its original location in the rocket.</html> | OBJOptionChooser.checkbox.removeOffset.ttip = <html>If true, remove the offset of the component from the origin.<br>If false, the component is exported at its original location in the rocket.</html> | ||||||
| OBJOptionChooser.btn.showAdvanced = Show Advanced options | OBJOptionChooser.btn.showAdvanced = Show Advanced options | ||||||
| OBJOptionChooser.checkbox.triangulate = Triangulate mesh | OBJOptionChooser.checkbox.triangulate = Triangulate mesh | ||||||
| OBJOptionChooser.checkbox.triangulate.ttip = If true, triangulate the mesh before exporting (convert all quads or high-order polygons to a triangle). | OBJOptionChooser.checkbox.triangulate.ttip = If true, triangulate the mesh before exporting (convert all quads or high-order polygons to a triangle). | ||||||
| OBJOptionChooser.checkbox.sRGB = Export colors in sRGB | OBJOptionChooser.checkbox.sRGB = Export colors in sRGB | ||||||
| OBJOptionChooser.checkbox.sRGB.ttip = <html>If true, export colors in sRGB instead of a linear color scheme.<br>Is useful for instance when exporting for use in Blender.</html> | OBJOptionChooser.checkbox.sRGB.ttip = <html>If true, export colors in sRGB instead of a linear color scheme.<br>Is useful for instance when exporting for use in Blender.</html> | ||||||
|  | OBJOptionChooser.lbl.Scaling = Scaling: | ||||||
|  | OBJOptionChooser.lbl.Scaling.ttip = <html>Scale the exported geometry by the given factor.<br>The default dimensions are in SI units (meters), but e.g. 3D printing slicer software often uses mm.<br>In that scenario, you can set the scale to '1000'.</html> | ||||||
| OBJOptionChooser.lbl.LevelOfDetail = Level of detail: | OBJOptionChooser.lbl.LevelOfDetail = Level of detail: | ||||||
| OBJOptionChooser.lbl.LevelOfDetail.ttip = Select the desired level of detail of the geometry export. | OBJOptionChooser.lbl.LevelOfDetail.ttip = Select the desired level of detail of the geometry export. | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -116,10 +116,18 @@ public class OBJExportOptions { | |||||||
|         return scaling; |         return scaling; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public double getScalingDouble() { | ||||||
|  |         return scaling; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public void setScaling(float scaling) { |     public void setScaling(float scaling) { | ||||||
|         this.scaling = scaling; |         this.scaling = scaling; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public void setScalingDouble(double scaling) { | ||||||
|  |         this.scaling = (float) scaling; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public boolean isUseSRGB() { |     public boolean isUseSRGB() { | ||||||
|         return useSRGB; |         return useSRGB; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -81,6 +81,8 @@ public class UnitGroup { | |||||||
| 	public static final UnitGroup UNITS_VOLTAGE; | 	public static final UnitGroup UNITS_VOLTAGE; | ||||||
| 	public static final UnitGroup UNITS_CURRENT; | 	public static final UnitGroup UNITS_CURRENT; | ||||||
| 
 | 
 | ||||||
|  | 	public static final UnitGroup UNITS_SCALING; | ||||||
|  | 	 | ||||||
| 	 | 	 | ||||||
| 	public static final Map<String, UnitGroup> UNITS; // keys such as "LENGTH", "VELOCITY" | 	public static final Map<String, UnitGroup> UNITS; // keys such as "LENGTH", "VELOCITY" | ||||||
| 	public static final Map<String, UnitGroup> SIUNITS; // keys such a "m", "m/s" | 	public static final Map<String, UnitGroup> SIUNITS; // keys such a "m", "m/s" | ||||||
| @ -291,6 +293,9 @@ public class UnitGroup { | |||||||
| 		UNITS_COEFFICIENT = new UnitGroup(); | 		UNITS_COEFFICIENT = new UnitGroup(); | ||||||
| 		UNITS_COEFFICIENT.addUnit(new FixedPrecisionUnit("" + ZWSP, 0.001)); // zero-width space | 		UNITS_COEFFICIENT.addUnit(new FixedPrecisionUnit("" + ZWSP, 0.001)); // zero-width space | ||||||
| 
 | 
 | ||||||
|  | 		UNITS_SCALING = new UnitGroup(); | ||||||
|  | 		UNITS_SCALING.addUnit(new FixedPrecisionUnit("" + ZWSP, 0.1)); // zero-width space | ||||||
|  | 		 | ||||||
| 		 | 		 | ||||||
| 		// This is not used by OpenRocket, and not extensively tested: | 		// This is not used by OpenRocket, and not extensively tested: | ||||||
| 		UNITS_FREQUENCY = new UnitGroup(); | 		UNITS_FREQUENCY = new UnitGroup(); | ||||||
| @ -328,6 +333,7 @@ public class UnitGroup { | |||||||
| 		map.put("RELATIVE", UNITS_RELATIVE); | 		map.put("RELATIVE", UNITS_RELATIVE); | ||||||
| 		map.put("ROUGHNESS", UNITS_ROUGHNESS); | 		map.put("ROUGHNESS", UNITS_ROUGHNESS); | ||||||
| 		map.put("COEFFICIENT", UNITS_COEFFICIENT); | 		map.put("COEFFICIENT", UNITS_COEFFICIENT); | ||||||
|  | 		map.put("SCALING", UNITS_SCALING); | ||||||
| 		map.put("VOLTAGE", UNITS_VOLTAGE); | 		map.put("VOLTAGE", UNITS_VOLTAGE); | ||||||
| 		map.put("CURRENT", UNITS_CURRENT); | 		map.put("CURRENT", UNITS_CURRENT); | ||||||
| 		map.put("ENERGY", UNITS_ENERGY); | 		map.put("ENERGY", UNITS_ENERGY); | ||||||
| @ -450,6 +456,7 @@ public class UnitGroup { | |||||||
| 		UNITS_RELATIVE.setDefaultUnit(1); | 		UNITS_RELATIVE.setDefaultUnit(1); | ||||||
| 		UNITS_ROUGHNESS.setDefaultUnit(0); | 		UNITS_ROUGHNESS.setDefaultUnit(0); | ||||||
| 		UNITS_COEFFICIENT.setDefaultUnit(0); | 		UNITS_COEFFICIENT.setDefaultUnit(0); | ||||||
|  | 		UNITS_SCALING.setDefaultUnit(0); | ||||||
| 		UNITS_FREQUENCY.setDefaultUnit(1); | 		UNITS_FREQUENCY.setDefaultUnit(1); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2,16 +2,20 @@ package net.sf.openrocket.file.wavefrontobj; | |||||||
| 
 | 
 | ||||||
| import net.miginfocom.swing.MigLayout; | import net.miginfocom.swing.MigLayout; | ||||||
| import net.sf.openrocket.file.wavefrontobj.export.OBJExportOptions; | import net.sf.openrocket.file.wavefrontobj.export.OBJExportOptions; | ||||||
|  | import net.sf.openrocket.gui.SpinnerEditor; | ||||||
|  | import net.sf.openrocket.gui.adaptors.DoubleModel; | ||||||
| import net.sf.openrocket.l10n.Translator; | import net.sf.openrocket.l10n.Translator; | ||||||
| import net.sf.openrocket.rocketcomponent.ComponentAssembly; | import net.sf.openrocket.rocketcomponent.ComponentAssembly; | ||||||
| import net.sf.openrocket.rocketcomponent.RocketComponent; | import net.sf.openrocket.rocketcomponent.RocketComponent; | ||||||
| import net.sf.openrocket.startup.Application; | import net.sf.openrocket.startup.Application; | ||||||
|  | import net.sf.openrocket.unit.UnitGroup; | ||||||
| 
 | 
 | ||||||
| import javax.swing.JCheckBox; | import javax.swing.JCheckBox; | ||||||
| import javax.swing.JComboBox; | import javax.swing.JComboBox; | ||||||
| import javax.swing.JLabel; | import javax.swing.JLabel; | ||||||
| import javax.swing.JPanel; | import javax.swing.JPanel; | ||||||
| import javax.swing.JSeparator; | import javax.swing.JSeparator; | ||||||
|  | import javax.swing.JSpinner; | ||||||
| import javax.swing.JToggleButton; | import javax.swing.JToggleButton; | ||||||
| import java.awt.event.ItemEvent; | import java.awt.event.ItemEvent; | ||||||
| import java.awt.event.ItemListener; | import java.awt.event.ItemListener; | ||||||
| @ -28,6 +32,7 @@ public class OBJOptionChooser extends JPanel { | |||||||
|     private final JCheckBox triangulate; |     private final JCheckBox triangulate; | ||||||
|     private final JCheckBox sRGB; |     private final JCheckBox sRGB; | ||||||
|     private final JComboBox<ObjUtils.LevelOfDetail> LOD; |     private final JComboBox<ObjUtils.LevelOfDetail> LOD; | ||||||
|  |     private final DoubleModel scalingModel; | ||||||
| 
 | 
 | ||||||
|     private final List<RocketComponent> selectedComponents; |     private final List<RocketComponent> selectedComponents; | ||||||
| 
 | 
 | ||||||
| @ -41,6 +46,11 @@ public class OBJOptionChooser extends JPanel { | |||||||
|         this.exportChildren = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportChildren")); |         this.exportChildren = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportChildren")); | ||||||
|         this.add(exportChildren, "spanx, wrap"); |         this.add(exportChildren, "spanx, wrap"); | ||||||
| 
 | 
 | ||||||
|  |         //// Remove origin offset | ||||||
|  |         this.removeOffset = new JCheckBox(trans.get("OBJOptionChooser.checkbox.removeOffset")); | ||||||
|  |         this.removeOffset.setToolTipText(trans.get("OBJOptionChooser.checkbox.removeOffset.ttip")); | ||||||
|  |         this.add(removeOffset, "spanx, wrap unrel"); | ||||||
|  | 
 | ||||||
|         //// Export appearance |         //// Export appearance | ||||||
|         this.exportAppearance = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportAppearance")); |         this.exportAppearance = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportAppearance")); | ||||||
|         this.exportAppearance.setToolTipText(trans.get("OBJOptionChooser.checkbox.exportAppearance.ttip")); |         this.exportAppearance.setToolTipText(trans.get("OBJOptionChooser.checkbox.exportAppearance.ttip")); | ||||||
| @ -49,12 +59,17 @@ public class OBJOptionChooser extends JPanel { | |||||||
|         //// Export as separate files |         //// Export as separate files | ||||||
|         this.exportAsSeparateFiles = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportAsSeparateFiles")); |         this.exportAsSeparateFiles = new JCheckBox(trans.get("OBJOptionChooser.checkbox.exportAsSeparateFiles")); | ||||||
|         this.exportAsSeparateFiles.setToolTipText(trans.get("OBJOptionChooser.checkbox.exportAsSeparateFiles.ttip")); |         this.exportAsSeparateFiles.setToolTipText(trans.get("OBJOptionChooser.checkbox.exportAsSeparateFiles.ttip")); | ||||||
|         this.add(exportAsSeparateFiles, "spanx, wrap"); |         this.add(exportAsSeparateFiles, "spanx, wrap unrel"); | ||||||
| 
 | 
 | ||||||
|         //// Remove offsets |         //// Scaling | ||||||
|         this.removeOffset = new JCheckBox(trans.get("OBJOptionChooser.checkbox.removeOffset")); |         JLabel scalingLabel = new JLabel(trans.get("OBJOptionChooser.lbl.Scaling")); | ||||||
|         this.removeOffset.setToolTipText(trans.get("OBJOptionChooser.checkbox.removeOffset.ttip")); |         scalingLabel.setToolTipText(trans.get("OBJOptionChooser.lbl.Scaling.ttip")); | ||||||
|         this.add(removeOffset, "spanx, wrap para"); |         this.add(scalingLabel, "spanx, split 2"); | ||||||
|  |         this.scalingModel = new DoubleModel(opts, "ScalingDouble", UnitGroup.UNITS_SCALING, 0, 10000); | ||||||
|  |         JSpinner spin = new JSpinner(scalingModel.getSpinnerModel()); | ||||||
|  |         spin.setToolTipText(trans.get("OBJOptionChooser.lbl.Scaling.ttip")); | ||||||
|  |         spin.setEditor(new SpinnerEditor(spin)); | ||||||
|  |         this.add(spin, "wrap para"); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         // ------------ Advanced options ------------ |         // ------------ Advanced options ------------ | ||||||
| @ -69,27 +84,23 @@ public class OBJOptionChooser extends JPanel { | |||||||
|         advancedOptionsPanel.setLayout(new MigLayout("ins 0")); |         advancedOptionsPanel.setLayout(new MigLayout("ins 0")); | ||||||
|         advancedOptionsPanel.setVisible(false); |         advancedOptionsPanel.setVisible(false); | ||||||
| 
 | 
 | ||||||
|         //// Triangulate |  | ||||||
|         this.triangulate = new JCheckBox(trans.get("OBJOptionChooser.checkbox.triangulate")); |  | ||||||
|         this.triangulate.setToolTipText(trans.get("OBJOptionChooser.checkbox.triangulate.ttip")); |  | ||||||
|         advancedOptionsPanel.add(triangulate, "spanx, wrap"); |  | ||||||
| 
 |  | ||||||
|         //// Export colors in sRGB |         //// Export colors in sRGB | ||||||
|         this.sRGB = new JCheckBox(trans.get("OBJOptionChooser.checkbox.sRGB")); |         this.sRGB = new JCheckBox(trans.get("OBJOptionChooser.checkbox.sRGB")); | ||||||
|         this.sRGB.setToolTipText(trans.get("OBJOptionChooser.checkbox.sRGB.ttip")); |         this.sRGB.setToolTipText(trans.get("OBJOptionChooser.checkbox.sRGB.ttip")); | ||||||
|         advancedOptionsPanel.add(sRGB, "spanx, wrap"); |         advancedOptionsPanel.add(sRGB, "spanx, wrap"); | ||||||
| 
 | 
 | ||||||
|  |         //// Triangulate | ||||||
|  |         this.triangulate = new JCheckBox(trans.get("OBJOptionChooser.checkbox.triangulate")); | ||||||
|  |         this.triangulate.setToolTipText(trans.get("OBJOptionChooser.checkbox.triangulate.ttip")); | ||||||
|  |         advancedOptionsPanel.add(triangulate, "spanx, wrap"); | ||||||
|  | 
 | ||||||
|         //// Level of detail |         //// Level of detail | ||||||
|         JLabel LODLabel = new JLabel(trans.get("OBJOptionChooser.lbl.LevelOfDetail")); |         JLabel LODLabel = new JLabel(trans.get("OBJOptionChooser.lbl.LevelOfDetail")); | ||||||
|         LODLabel.setToolTipText(trans.get("OBJOptionChooser.lbl.LevelOfDetail.ttip")); |         LODLabel.setToolTipText(trans.get("OBJOptionChooser.lbl.LevelOfDetail.ttip")); | ||||||
|         advancedOptionsPanel.add(LODLabel); |         advancedOptionsPanel.add(LODLabel, "spanx, split 2"); | ||||||
|         this.LOD = new JComboBox<>(ObjUtils.LevelOfDetail.values()); |         this.LOD = new JComboBox<>(ObjUtils.LevelOfDetail.values()); | ||||||
|         this.LOD.setToolTipText(trans.get("OBJOptionChooser.lbl.LevelOfDetail.ttip")); |         this.LOD.setToolTipText(trans.get("OBJOptionChooser.lbl.LevelOfDetail.ttip")); | ||||||
|         advancedOptionsPanel.add(LOD, "spanx, wrap para"); |         advancedOptionsPanel.add(LOD, "growx, wrap para"); | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         //// Scale |  | ||||||
|         // TODO: + (add tooltip text that mm is useful for 3D printing) |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         //// Coordinate transformer |         //// Coordinate transformer | ||||||
| @ -131,6 +142,8 @@ public class OBJOptionChooser extends JPanel { | |||||||
|         this.triangulate.setSelected(opts.isTriangulate()); |         this.triangulate.setSelected(opts.isTriangulate()); | ||||||
|         this.sRGB.setSelected(opts.isUseSRGB()); |         this.sRGB.setSelected(opts.isUseSRGB()); | ||||||
| 
 | 
 | ||||||
|  |         this.scalingModel.setValue(opts.getScaling()); | ||||||
|  | 
 | ||||||
|         this.LOD.setSelectedItem(opts.getLOD()); |         this.LOD.setSelectedItem(opts.getLOD()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -151,6 +164,7 @@ public class OBJOptionChooser extends JPanel { | |||||||
|         opts.setRemoveOffset(removeOffset.isSelected()); |         opts.setRemoveOffset(removeOffset.isSelected()); | ||||||
|         opts.setTriangulate(triangulate.isSelected()); |         opts.setTriangulate(triangulate.isSelected()); | ||||||
|         opts.setUseSRGB(sRGB.isSelected()); |         opts.setUseSRGB(sRGB.isSelected()); | ||||||
|  |         opts.setScaling((float) scalingModel.getValue()); | ||||||
|         opts.setLOD((ObjUtils.LevelOfDetail) LOD.getSelectedItem()); |         opts.setLOD((ObjUtils.LevelOfDetail) LOD.getSelectedItem()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user