/* * Open Source Physics software is free software as described near the bottom of this code file. * * For additional information and documentation on Open Source Physics please see: * <http://www.opensourcephysics.org/> */ package org.opensourcephysics.controls; import java.awt.Color; import java.awt.event.ActionEvent; import java.util.HashSet; import java.util.Iterator; import java.util.Set; /** * An AnimationControl that controls the editing of parameters. * * @author Wolfgang Christian * @version 1.0 */ public class SimulationControl extends AnimationControl implements SimControl { Set<String> fixedParameters = new HashSet<String>(); /** * Constructs a SIPAnimationControl for the given animation. * @param animation Animation */ public SimulationControl(Simulation animation) { super(animation); } /** * Sets the fixed property of the given parameter. * Fixed parameters can only be changed before initialization. */ public void setParameterToFixed(String name, boolean fixed) { if(fixed) { this.fixedParameters.add(name); } else { this.fixedParameters.remove(name); } table.refresh(); } /** * Determines if the given parameter is fixed and can only be changed during initialization. * @param name String * @return boolean */ public boolean isParamterFixed(String name) { return fixedParameters.contains(name); } /** * Stores an object in the control * that can only be edited when the control is in initialization mode. * * @param name * @param val */ public void setValue(String name, Object val) { super.setValue(name, val); fixedParameters.add(name); } /** * Stores an object in the control that can be edited after initialization. * * @param name * @param val */ public void setAdjustableValue(String name, Object val) { super.setValue(name, val); fixedParameters.remove(name); } /** * Stores a name and a double value in the control * that can only be edited when the control is in initialization mode. * * @param name * @param val */ public void setValue(String name, double val) { super.setValue(name, val); fixedParameters.add(name); } /** * Stores a double in the control that can be edited after initialization. * * @param name * @param val */ public void setAdjustableValue(String name, double val) { super.setValue(name, val); fixedParameters.remove(name); } /** * Stores a name and an integer value in the control * that can only be edited when the control is in initialization mode. * * @param name * @param val */ public void setValue(String name, int val) { super.setValue(name, val); fixedParameters.add(name); } /** * Stores an integer in the control that can be edited after initialization. * * @param name * @param val */ public void setAdjustableValue(String name, int val) { super.setValue(name, val); fixedParameters.remove(name); } /** * Stores a name and a boolean value in the control * that can only be edited when the control is in initialization mode. * * @param name * @param val */ public void setValue(String name, boolean val) { super.setValue(name, val); fixedParameters.add(name); } /** * Removes a parameter from this control. * * @param name */ public void removeParameter(String name) { super.removeParameter(name); fixedParameters.remove(name); } /** * Stores a boolean in the control that can be edited after initialization. * * @param name * @param val */ public void setAdjustableValue(String name, boolean val) { super.setValue(name, val); fixedParameters.remove(name); } /** * Resets the control by putting the control into its initialization state. * * Fixed parameters are editiable when the control is in the initialization state. * * @param e */ void resetBtnActionPerformed(ActionEvent e) { Iterator<String> it = fixedParameters.iterator(); while(it.hasNext()) { String par = it.next(); table.setEditable(par, true); table.setBackgroundColor(par, Color.WHITE); } table.refresh(); super.resetBtnActionPerformed(e); } /** * Starts, stops, or steps the animation depending on the mode. * * @param e */ void startBtnActionPerformed(ActionEvent e) { if(e.getActionCommand().equals(initText)) { // animation is being initialized and fixed parameters are no longer editable table.setEditable(true); Iterator<String> it = fixedParameters.iterator(); while(it.hasNext()) { String par = it.next(); table.setEditable(par, false); table.setBackgroundColor(par, Control.NOT_EDITABLE_BACKGROUND); } } else if(e.getActionCommand().equals(startText)) { Iterator<String> it = table.getPropertyNames().iterator(); while(it.hasNext()) { String par = it.next(); table.setEditable(par, false); table.setBackgroundColor(par, Control.NOT_EDITABLE_BACKGROUND); } } else if(e.getActionCommand().equals(stopText)) { Iterator<String> it = table.getPropertyNames().iterator(); while(it.hasNext()) { String par = it.next(); if(fixedParameters.contains(par)) { continue; } table.setEditable(par, true); table.setBackgroundColor(par, Color.WHITE); } } table.refresh(); super.startBtnActionPerformed(e); } /** * Returns an XML.ObjectLoader to save and load data for this object. * * @return the object loader */ public static XML.ObjectLoader getLoader() { return new SimulationControlLoader(); } /** * A class to save and load data for OSPControls. */ static class SimulationControlLoader extends AnimationControlLoader { /** * Creates an object using data from an XMLControl. * * @param control the control * @return the newly created object */ public Object createObject(XMLControl control) { return new SimulationControl(null); } /** * Loads an object with data from an XMLControl. * * @param control the control * @param obj the object * @return the loaded object */ public Object loadObject(XMLControl control, Object obj) { SimulationControl sc = (SimulationControl) obj; String[] fixedParm = sc.fixedParameters.toArray(new String[0]); super.loadObject(control, obj); // load the control's parameters and the model sc.fixedParameters.clear(); for(int i = 0, n = fixedParm.length; i<n; i++) { sc.fixedParameters.add(fixedParm[i]); } Iterator<String> it = sc.table.getPropertyNames().iterator(); while(it.hasNext()) { String parm = it.next(); if(sc.fixedParameters.contains(parm)) { continue; } sc.table.setEditable(parm, true); sc.table.setBackgroundColor(parm, Color.WHITE); } if((sc.model instanceof AbstractSimulation)&&(control.getObject("steps per display")!=null)) { //$NON-NLS-1$ ((AbstractSimulation) sc.model).enableStepsPerDisplay(true); ((AbstractSimulation) sc.model).setStepsPerDisplay(Integer.parseInt(control.getString("steps per display"))); //$NON-NLS-1$ } else { ((AbstractSimulation) sc.model).enableStepsPerDisplay(false); } return obj; } } /** * Creates a SIP animation control and establishes communication between the control and the model. * * @param model SIPAnimation * @return AnimationControl */ public static SimulationControl createApp(Simulation model) { SimulationControl control = new SimulationControl(model); model.setControl(control); return control; } /** * Creates a simulation control and establishes communication between the control and the model. * Initial parameters are set using the xml data. * * @param model Simulation * @param xml String[] * @return SimulationControl */ public static SimulationControl createApp(Simulation model, String[] xml) { SimulationControl control = createApp(model); control.loadXML(xml); return control; } } /* * Open Source Physics software is free software; you can redistribute * it and/or modify it under the terms of the GNU General Public License (GPL) as * published by the Free Software Foundation; either version 2 of the License, * or(at your option) any later version. * Code that uses any portion of the code in the org.opensourcephysics package * or any subpackage (subdirectory) of this package must must also be be released * under the GNU GPL license. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston MA 02111-1307 USA * or view the license online at http://www.gnu.org/copyleft/gpl.html * * Copyright (c) 2007 The Open Source Physics project * http://www.opensourcephysics.org */