/*
* Copyright (C) 2008-2015 by Holger Arndt
*
* This file is part of the Universal Java Matrix Package (UJMP).
* See the NOTICE file distributed with this work for additional
* information regarding copyright ownership and licensing.
*
* UJMP is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* UJMP 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with UJMP; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301 USA
*/
package org.ujmp.gui.actions;
import java.awt.event.KeyEvent;
import javax.swing.Action;
import javax.swing.JComponent;
import javax.swing.JOptionPane;
import javax.swing.KeyStroke;
import org.ujmp.core.Coordinates;
import org.ujmp.core.Matrix;
import org.ujmp.core.doublematrix.DenseDoubleMatrix2D;
import org.ujmp.core.doublematrix.SparseDoubleMatrix2D;
import org.ujmp.core.enums.ValueType;
import org.ujmp.core.interfaces.GUIObject;
import org.ujmp.gui.util.GUIUtil;
public class NewMatrixAction extends AbstractObjectAction {
private static final long serialVersionUID = 1875202202123788470L;
public NewMatrixAction(JComponent c, GUIObject o) {
super(c, o);
putValue(Action.NAME, "New Matrix...");
putValue(Action.SHORT_DESCRIPTION, "Creates a new empty matrix");
putValue(Action.MNEMONIC_KEY, KeyEvent.VK_N);
putValue(Action.ACCELERATOR_KEY, KeyStroke.getKeyStroke(KeyEvent.VK_N, KeyEvent.CTRL_DOWN_MASK));
}
public Object call() {
try {
boolean isDense = GUIUtil.getBoolean("Should the matrix be dense?");
ValueType valueType = ValueType.values()[JOptionPane.showOptionDialog(getComponent(),
"Select the value type for the new matrix", "Sparse Matrix", JOptionPane.OK_OPTION,
JOptionPane.QUESTION_MESSAGE, null, ValueType.values(), ValueType.DOUBLE)];
long[] size = null;
while (size == null || size.length < 2) {
String s = JOptionPane.showInputDialog(getComponent(), "Enter the size of the new matrix, e.g. 3x5x6",
"Dense Matrix", JOptionPane.QUESTION_MESSAGE);
try {
size = Coordinates.parseString(s);
} catch (Exception e) {
}
}
Matrix m = null;
switch (valueType) {
case DOUBLE:
if (isDense) {
m = DenseDoubleMatrix2D.Factory.zeros(size);
} else {
m = SparseDoubleMatrix2D.Factory.zeros(size);
}
break;
default:
throw new RuntimeException("not implemented");
}
return m;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
}