/* * 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.tools; import java.awt.Dimension; import java.util.List; /** * A FunctionEditor for initial values. * * @author Douglas Brown */ public class InitialValueEditor extends ParamEditor { /** * Default constructor * @param editor */ public InitialValueEditor(ParamEditor editor) { super(); paramEditor = editor; setFunctionPanel(editor.getFunctionPanel()); } /** * Determines if an object's name is editable. * * @param obj the object * @return always false */ public boolean isNameEditable(Object obj) { return false; } /** * Override getPreferredSize(). * * @return the table size, with adjustments */ public Dimension getPreferredSize() { boolean hasButtons = false; for(java.awt.Component c : getComponents()) { if(c==buttonPanel) { hasButtons = true; } } if(hasButtons) { return super.getPreferredSize(); } Dimension dim = table.getPreferredSize(); dim.height += table.getTableHeader().getHeight(); dim.height += 1.25*table.getRowHeight()+14; return dim; } @Override public Dimension getMaximumSize() { Dimension dim = super.getMaximumSize(); dim.height = getPreferredSize().height; return dim; } /** * Evaluates all current objects. */ public void evaluateAll() { super.evaluateAll(); if(paramValues.length!=objects.size()) { paramValues = new double[objects.size()]; } List<Object> params = paramEditor.getObjects(); for(int i = 0; i<evaluate.size(); i++) { Parameter p = (Parameter) evaluate.get(i); p.evaluate(params); } for(int i = 0; i<objects.size(); i++) { Parameter p = (Parameter) objects.get(i); paramValues[i] = p.getValue(); } } /** * Creates the GUI. */ protected void createGUI() { super.createGUI(); remove(buttonPanel); } /** * Refreshes the GUI. */ public void refreshGUI() { super.refreshGUI(); titledBorder.setTitle(ToolsRes.getString("InitialValueEditor.Border.Title")); //$NON-NLS-1$ } /** * Returns a String with the names of variables available for expressions. * Only parameter names are available to initial values. */ protected String getVariablesString(String separator) { StringBuffer vars = new StringBuffer(""); //$NON-NLS-1$ int init = vars.length(); int row = table.getSelectedRow(); if (!"t".equals(table.getValueAt(row, 0))) { //$NON-NLS-1$ // add parameters, if any boolean firstItem = true; String[] paramNames = paramEditor.getNames(); for(int i = 0; i<paramNames.length; i++) { if(!firstItem) { vars.append(" "); //$NON-NLS-1$ } vars.append(paramNames[i]); firstItem = false; } } if(vars.length()==init) { return ToolsRes.getString("FunctionPanel.Instructions.Help"); //$NON-NLS-1$ } return ToolsRes.getString("FunctionPanel.Instructions.ValueCell") //$NON-NLS-1$ +separator+vars.toString(); } } /* * 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 */