diff --git a/engine/src/test-data/Blender/2.4x/BaseMesh_249.blend b/engine/src/test-data/Blender/2.4x/BaseMesh_249.blend new file mode 100644 index 000000000..617711c51 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/BaseMesh_249.blend differ diff --git a/engine/src/test-data/Blender/2.4x/BaseScene.blend b/engine/src/test-data/Blender/2.4x/BaseScene.blend new file mode 100644 index 000000000..a6369071a Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/BaseScene.blend differ diff --git a/engine/src/test-data/Blender/2.4x/MountainValley_Track.blend b/engine/src/test-data/Blender/2.4x/MountainValley_Track.blend new file mode 100644 index 000000000..f2f794f14 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/MountainValley_Track.blend differ diff --git a/engine/src/test-data/Blender/2.4x/ObjectAnimation.blend b/engine/src/test-data/Blender/2.4x/ObjectAnimation.blend new file mode 100644 index 000000000..ea0404c87 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/ObjectAnimation.blend differ diff --git a/engine/src/test-data/Blender/2.4x/SimpleAnimation.blend b/engine/src/test-data/Blender/2.4x/SimpleAnimation.blend new file mode 100644 index 000000000..8ca887d09 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/SimpleAnimation.blend differ diff --git a/engine/src/test-data/Blender/2.4x/Sinbad.blend b/engine/src/test-data/Blender/2.4x/Sinbad.blend new file mode 100644 index 000000000..3737d0085 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/Sinbad.blend differ diff --git a/engine/src/test-data/Blender/2.4x/animtest.blend b/engine/src/test-data/Blender/2.4x/animtest.blend new file mode 100644 index 000000000..9a0df27b8 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/animtest.blend differ diff --git a/engine/src/test-data/Blender/2.4x/constraints.blend b/engine/src/test-data/Blender/2.4x/constraints.blend new file mode 100644 index 000000000..36df26740 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/constraints.blend differ diff --git a/engine/src/test-data/Blender/2.4x/curves.blend b/engine/src/test-data/Blender/2.4x/curves.blend new file mode 100644 index 000000000..9e9b73b1a Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/curves.blend differ diff --git a/engine/src/test-data/Blender/2.4x/kerrigan.blend b/engine/src/test-data/Blender/2.4x/kerrigan.blend new file mode 100644 index 000000000..51b4266eb Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/kerrigan.blend differ diff --git a/engine/src/test-data/Blender/2.4x/kerrigan_diffuse.png b/engine/src/test-data/Blender/2.4x/kerrigan_diffuse.png new file mode 100644 index 000000000..3776ea017 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/kerrigan_diffuse.png differ diff --git a/engine/src/test-data/Blender/2.4x/materials.blend b/engine/src/test-data/Blender/2.4x/materials.blend new file mode 100644 index 000000000..e38be7355 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/materials.blend differ diff --git a/engine/src/test-data/Blender/2.4x/modifiers.blend b/engine/src/test-data/Blender/2.4x/modifiers.blend new file mode 100644 index 000000000..52403dbaf Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/modifiers.blend differ diff --git a/engine/src/test-data/Blender/2.4x/nurbs.blend b/engine/src/test-data/Blender/2.4x/nurbs.blend new file mode 100644 index 000000000..84b291b73 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/nurbs.blend differ diff --git a/engine/src/test-data/Blender/2.4x/particles.blend b/engine/src/test-data/Blender/2.4x/particles.blend new file mode 100644 index 000000000..ba7ee53ee Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/particles.blend differ diff --git a/engine/src/test-data/Blender/2.4x/positions.blend b/engine/src/test-data/Blender/2.4x/positions.blend new file mode 100644 index 000000000..61ede0a57 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/positions.blend differ diff --git a/engine/src/test-data/Blender/2.4x/sinbad_body.tga b/engine/src/test-data/Blender/2.4x/sinbad_body.tga new file mode 100644 index 000000000..0074ecd4c Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/sinbad_body.tga differ diff --git a/engine/src/test-data/Blender/2.4x/sinbad_clothes.tga b/engine/src/test-data/Blender/2.4x/sinbad_clothes.tga new file mode 100644 index 000000000..51bf211bd Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/sinbad_clothes.tga differ diff --git a/engine/src/test-data/Blender/2.4x/sinbad_sword.tga b/engine/src/test-data/Blender/2.4x/sinbad_sword.tga new file mode 100644 index 000000000..2cabb79e8 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/sinbad_sword.tga differ diff --git a/engine/src/test-data/Blender/2.4x/test.conf b/engine/src/test-data/Blender/2.4x/test.conf new file mode 100644 index 000000000..93e16e2be Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/test.conf differ diff --git a/engine/src/test-data/Blender/2.4x/texturedPlaneTest.blend b/engine/src/test-data/Blender/2.4x/texturedPlaneTest.blend new file mode 100644 index 000000000..da8128d6b Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/texturedPlaneTest.blend differ diff --git a/engine/src/test-data/Blender/2.4x/textures.blend b/engine/src/test-data/Blender/2.4x/textures.blend new file mode 100644 index 000000000..4b771c9cc Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures.blend differ diff --git a/engine/src/test-data/Blender/2.4x/textures/Concrete_Wall.PNG b/engine/src/test-data/Blender/2.4x/textures/Concrete_Wall.PNG new file mode 100644 index 000000000..b6713622e Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/Concrete_Wall.PNG differ diff --git a/engine/src/test-data/Blender/2.4x/textures/Grass_256.png b/engine/src/test-data/Blender/2.4x/textures/Grass_256.png new file mode 100644 index 000000000..4b6cd8466 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/Grass_256.png differ diff --git a/engine/src/test-data/Blender/2.4x/textures/SandDesert_StartTower.png b/engine/src/test-data/Blender/2.4x/textures/SandDesert_StartTower.png new file mode 100644 index 000000000..7b2e6ddd2 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/SandDesert_StartTower.png differ diff --git a/engine/src/test-data/Blender/2.4x/textures/SkyBox-Mountain.png b/engine/src/test-data/Blender/2.4x/textures/SkyBox-Mountain.png new file mode 100644 index 000000000..ac0821d56 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/SkyBox-Mountain.png differ diff --git a/engine/src/test-data/Blender/2.4x/textures/Tar_Cracked.png b/engine/src/test-data/Blender/2.4x/textures/Tar_Cracked.png new file mode 100644 index 000000000..27ba25f32 Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/Tar_Cracked.png differ diff --git a/engine/src/test-data/Blender/2.4x/textures/WarningStrip.png b/engine/src/test-data/Blender/2.4x/textures/WarningStrip.png new file mode 100644 index 000000000..05366a7af Binary files /dev/null and b/engine/src/test-data/Blender/2.4x/textures/WarningStrip.png differ diff --git a/engine/src/test-data/Blender/2.5x/BaseMesh_256.blend b/engine/src/test-data/Blender/2.5x/BaseMesh_256.blend new file mode 100644 index 000000000..2d058d196 Binary files /dev/null and b/engine/src/test-data/Blender/2.5x/BaseMesh_256.blend differ diff --git a/engine/src/test-data/Blender/2.5x/textures.blend b/engine/src/test-data/Blender/2.5x/textures.blend new file mode 100644 index 000000000..a4f743c17 Binary files /dev/null and b/engine/src/test-data/Blender/2.5x/textures.blend differ diff --git a/engine/src/test/jme3test/blender/ManualBlenderTester.java b/engine/src/test/jme3test/blender/ManualBlenderTester.java new file mode 100644 index 000000000..e046f798e --- /dev/null +++ b/engine/src/test/jme3test/blender/ManualBlenderTester.java @@ -0,0 +1,223 @@ +/* + * Copyright (c) 2009-2010 jMonkeyEngine + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * * Neither the name of 'jMonkeyEngine' nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ +package jme3test.blender; + +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.IOException; +import java.io.InputStream; +import java.util.Map; +import java.util.Map.Entry; +import java.util.logging.Level; +import java.util.logging.Logger; + +import jme3test.blender.config.ConfigDialog; +import jme3test.blender.config.IConfigExecutable; +import jme3test.blender.scene.Pivot; + +import com.jme3.animation.AnimControl; +import com.jme3.app.SimpleApplication; +import com.jme3.asset.AssetInfo; +import com.jme3.asset.BlenderKey; +import com.jme3.asset.BlenderKey.LoadingResults; +import com.jme3.asset.ModelKey; +import com.jme3.asset.plugins.FileLocator; +import com.jme3.light.DirectionalLight; +import com.jme3.light.Light; +import com.jme3.math.ColorRGBA; +import com.jme3.math.Vector3f; +import com.jme3.renderer.Camera; +import com.jme3.scene.Node; +import com.jme3.scene.Spatial; +import com.jme3.scene.plugins.blender.BlenderLoader; +import com.jme3.scene.plugins.blender.BlenderModelLoader; +import com.jme3.texture.plugins.AWTLoader; + +/** + * This class allow to manually test the blender loader. + * @author Marcin Roguski (Kaelthas) + */ +public class ManualBlenderTester extends SimpleApplication { + private static final Logger LOGGER = Logger.getLogger(ManualBlenderTester.class.getName()); + private ModelKey modelKey;//the key that holds the test file configuration + private final boolean debug; + + /** + * Starting method + * @param args input parameters; the following options can be passed to the application: + *
  • -debug : this one indicates if the application runs in debug or not (it is used under linux + * in order to enable the mouse in debug mode since linuxes tend not to give the cursor back + * to eclipse) + */ + public static void main(String[] args) { + //veryfying if the application is in debug mode + boolean debug = false; + for(String arg : args) { + if("-debug".equalsIgnoreCase(arg)) { + debug = true; + break; + } + } + final boolean debugMode = debug; + //running the application + new ConfigDialog("./src/test-data/Blender", new IConfigExecutable() { + @Override + public void execute(ModelKey modelKey, Level logLevel) { + new ManualBlenderTester(modelKey, logLevel, debugMode).start(); + } + }); + } + + /** + * Constructor stores the given key and disables the settings screen. + * @param modelKey the key to be stored + * @param logLevel the jme logger log level + * @param debug variable that indicates if the application runs in debug mode + * (this is required on linux to show release the mouse to be used in debug mode) + */ + public ManualBlenderTester(ModelKey modelKey, Level logLevel, boolean debug) { + this.debug = debug; + Logger.getLogger("com.jme3").setLevel(logLevel); + this.modelKey = modelKey; + this.showSettings = false; + } + + @Override + public void simpleInitApp() { + if(debug) { + mouseInput.setCursorVisible(true); + } + assetManager.registerLocator(".", FileLocator.class); + assetManager.registerLoader(BlenderLoader.class, "blend"); + assetManager.registerLoader(AWTLoader.class, "png"); + + viewPort.setBackgroundColor(ColorRGBA.Gray); + + flyCam.setMoveSpeed(20); + cam.setFrustumFar(1000.0f); + cam.setFrustumNear(1.0f); + AssetInfo ai = new AssetInfo(assetManager, modelKey) { + @Override + public InputStream openStream() { + try { + return new FileInputStream(this.key.getName()); + } catch(FileNotFoundException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + return null; + } + } + }; + rootNode.attachChild(new Pivot(assetManager)); + if(modelKey instanceof BlenderKey) { + Node blenderModel = this.testBlenderLoader(ai); + Map> animations = ((BlenderKey) modelKey).getAnimations(); + //setting the first animation as active + if(((BlenderKey) modelKey).getAnimations()!=null) { + for(Entry> animEntry : animations.entrySet()) { + for(Entry anim : animEntry.getValue().entrySet()) { + Spatial animatedSpatial = this.findNode(blenderModel, animEntry.getKey()); + animatedSpatial.getControl(AnimControl.class).createChannel().setAnim(anim.getKey()); + break; + } + break; + } + } + } else { + this.testBlenderModelLoader(ai); + } + + DirectionalLight sun = new DirectionalLight(); + sun.setDirection(new Vector3f(0, -10, 0).normalizeLocal()); + sun.setColor(ColorRGBA.White); + rootNode.addLight(sun); + } + + /** + * This method finds a node of a given name. + * @param rootNode the root node to search + * @param name the name of the searched node + * @return the found node or null + */ + private Spatial findNode(Node rootNode, String name) { + if(name.equals(rootNode.getName())) { + return rootNode; + } + return rootNode.getChild(name); + } + + /** + * This method loads the model using blenderLoader. + * @param assetInfo + * the asset info + * @return the loaded model + */ + private Node testBlenderLoader(AssetInfo assetInfo) { + Node blenderModel = null; + BlenderLoader blenderLoader = new BlenderLoader(); + try { + LoadingResults loadingResults = blenderLoader.load(assetInfo); + for(Node object : loadingResults.getObjects()) { + this.rootNode.attachChild(object); + blenderModel = object; + } + for(Light light : loadingResults.getLights()) { + this.rootNode.addLight(light); + } + for(Camera camera : loadingResults.getCameras()) { + LOGGER.info(camera.toString()); + } + } catch(IOException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } + return blenderModel; + } + + /** + * This method loads the model using blenderModelLoader. + * @param assetInfo + * the asset info + * @return the loaded model + */ + private Node testBlenderModelLoader(AssetInfo assetInfo) { + BlenderModelLoader blenderLoader = new BlenderModelLoader(); + try { + Spatial loadingResults = blenderLoader.load(assetInfo); + this.rootNode.attachChild(loadingResults); + if(loadingResults instanceof Node) { + return (Node)loadingResults; + } + } catch(IOException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } + return null; + } +} diff --git a/engine/src/test/jme3test/blender/config/AbstractConfigDialog.java b/engine/src/test/jme3test/blender/config/AbstractConfigDialog.java new file mode 100644 index 000000000..3309edaba --- /dev/null +++ b/engine/src/test/jme3test/blender/config/AbstractConfigDialog.java @@ -0,0 +1,376 @@ +package jme3test.blender.config; + +import java.awt.BorderLayout; +import java.awt.Component; +import java.awt.FlowLayout; +import java.awt.Insets; +import java.awt.Label; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.io.File; +import java.util.HashMap; +import java.util.Map; +import java.util.logging.Level; +import java.util.logging.Logger; + +import javax.swing.AbstractCellEditor; +import javax.swing.Box; +import javax.swing.ButtonGroup; +import javax.swing.DefaultComboBoxModel; +import javax.swing.DefaultListModel; +import javax.swing.DefaultListSelectionModel; +import javax.swing.JButton; +import javax.swing.JCheckBox; +import javax.swing.JComboBox; +import javax.swing.JFrame; +import javax.swing.JLabel; +import javax.swing.JList; +import javax.swing.JPanel; +import javax.swing.JRadioButton; +import javax.swing.JScrollPane; +import javax.swing.JTable; +import javax.swing.JTextField; +import javax.swing.ListSelectionModel; +import javax.swing.UIManager; +import javax.swing.UnsupportedLookAndFeelException; +import javax.swing.border.EmptyBorder; +import javax.swing.border.TitledBorder; +import javax.swing.table.DefaultTableModel; +import javax.swing.table.TableCellEditor; + +/** + * A base class for defining the start configuration. + * This separates the gui window definition from its logic. + * It is made so to easier maintain the dialog window. + * @author Marcin Roguski (Kaelthas) + */ +public abstract class AbstractConfigDialog extends JFrame { + private static final long serialVersionUID = -3677493125861310310L; + private static final Logger LOGGER = Logger.getLogger(AbstractConfigDialog.class.getName()); + + protected JComboBox jComboBoxVersionSelection; + protected JList jListBlenderFiles; + protected JTable jTableProperties; + protected JTable jTableAnimations; + protected JButton jButtonAddAnimation; + protected JButton jButtonRemoveAnimation; + protected JCheckBox jCheckBoxUseModelKey; + protected JButton jButtonOK; + protected JButton jButtonCancel; + + /** + * Cionstructor initializes the gui. + */ + public AbstractConfigDialog() { + this.init(); + } + + /** + * This method initializes the window. + */ + private void init() { + try {//setting the system Look And Feel + UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); + } catch (ClassNotFoundException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } catch (InstantiationException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } catch (IllegalAccessException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } catch (UnsupportedLookAndFeelException e) { + LOGGER.log(Level.SEVERE, e.getMessage(), e); + } + this.setLayout(new BorderLayout()); + + this.add(this.prepareBlenderFilesAndLogLevelPanel(), BorderLayout.WEST); + this.add(this.prepareFilePropertiesPanel(), BorderLayout.CENTER); + this.add(this.prepareButtonsPanel(), BorderLayout.SOUTH); + + this.pack(); + this.setLocationRelativeTo(null); + this.setVisible(true); + this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + } + + /** + * This method prepares a swing panel containing the list of blender files + * and log level chooser. + * @return prepared swing panel + */ + private JPanel prepareBlenderFilesAndLogLevelPanel() { + JPanel jPanelBlenderFilesListAndLogLevel = new JPanel(); + jPanelBlenderFilesListAndLogLevel.setBorder(new TitledBorder("Blender test files")); + jPanelBlenderFilesListAndLogLevel.setLayout(new BorderLayout()); + + //blender version selection combo box + jComboBoxVersionSelection = new JComboBox(new DefaultComboBoxModel()); + jComboBoxVersionSelection.setEditable(false); + jPanelBlenderFilesListAndLogLevel.add(jComboBoxVersionSelection, BorderLayout.NORTH); + + //blender list files + jListBlenderFiles = new JList(new DefaultListModel()); + jListBlenderFiles.setSelectionMode(ListSelectionModel.SINGLE_SELECTION); + JScrollPane listScroller = new JScrollPane(jListBlenderFiles); + jPanelBlenderFilesListAndLogLevel.add(listScroller, BorderLayout.CENTER); + + //Log Level list + Box box = Box.createVerticalBox(); + box.add(new Label("Log level:")); + ButtonGroup buttonGroup = new ButtonGroup(); + + Level[] levels = new Level[] {Level.OFF, Level.SEVERE, Level.WARNING, Level.INFO, + Level.CONFIG, Level.FINE, Level.FINER, Level.FINEST, Level.ALL}; + for(Level level : levels) { + JRadioButtonLevel jRadioButtonLevel = new JRadioButtonLevel(level); + buttonGroup.add(jRadioButtonLevel); + box.add(jRadioButtonLevel); + } + jPanelBlenderFilesListAndLogLevel.add(box, BorderLayout.SOUTH); + + return jPanelBlenderFilesListAndLogLevel; + } + + /** + * This method prepares a swing panel containing the file's animations. + * @return prepared swing panel + */ + protected JPanel prepareFilePropertiesPanel() { + //properties table + JPanel jPanelProperties = new JPanel(); + jPanelProperties.setBorder(new EmptyBorder(new Insets(0, 5, 0, 5))); + jPanelProperties.setLayout(new BorderLayout()); + jPanelProperties.add(new JLabel("Properties"), BorderLayout.NORTH); + + jTableProperties = new JTable(); + jTableProperties.setSelectionMode(DefaultListSelectionModel.SINGLE_SELECTION); + jTableProperties.setModel(new BlenderTableModel(new Object[] {"Name", "Value"})); + jTableProperties.getColumnModel().getColumn(1).setCellEditor(new BlenderTableCellEditor()); + JScrollPane jScrollPaneProperties = new JScrollPane(jTableProperties); + jTableProperties.setFillsViewportHeight(true); + + jPanelProperties.add(jScrollPaneProperties, BorderLayout.CENTER); + + //animations table + JPanel jPanelAnimations = new JPanel(); + jPanelAnimations.setBorder(new EmptyBorder(new Insets(0, 5, 0, 5))); + jPanelAnimations.setLayout(new BorderLayout()); + jPanelAnimations.add(new JLabel("Animations"), BorderLayout.NORTH); + + jTableAnimations = new JTable(); + jTableAnimations.setSelectionMode(DefaultListSelectionModel.SINGLE_SELECTION); + jTableAnimations.setModel(new DefaultTableModel(new Object[] {"Object", "Name", "Start frame", "Stop frame"}, 0)); + for(int i=0;i radioButtons = new HashMap(); + private Level level; + + /** + * Constructor. Creates the radio button. + * Stores it inside the buttons map. + * @param level the level of log info + */ + public JRadioButtonLevel(Level level) { + super(level.getName()); + this.level = level; + radioButtons.put(level, this); + this.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent e) { + JRadioButtonLevel.selectedLevel = JRadioButtonLevel.this.level; + } + }); + } + + /** + * This method returns the currently selected info level. + * @return currently selected info level + */ + public static Level getSelectedLevel() { + return selectedLevel; + } + + /** + * This method sets the current info level. + * @param level the current info level + */ + public static synchronized void setSelectedLevel(Level level) { + radioButtons.get(level).setSelected(true); + } + } + + /** + * This class is an item that should be stored in the files' list. + * @author Marcin Roguski (Kaelthas) + */ + protected static class FileListItem { + private File file; //the file to be stored + /** + * Constructore. Stores the given file. + * @param file the file to be stored + */ + public FileListItem(File file) { + this.file = file; + } + + /** + * This method returns the stored file. + * @return the stored file + */ + public File getFile() { + return file; + } + + @Override + public String toString() { + return file.getName(); + } + } + + /** + * The model for properties table. + * It makes left column ineditable. + * @author Marcin Roguski (Kaelthas) + */ + protected static class BlenderTableModel extends DefaultTableModel { + private static final long serialVersionUID = -4211206550875326553L; + + /** + * Constructor only calls super-constuctor. + * @param columnNames the names of table columns + */ + public BlenderTableModel(Object[] columnNames) { + super(columnNames, 0); + } + + @Override + public void addRow(Object[] rowData) { + for(int i=0;i0; + } + } + + /** + * A cell editor tah improves data input to the table. + * @author Marcin Roguski (Kaelthas) + */ + protected static class BlenderTableCellEditor extends AbstractCellEditor implements TableCellEditor { + private static final long serialVersionUID = -8601975203921608519L; + private JCheckBox jCheckBox = new JCheckBox(); + private JTextField jTextField = new JTextField(); + private JComboBox jComboBox = new JComboBox(); + private Object lastValue; + + @Override + public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) { + this.lastValue = value; + if(value instanceof Boolean) { + jCheckBox.setSelected(((Boolean) value).booleanValue()); + return jCheckBox; + } else if(value instanceof String || value instanceof Number || value instanceof Character) { + jTextField.setText(value.toString()); + return jTextField; + } else if(value instanceof Enum) { + DefaultComboBoxModel defaultComboBoxModel = (DefaultComboBoxModel)jComboBox.getModel(); + defaultComboBoxModel.removeAllElements(); + for(Object object : value.getClass().getEnumConstants()) { + defaultComboBoxModel.addElement(object); + } + return jComboBox; + } + else { + jTextField.setText(value==null ? "" : value.toString()); + return jTextField; + } + } + + @Override + public Object getCellEditorValue() { + if(lastValue instanceof Boolean) { + return Boolean.valueOf(jCheckBox.isSelected()); + } else if(lastValue instanceof String) { + return jTextField.getText(); + } else if(lastValue instanceof Character) { + return Character.valueOf(jTextField.getText().charAt(0)); + } else if(lastValue instanceof Byte) { + return Byte.valueOf(jTextField.getText()); + } else if(lastValue instanceof Short) { + return Short.valueOf(jTextField.getText()); + } else if(lastValue instanceof Integer) { + return Integer.valueOf(jTextField.getText()); + } else if(lastValue instanceof Long) { + return Long.valueOf(jTextField.getText()); + } else if(lastValue instanceof Float) { + return Float.valueOf(jTextField.getText()); + } else if(lastValue instanceof Double) { + return Double.valueOf(jTextField.getText()); + } else if(lastValue instanceof Enum) { + return jComboBox.getSelectedItem(); + } + //TODO: savable objects + return null; + } + } +} diff --git a/engine/src/test/jme3test/blender/config/ConfigDialog.java b/engine/src/test/jme3test/blender/config/ConfigDialog.java new file mode 100644 index 000000000..e9c02c498 --- /dev/null +++ b/engine/src/test/jme3test/blender/config/ConfigDialog.java @@ -0,0 +1,440 @@ +/** + * + */ +package jme3test.blender.config; + +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.io.File; +import java.io.FileFilter; +import java.io.IOException; +import java.lang.reflect.Field; +import java.lang.reflect.Modifier; +import java.util.HashMap; +import java.util.Map; +import java.util.Map.Entry; +import java.util.logging.Level; +import java.util.logging.Logger; + +import javax.swing.DefaultComboBoxModel; +import javax.swing.DefaultListModel; +import javax.swing.JOptionPane; +import javax.swing.SwingUtilities; +import javax.swing.event.ListSelectionEvent; +import javax.swing.event.ListSelectionListener; +import javax.swing.event.TableModelEvent; +import javax.swing.event.TableModelListener; +import javax.swing.table.DefaultTableModel; + +import com.jme3.asset.BlenderKey; +import com.jme3.asset.ModelKey; +import com.jme3.export.InputCapsule; +import com.jme3.export.JmeExporter; +import com.jme3.export.JmeImporter; +import com.jme3.export.OutputCapsule; +import com.jme3.export.Savable; +import com.jme3.export.binary.BinaryExporter; +import com.jme3.export.binary.BinaryImporter; + +/** + * A class that shows a dialog box for blender testing configuration. + * @author Marcin Roguski (Kaelthas) + */ +public class ConfigDialog extends AbstractConfigDialog { + private static final long serialVersionUID = 2863364888664674247L; + private static final Logger LOGGER = Logger.getLogger(ConfigDialog.class.getName()); + + private String baseFolderName; + private File configFile; //the config file + private Map configMap; //the blender key configuration map + private BlenderKeyConfiguration blenderKeyConfiguration;//the configuration for the files + private IConfigExecutable configExecutable; //this is called after clicking the 'OK' button + + /** + * Constructor. Builds the whole window and stores its data. + * @param testAssetsFolderName the path to test files folder + */ + public ConfigDialog(String baseFolderName, IConfigExecutable configExecutable) { + if(baseFolderName==null) { + throw new IllegalArgumentException("No test asset folder given!"); + } + if(configExecutable==null) { + throw new IllegalArgumentException("No config executable given!"); + } + this.baseFolderName = baseFolderName; + this.configExecutable = configExecutable; + this.configMap = new HashMap(); + + //setting up version selection (as a folder list in a compo box) + File baseFolder = new File(baseFolderName); + if(!baseFolder.exists() || !baseFolder.isDirectory()) { + throw new IllegalArgumentException("The given base folder path either does not exists or does not point to a directory!"); + } + File[] folders = baseFolder.listFiles(new FileFilter() { + @Override + public boolean accept(File file) { + return file.isDirectory() && file.getName().charAt(0)!='.'; + } + }); + for(File folder : folders) { + ((DefaultComboBoxModel)jComboBoxVersionSelection.getModel()).addElement(folder.getName()); + configMap.put(folder.getName(), null); + } + this.initListeners(); + + jComboBoxVersionSelection.setSelectedIndex(0); + } + + /** + * This method returns the selected blender key. + * @return the selected blender key + */ + public BlenderKey getSelectedBlenderKey() { + return blenderKeyConfiguration.lastUsedKey; + } + + /** + * This method prepares the blender files' list. + * @param testAssetsFolderName the path to test files folder + * @return array of blender files + */ + private File[] prepareFilesList(String testAssetsFolderName) { + File testAssetsFolder = new File(testAssetsFolderName); + + //loading blender files + File[] blenderFiles = testAssetsFolder.listFiles(new FileFilter() { + @Override + public boolean accept(File file) { + return file.isFile() && file.canRead() && file.getName().endsWith(".blend"); + } + }); + + //loading the blender files configuration + File[] files = testAssetsFolder.listFiles(new FileFilter() { + @Override + public boolean accept(File file) { + return file.isFile() && file.canRead() && file.getName().endsWith(".conf"); + } + }); + if (files == null || files.length == 0) { + blenderKeyConfiguration = new BlenderKeyConfiguration(blenderFiles.length); + + } else { + BinaryImporter jmeImporter = new BinaryImporter(); + String instructionToUser = files.length==1 ? + "No other config file to load! No configuration set!" : + "Please choose different config file!"; + do { + if (files.length > 1) { + configFile = (File) JOptionPane.showInputDialog(null, "Choose the config file!", "Config file selection", + JOptionPane.INFORMATION_MESSAGE, null, files, files[0]); + } else { + configFile = files[0]; + } + if(configFile==null) { + JOptionPane.showMessageDialog(this, "No config file selected!\nEmpty configuration will be created!", + "No configuration selected", JOptionPane.INFORMATION_MESSAGE); + blenderKeyConfiguration = new BlenderKeyConfiguration(blenderFiles.length); + } else { + try { + Savable loadedData = jmeImporter.load(configFile); + if (loadedData instanceof BlenderKeyConfiguration) { + blenderKeyConfiguration = (BlenderKeyConfiguration) loadedData; + } else { + LOGGER.warning("Cannot load data drom the given file!"); + JOptionPane.showMessageDialog(this, "The data stored in the config file is of invalid type!\n" + + instructionToUser, "Config data error", JOptionPane.ERROR_MESSAGE); + } + } catch (IOException e) { + JOptionPane.showMessageDialog(this, "Unable to load configuration! Reason: " + e.getLocalizedMessage(), + "Loading data error", JOptionPane.ERROR_MESSAGE); + LOGGER.severe("Unable to load configuration"); + } catch (Exception e) { + JOptionPane.showMessageDialog(this, "Unable to load configuration!", + "Loading data error", JOptionPane.ERROR_MESSAGE); + LOGGER.log(Level.SEVERE, "Unable to load configuration due to unpredicted error!", e); + } + } + } while (blenderKeyConfiguration == null && files.length>1); + } + configFile = new File(testAssetsFolder, "test.conf"); + + jCheckBoxUseModelKey.setSelected(blenderKeyConfiguration.useModelKey); + + //enlisting the files in the list + DefaultListModel defaultListModel = (DefaultListModel) jListBlenderFiles.getModel(); + defaultListModel.removeAllElements(); + for(int i=0; i> animations = blenderKey.getAnimations(); + if(animations!=null) { + for(Entry> animationEntry : animations.entrySet()) { + for(Entry animDataEntry : animationEntry.getValue().entrySet()) { + int[] frames = animDataEntry.getValue(); + animationsModel.addRow(new Object[] {animationEntry.getKey(), animDataEntry.getKey(), + Integer.valueOf(frames[0]), Integer.valueOf(frames[1])}); + } + } + } + + this.jButtonOK.setEnabled(true); + this.jButtonOK.requestFocusInWindow(); + this.jButtonAddAnimation.setEnabled(true); + } + + /** + * This method stores the current blender config. + * @param configuration the blender config to store + */ + private void storeConfig(BlenderKeyConfiguration configuration) { + if(configuration.lastUsedKey!=null) {//reading animations + DefaultTableModel animationsTableModel = (DefaultTableModel)jTableAnimations.getModel(); + if(configuration.lastUsedKey.getAnimations()!=null) { + configuration.lastUsedKey.getAnimations().clear(); + } + int animCounter = 0; + for(int i=0;i=0) { + ((DefaultTableModel)jTableAnimations.getModel()).removeRow(row); + } + } + }); + + //button listeners + jButtonOK.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent evt) { + ConfigDialog.this.storeConfig(blenderKeyConfiguration); + //running the test + SwingUtilities.invokeLater(new Runnable() { + @Override + public void run() { + configExecutable.execute(ConfigDialog.this.blenderKeyConfiguration.getKeyToUse(), + ConfigDialog.this.blenderKeyConfiguration.logLevel); + } + }); + //disposing the config window + ConfigDialog.this.dispose(); + } + }); + jButtonCancel.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent evt) { + ConfigDialog.this.dispose(); + } + }); + } + + /** + * This class holds the configuration for all the files. + * It can be saved and loaded using jme mechanisms. + * @author Marcin Roguski (Kaelthas) + */ + public static class BlenderKeyConfiguration implements Savable { + private Map blenderKeys; + private BlenderKey lastUsedKey; + private Level logLevel; + private boolean useModelKey; + + /** + * Constructor for jme serialization. + */ + public BlenderKeyConfiguration() {} + + /** + * Constructor that creates new empty configuration for every blender file. + * @param blenderFilesAmount the amount of blender files + */ + public BlenderKeyConfiguration(int blenderFilesAmount) { + blenderKeys = new HashMap(blenderFilesAmount); + } + + /** + * This method returns the key that will be used during the test. + * @return the key that will be used during the test + */ + public ModelKey getKeyToUse() { + return useModelKey ? new ModelKey(lastUsedKey.getName()) : lastUsedKey; + } + + @Override + public void write(JmeExporter ex) throws IOException { + OutputCapsule oc = ex.getCapsule(this); + oc.writeStringSavableMap(blenderKeys, "keys", null); + oc.write(lastUsedKey, "last-key", null); + oc.write(useModelKey, "use-model-key", false); + oc.write(logLevel==null ? null : logLevel.getName(), "log-level", Level.INFO.getName()); + } + + @Override + @SuppressWarnings("unchecked") + public void read(JmeImporter im) throws IOException { + InputCapsule ic = im.getCapsule(this); + blenderKeys = (Map) ic.readStringSavableMap("keys", null); + lastUsedKey = (BlenderKey) ic.readSavable("last-key", null); + useModelKey = ic.readBoolean("use-model-key", false); + String logLevelName = ic.readString("log-level", Level.INFO.getName()); + logLevel = logLevelName==null ? Level.INFO : Level.parse(logLevelName); + } + } +} diff --git a/engine/src/test/jme3test/blender/config/IConfigExecutable.java b/engine/src/test/jme3test/blender/config/IConfigExecutable.java new file mode 100644 index 000000000..51bcffc12 --- /dev/null +++ b/engine/src/test/jme3test/blender/config/IConfigExecutable.java @@ -0,0 +1,21 @@ +package jme3test.blender.config; + +import java.util.logging.Level; + +import com.jme3.asset.ModelKey; + +/** + * This interface provides a method that allows to execute a method after the config has been properly set. It actually runs the test + * itself. + * @author Marcin Roguski (Kaelthas) + */ +public interface IConfigExecutable { + /** + * This method runs the test with the given blender key. + * @param modelKey + * the model key + * @param logLevel + * the jme3 logger log level + */ + void execute(ModelKey modelKey, Level logLevel); +} diff --git a/engine/src/test/jme3test/blender/config/NoiseConstantsGenerator.java b/engine/src/test/jme3test/blender/config/NoiseConstantsGenerator.java new file mode 100644 index 000000000..886672fc2 --- /dev/null +++ b/engine/src/test/jme3test/blender/config/NoiseConstantsGenerator.java @@ -0,0 +1,954 @@ +package jme3test.blender.config; + +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.io.ObjectOutputStream; +import java.util.logging.Level; +import java.util.logging.Logger; + + +public class NoiseConstantsGenerator { + private static final Logger LOGGER = Logger.getLogger(NoiseConstantsGenerator.class.getName()); + private static final String FILE_NAME = "noiseconstants.dat"; + + public static void main(String[] args) { + NoiseConstantsGenerator noiseConstantsGenerator = new NoiseConstantsGenerator(); + noiseConstantsGenerator.setFilePath("./src/com/jme3/scene/plugins/blender/helpers/" + FILE_NAME); + noiseConstantsGenerator.execute(); + LOGGER.info("Noise data generation successfull!"); + } + + private String filePath; + + public void execute() { + if(filePath==null) { + throw new IllegalStateException("The output file path cannot be null!"); + } + + FileOutputStream fos = null; + try { + + fos = new FileOutputStream(filePath); + ObjectOutputStream oos = new ObjectOutputStream(fos); + oos.writeObject(hashpntf); + oos.writeObject(hash); + oos.writeObject(hashvectf); + oos.writeObject(p); + oos.writeObject(g); + oos.flush(); + } catch (FileNotFoundException e) { + LOGGER.log(Level.SEVERE, e.getLocalizedMessage(), e); + } catch (IOException e) { + LOGGER.log(Level.SEVERE, e.getLocalizedMessage(), e); + } finally { + if(fos!=null) { + try { + fos.close(); + } catch (IOException e) { + LOGGER.log(Level.SEVERE, e.getLocalizedMessage(), e); + } + } + } + } + + public String getFilePath() { + return filePath; + } + + public void setFilePath(String filePath) { + this.filePath = filePath; + } + + /* + * Constants to be stored. + */ + private static float[] hashpntf = new float[] { 0.536902f, 0.020915f, + 0.501445f, 0.216316f, 0.517036f, 0.822466f, 0.965315f, 0.377313f, + 0.678764f, 0.744545f, 0.097731f, 0.396357f, 0.247202f, 0.520897f, + 0.613396f, 0.542124f, 0.146813f, 0.255489f, 0.810868f, 0.638641f, + 0.980742f, 0.292316f, 0.357948f, 0.114382f, 0.861377f, 0.629634f, + 0.722530f, 0.714103f, 0.048549f, 0.075668f, 0.564920f, 0.162026f, + 0.054466f, 0.411738f, 0.156897f, 0.887657f, 0.599368f, 0.074249f, + 0.170277f, 0.225799f, 0.393154f, 0.301348f, 0.057434f, 0.293849f, + 0.442745f, 0.150002f, 0.398732f, 0.184582f, 0.915200f, 0.630984f, + 0.974040f, 0.117228f, 0.795520f, 0.763238f, 0.158982f, 0.616211f, + 0.250825f, 0.906539f, 0.316874f, 0.676205f, 0.234720f, 0.667673f, + 0.792225f, 0.273671f, 0.119363f, 0.199131f, 0.856716f, 0.828554f, + 0.900718f, 0.705960f, 0.635923f, 0.989433f, 0.027261f, 0.283507f, + 0.113426f, 0.388115f, 0.900176f, 0.637741f, 0.438802f, 0.715490f, + 0.043692f, 0.202640f, 0.378325f, 0.450325f, 0.471832f, 0.147803f, + 0.906899f, 0.524178f, 0.784981f, 0.051483f, 0.893369f, 0.596895f, + 0.275635f, 0.391483f, 0.844673f, 0.103061f, 0.257322f, 0.708390f, + 0.504091f, 0.199517f, 0.660339f, 0.376071f, 0.038880f, 0.531293f, + 0.216116f, 0.138672f, 0.907737f, 0.807994f, 0.659582f, 0.915264f, + 0.449075f, 0.627128f, 0.480173f, 0.380942f, 0.018843f, 0.211808f, + 0.569701f, 0.082294f, 0.689488f, 0.573060f, 0.593859f, 0.216080f, + 0.373159f, 0.108117f, 0.595539f, 0.021768f, 0.380297f, 0.948125f, + 0.377833f, 0.319699f, 0.315249f, 0.972805f, 0.792270f, 0.445396f, + 0.845323f, 0.372186f, 0.096147f, 0.689405f, 0.423958f, 0.055675f, + 0.117940f, 0.328456f, 0.605808f, 0.631768f, 0.372170f, 0.213723f, + 0.032700f, 0.447257f, 0.440661f, 0.728488f, 0.299853f, 0.148599f, + 0.649212f, 0.498381f, 0.049921f, 0.496112f, 0.607142f, 0.562595f, + 0.990246f, 0.739659f, 0.108633f, 0.978156f, 0.209814f, 0.258436f, + 0.876021f, 0.309260f, 0.600673f, 0.713597f, 0.576967f, 0.641402f, + 0.853930f, 0.029173f, 0.418111f, 0.581593f, 0.008394f, 0.589904f, + 0.661574f, 0.979326f, 0.275724f, 0.111109f, 0.440472f, 0.120839f, + 0.521602f, 0.648308f, 0.284575f, 0.204501f, 0.153286f, 0.822444f, + 0.300786f, 0.303906f, 0.364717f, 0.209038f, 0.916831f, 0.900245f, + 0.600685f, 0.890002f, 0.581660f, 0.431154f, 0.705569f, 0.551250f, + 0.417075f, 0.403749f, 0.696652f, 0.292652f, 0.911372f, 0.690922f, + 0.323718f, 0.036773f, 0.258976f, 0.274265f, 0.225076f, 0.628965f, + 0.351644f, 0.065158f, 0.080340f, 0.467271f, 0.130643f, 0.385914f, + 0.919315f, 0.253821f, 0.966163f, 0.017439f, 0.392610f, 0.478792f, + 0.978185f, 0.072691f, 0.982009f, 0.097987f, 0.731533f, 0.401233f, + 0.107570f, 0.349587f, 0.479122f, 0.700598f, 0.481751f, 0.788429f, + 0.706864f, 0.120086f, 0.562691f, 0.981797f, 0.001223f, 0.192120f, + 0.451543f, 0.173092f, 0.108960f, 0.549594f, 0.587892f, 0.657534f, + 0.396365f, 0.125153f, 0.666420f, 0.385823f, 0.890916f, 0.436729f, + 0.128114f, 0.369598f, 0.759096f, 0.044677f, 0.904752f, 0.088052f, + 0.621148f, 0.005047f, 0.452331f, 0.162032f, 0.494238f, 0.523349f, + 0.741829f, 0.698450f, 0.452316f, 0.563487f, 0.819776f, 0.492160f, + 0.004210f, 0.647158f, 0.551475f, 0.362995f, 0.177937f, 0.814722f, + 0.727729f, 0.867126f, 0.997157f, 0.108149f, 0.085726f, 0.796024f, + 0.665075f, 0.362462f, 0.323124f, 0.043718f, 0.042357f, 0.315030f, + 0.328954f, 0.870845f, 0.683186f, 0.467922f, 0.514894f, 0.809971f, + 0.631979f, 0.176571f, 0.366320f, 0.850621f, 0.505555f, 0.749551f, + 0.750830f, 0.401714f, 0.481216f, 0.438393f, 0.508832f, 0.867971f, + 0.654581f, 0.058204f, 0.566454f, 0.084124f, 0.548539f, 0.902690f, + 0.779571f, 0.562058f, 0.048082f, 0.863109f, 0.079290f, 0.713559f, + 0.783496f, 0.265266f, 0.672089f, 0.786939f, 0.143048f, 0.086196f, + 0.876129f, 0.408708f, 0.229312f, 0.629995f, 0.206665f, 0.207308f, + 0.710079f, 0.341704f, 0.264921f, 0.028748f, 0.629222f, 0.470173f, + 0.726228f, 0.125243f, 0.328249f, 0.794187f, 0.741340f, 0.489895f, + 0.189396f, 0.724654f, 0.092841f, 0.039809f, 0.860126f, 0.247701f, + 0.655331f, 0.964121f, 0.672536f, 0.044522f, 0.690567f, 0.837238f, + 0.631520f, 0.953734f, 0.352484f, 0.289026f, 0.034152f, 0.852575f, + 0.098454f, 0.795529f, 0.452181f, 0.826159f, 0.186993f, 0.820725f, + 0.440328f, 0.922137f, 0.704592f, 0.915437f, 0.738183f, 0.733461f, + 0.193798f, 0.929213f, 0.161390f, 0.318547f, 0.888751f, 0.430968f, + 0.740837f, 0.193544f, 0.872253f, 0.563074f, 0.274598f, 0.347805f, + 0.666176f, 0.449831f, 0.800991f, 0.588727f, 0.052296f, 0.714761f, + 0.420620f, 0.570325f, 0.057550f, 0.210888f, 0.407312f, 0.662848f, + 0.924382f, 0.895958f, 0.775198f, 0.688605f, 0.025721f, 0.301913f, + 0.791408f, 0.500602f, 0.831984f, 0.828509f, 0.642093f, 0.494174f, + 0.525880f, 0.446365f, 0.440063f, 0.763114f, 0.630358f, 0.223943f, + 0.333806f, 0.906033f, 0.498306f, 0.241278f, 0.427640f, 0.772683f, + 0.198082f, 0.225379f, 0.503894f, 0.436599f, 0.016503f, 0.803725f, + 0.189878f, 0.291095f, 0.499114f, 0.151573f, 0.079031f, 0.904618f, + 0.708535f, 0.273900f, 0.067419f, 0.317124f, 0.936499f, 0.716511f, + 0.543845f, 0.939909f, 0.826574f, 0.715090f, 0.154864f, 0.750150f, + 0.845808f, 0.648108f, 0.556564f, 0.644757f, 0.140873f, 0.799167f, + 0.632989f, 0.444245f, 0.471978f, 0.435910f, 0.359793f, 0.216241f, + 0.007633f, 0.337236f, 0.857863f, 0.380247f, 0.092517f, 0.799973f, + 0.919000f, 0.296798f, 0.096989f, 0.854831f, 0.165369f, 0.568475f, + 0.216855f, 0.020457f, 0.835511f, 0.538039f, 0.999742f, 0.620226f, + 0.244053f, 0.060399f, 0.323007f, 0.294874f, 0.988899f, 0.384919f, + 0.735655f, 0.773428f, 0.549776f, 0.292882f, 0.660611f, 0.593507f, + 0.621118f, 0.175269f, 0.682119f, 0.794493f, 0.868197f, 0.632150f, + 0.807823f, 0.509656f, 0.482035f, 0.001780f, 0.259126f, 0.358002f, + 0.280263f, 0.192985f, 0.290367f, 0.208111f, 0.917633f, 0.114422f, + 0.925491f, 0.981110f, 0.255570f, 0.974862f, 0.016629f, 0.552599f, + 0.575741f, 0.612978f, 0.615965f, 0.803615f, 0.772334f, 0.089745f, + 0.838812f, 0.634542f, 0.113709f, 0.755832f, 0.577589f, 0.667489f, + 0.529834f, 0.325660f, 0.817597f, 0.316557f, 0.335093f, 0.737363f, + 0.260951f, 0.737073f, 0.049540f, 0.735541f, 0.988891f, 0.299116f, + 0.147695f, 0.417271f, 0.940811f, 0.524160f, 0.857968f, 0.176403f, + 0.244835f, 0.485759f, 0.033353f, 0.280319f, 0.750688f, 0.755809f, + 0.924208f, 0.095956f, 0.962504f, 0.275584f, 0.173715f, 0.942716f, + 0.706721f, 0.078464f, 0.576716f, 0.804667f, 0.559249f, 0.900611f, + 0.646904f, 0.432111f, 0.927885f, 0.383277f, 0.269973f, 0.114244f, + 0.574867f, 0.150703f, 0.241855f, 0.272871f, 0.199950f, 0.079719f, + 0.868566f, 0.962833f, 0.789122f, 0.320025f, 0.905554f, 0.234876f, + 0.991356f, 0.061913f, 0.732911f, 0.785960f, 0.874074f, 0.069035f, + 0.658632f, 0.309901f, 0.023676f, 0.791603f, 0.764661f, 0.661278f, + 0.319583f, 0.829650f, 0.117091f, 0.903124f, 0.982098f, 0.161631f, + 0.193576f, 0.670428f, 0.857390f, 0.003760f, 0.572578f, 0.222162f, + 0.114551f, 0.420118f, 0.530404f, 0.470682f, 0.525527f, 0.764281f, + 0.040596f, 0.443275f, 0.501124f, 0.816161f, 0.417467f, 0.332172f, + 0.447565f, 0.614591f, 0.559246f, 0.805295f, 0.226342f, 0.155065f, + 0.714630f, 0.160925f, 0.760001f, 0.453456f, 0.093869f, 0.406092f, + 0.264801f, 0.720370f, 0.743388f, 0.373269f, 0.403098f, 0.911923f, + 0.897249f, 0.147038f, 0.753037f, 0.516093f, 0.739257f, 0.175018f, + 0.045768f, 0.735857f, 0.801330f, 0.927708f, 0.240977f, 0.591870f, + 0.921831f, 0.540733f, 0.149100f, 0.423152f, 0.806876f, 0.397081f, + 0.061100f, 0.811630f, 0.044899f, 0.460915f, 0.961202f, 0.822098f, + 0.971524f, 0.867608f, 0.773604f, 0.226616f, 0.686286f, 0.926972f, + 0.411613f, 0.267873f, 0.081937f, 0.226124f, 0.295664f, 0.374594f, + 0.533240f, 0.237876f, 0.669629f, 0.599083f, 0.513081f, 0.878719f, + 0.201577f, 0.721296f, 0.495038f, 0.079760f, 0.965959f, 0.233090f, + 0.052496f, 0.714748f, 0.887844f, 0.308724f, 0.972885f, 0.723337f, + 0.453089f, 0.914474f, 0.704063f, 0.823198f, 0.834769f, 0.906561f, + 0.919600f, 0.100601f, 0.307564f, 0.901977f, 0.468879f, 0.265376f, + 0.885188f, 0.683875f, 0.868623f, 0.081032f, 0.466835f, 0.199087f, + 0.663437f, 0.812241f, 0.311337f, 0.821361f, 0.356628f, 0.898054f, + 0.160781f, 0.222539f, 0.714889f, 0.490287f, 0.984915f, 0.951755f, + 0.964097f, 0.641795f, 0.815472f, 0.852732f, 0.862074f, 0.051108f, + 0.440139f, 0.323207f, 0.517171f, 0.562984f, 0.115295f, 0.743103f, + 0.977914f, 0.337596f, 0.440694f, 0.535879f, 0.959427f, 0.351427f, + 0.704361f, 0.010826f, 0.131162f, 0.577080f, 0.349572f, 0.774892f, + 0.425796f, 0.072697f, 0.500001f, 0.267322f, 0.909654f, 0.206176f, + 0.223987f, 0.937698f, 0.323423f, 0.117501f, 0.490308f, 0.474372f, + 0.689943f, 0.168671f, 0.719417f, 0.188928f, 0.330464f, 0.265273f, + 0.446271f, 0.171933f, 0.176133f, 0.474616f, 0.140182f, 0.114246f, + 0.905043f, 0.713870f, 0.555261f, 0.951333f }; + + private static short[] hash = new short[] {// 512 + 0xA2, 0xA0, 0x19, 0x3B, 0xF8, 0xEB, 0xAA, 0xEE, 0xF3, 0x1C, 0x67, 0x28, + 0x1D, 0xED, 0x0, 0xDE, 0x95, 0x2E, 0xDC, 0x3F, 0x3A, 0x82, 0x35, + 0x4D, 0x6C, 0xBA, 0x36, 0xD0, 0xF6, 0xC, 0x79, 0x32, 0xD1, 0x59, + 0xF4, 0x8, 0x8B, 0x63, 0x89, 0x2F, 0xB8, 0xB4, 0x97, 0x83, 0xF2, + 0x8F, 0x18, 0xC7, 0x51, 0x14, 0x65, 0x87, 0x48, 0x20, 0x42, 0xA8, + 0x80, 0xB5, 0x40, 0x13, 0xB2, 0x22, 0x7E, 0x57, 0xBC, 0x7F, 0x6B, + 0x9D, 0x86, 0x4C, 0xC8, 0xDB, 0x7C, 0xD5, 0x25, 0x4E, 0x5A, 0x55, + 0x74, 0x50, 0xCD, 0xB3, 0x7A, 0xBB, 0xC3, 0xCB, 0xB6, 0xE2, 0xE4, + 0xEC, 0xFD, 0x98, 0xB, 0x96, 0xD3, 0x9E, 0x5C, 0xA1, 0x64, 0xF1, + 0x81, 0x61, 0xE1, 0xC4, 0x24, 0x72, 0x49, 0x8C, 0x90, 0x4B, 0x84, + 0x34, 0x38, 0xAB, 0x78, 0xCA, 0x1F, 0x1, 0xD7, 0x93, 0x11, 0xC1, + 0x58, 0xA9, 0x31, 0xF9, 0x44, 0x6D, 0xBF, 0x33, 0x9C, 0x5F, 0x9, + 0x94, 0xA3, 0x85, 0x6, 0xC6, 0x9A, 0x1E, 0x7B, 0x46, 0x15, 0x30, + 0x27, 0x2B, 0x1B, 0x71, 0x3C, 0x5B, 0xD6, 0x6F, 0x62, 0xAC, 0x4F, + 0xC2, 0xC0, 0xE, 0xB1, 0x23, 0xA7, 0xDF, 0x47, 0xB0, 0x77, 0x69, + 0x5, 0xE9, 0xE6, 0xE7, 0x76, 0x73, 0xF, 0xFE, 0x6E, 0x9B, 0x56, + 0xEF, 0x12, 0xA5, 0x37, 0xFC, 0xAE, 0xD9, 0x3, 0x8E, 0xDD, 0x10, + 0xB9, 0xCE, 0xC9, 0x8D, 0xDA, 0x2A, 0xBD, 0x68, 0x17, 0x9F, 0xBE, + 0xD4, 0xA, 0xCC, 0xD2, 0xE8, 0x43, 0x3D, 0x70, 0xB7, 0x2, 0x7D, + 0x99, 0xD8, 0xD, 0x60, 0x8A, 0x4, 0x2C, 0x3E, 0x92, 0xE5, 0xAF, + 0x53, 0x7, 0xE0, 0x29, 0xA6, 0xC5, 0xE3, 0xF5, 0xF7, 0x4A, 0x41, + 0x26, 0x6A, 0x16, 0x5E, 0x52, 0x2D, 0x21, 0xAD, 0xF0, 0x91, 0xFF, + 0xEA, 0x54, 0xFA, 0x66, 0x1A, 0x45, 0x39, 0xCF, 0x75, 0xA4, 0x88, + 0xFB, 0x5D, 0xA2, 0xA0, 0x19, 0x3B, 0xF8, 0xEB, 0xAA, 0xEE, 0xF3, + 0x1C, 0x67, 0x28, 0x1D, 0xED, 0x0, 0xDE, 0x95, 0x2E, 0xDC, 0x3F, + 0x3A, 0x82, 0x35, 0x4D, 0x6C, 0xBA, 0x36, 0xD0, 0xF6, 0xC, 0x79, + 0x32, 0xD1, 0x59, 0xF4, 0x8, 0x8B, 0x63, 0x89, 0x2F, 0xB8, 0xB4, + 0x97, 0x83, 0xF2, 0x8F, 0x18, 0xC7, 0x51, 0x14, 0x65, 0x87, 0x48, + 0x20, 0x42, 0xA8, 0x80, 0xB5, 0x40, 0x13, 0xB2, 0x22, 0x7E, 0x57, + 0xBC, 0x7F, 0x6B, 0x9D, 0x86, 0x4C, 0xC8, 0xDB, 0x7C, 0xD5, 0x25, + 0x4E, 0x5A, 0x55, 0x74, 0x50, 0xCD, 0xB3, 0x7A, 0xBB, 0xC3, 0xCB, + 0xB6, 0xE2, 0xE4, 0xEC, 0xFD, 0x98, 0xB, 0x96, 0xD3, 0x9E, 0x5C, + 0xA1, 0x64, 0xF1, 0x81, 0x61, 0xE1, 0xC4, 0x24, 0x72, 0x49, 0x8C, + 0x90, 0x4B, 0x84, 0x34, 0x38, 0xAB, 0x78, 0xCA, 0x1F, 0x1, 0xD7, + 0x93, 0x11, 0xC1, 0x58, 0xA9, 0x31, 0xF9, 0x44, 0x6D, 0xBF, 0x33, + 0x9C, 0x5F, 0x9, 0x94, 0xA3, 0x85, 0x6, 0xC6, 0x9A, 0x1E, 0x7B, + 0x46, 0x15, 0x30, 0x27, 0x2B, 0x1B, 0x71, 0x3C, 0x5B, 0xD6, 0x6F, + 0x62, 0xAC, 0x4F, 0xC2, 0xC0, 0xE, 0xB1, 0x23, 0xA7, 0xDF, 0x47, + 0xB0, 0x77, 0x69, 0x5, 0xE9, 0xE6, 0xE7, 0x76, 0x73, 0xF, 0xFE, + 0x6E, 0x9B, 0x56, 0xEF, 0x12, 0xA5, 0x37, 0xFC, 0xAE, 0xD9, 0x3, + 0x8E, 0xDD, 0x10, 0xB9, 0xCE, 0xC9, 0x8D, 0xDA, 0x2A, 0xBD, 0x68, + 0x17, 0x9F, 0xBE, 0xD4, 0xA, 0xCC, 0xD2, 0xE8, 0x43, 0x3D, 0x70, + 0xB7, 0x2, 0x7D, 0x99, 0xD8, 0xD, 0x60, 0x8A, 0x4, 0x2C, 0x3E, + 0x92, 0xE5, 0xAF, 0x53, 0x7, 0xE0, 0x29, 0xA6, 0xC5, 0xE3, 0xF5, + 0xF7, 0x4A, 0x41, 0x26, 0x6A, 0x16, 0x5E, 0x52, 0x2D, 0x21, 0xAD, + 0xF0, 0x91, 0xFF, 0xEA, 0x54, 0xFA, 0x66, 0x1A, 0x45, 0x39, 0xCF, + 0x75, 0xA4, 0x88, 0xFB, 0x5D }; + + private static float[] hashvectf = new float[] {// 768 + 0.33783f, 0.715698f, -0.611206f, -0.944031f, -0.326599f, -0.045624f, + -0.101074f, -0.416443f, -0.903503f, 0.799286f, 0.49411f, + -0.341949f, -0.854645f, 0.518036f, 0.033936f, 0.42514f, -0.437866f, + -0.792114f, -0.358948f, 0.597046f, 0.717377f, -0.985413f, + 0.144714f, 0.089294f, -0.601776f, -0.33728f, -0.723907f, + -0.449921f, 0.594513f, 0.666382f, 0.208313f, -0.10791f, 0.972076f, + 0.575317f, 0.060425f, 0.815643f, 0.293365f, -0.875702f, -0.383453f, + 0.293762f, 0.465759f, 0.834686f, -0.846008f, -0.233398f, -0.47934f, + -0.115814f, 0.143036f, -0.98291f, 0.204681f, -0.949036f, + -0.239532f, 0.946716f, -0.263947f, 0.184326f, -0.235596f, + 0.573822f, 0.784332f, 0.203705f, -0.372253f, -0.905487f, 0.756989f, + -0.651031f, 0.055298f, 0.497803f, 0.814697f, -0.297363f, -0.16214f, + 0.063995f, -0.98468f, -0.329254f, 0.834381f, 0.441925f, 0.703827f, + -0.527039f, -0.476227f, 0.956421f, 0.266113f, 0.119781f, 0.480133f, + 0.482849f, 0.7323f, -0.18631f, 0.961212f, -0.203125f, -0.748474f, + -0.656921f, -0.090393f, -0.085052f, -0.165253f, 0.982544f, + -0.76947f, 0.628174f, -0.115234f, 0.383148f, 0.537659f, 0.751068f, + 0.616486f, -0.668488f, -0.415924f, -0.259979f, -0.630005f, + 0.73175f, 0.570953f, -0.087952f, 0.816223f, -0.458008f, 0.023254f, + 0.888611f, -0.196167f, 0.976563f, -0.088287f, -0.263885f, + -0.69812f, -0.665527f, 0.437134f, -0.892273f, -0.112793f, + -0.621674f, -0.230438f, 0.748566f, 0.232422f, 0.900574f, + -0.367249f, 0.22229f, -0.796143f, 0.562744f, -0.665497f, -0.73764f, + 0.11377f, 0.670135f, 0.704803f, 0.232605f, 0.895599f, 0.429749f, + -0.114655f, -0.11557f, -0.474243f, 0.872742f, 0.621826f, 0.604004f, + -0.498444f, -0.832214f, 0.012756f, 0.55426f, -0.702484f, 0.705994f, + -0.089661f, -0.692017f, 0.649292f, 0.315399f, -0.175995f, + -0.977997f, 0.111877f, 0.096954f, -0.04953f, 0.994019f, 0.635284f, + -0.606689f, -0.477783f, -0.261261f, -0.607422f, -0.750153f, + 0.983276f, 0.165436f, 0.075958f, -0.29837f, 0.404083f, -0.864655f, + -0.638672f, 0.507721f, 0.578156f, 0.388214f, 0.412079f, 0.824249f, + 0.556183f, -0.208832f, 0.804352f, 0.778442f, 0.562012f, 0.27951f, + -0.616577f, 0.781921f, -0.091522f, 0.196289f, 0.051056f, 0.979187f, + -0.121216f, 0.207153f, -0.970734f, -0.173401f, -0.384735f, + 0.906555f, 0.161499f, -0.723236f, -0.671387f, 0.178497f, + -0.006226f, -0.983887f, -0.126038f, 0.15799f, 0.97934f, 0.830475f, + -0.024811f, 0.556458f, -0.510132f, -0.76944f, 0.384247f, 0.81424f, + 0.200104f, -0.544891f, -0.112549f, -0.393311f, -0.912445f, + 0.56189f, 0.152222f, -0.813049f, 0.198914f, -0.254517f, -0.946381f, + -0.41217f, 0.690979f, -0.593811f, -0.407257f, 0.324524f, 0.853668f, + -0.690186f, 0.366119f, -0.624115f, -0.428345f, 0.844147f, + -0.322296f, -0.21228f, -0.297546f, -0.930756f, -0.273071f, + 0.516113f, 0.811798f, 0.928314f, 0.371643f, 0.007233f, 0.785828f, + -0.479218f, -0.390778f, -0.704895f, 0.058929f, 0.706818f, + 0.173248f, 0.203583f, 0.963562f, 0.422211f, -0.904297f, -0.062469f, + -0.363312f, -0.182465f, 0.913605f, 0.254028f, -0.552307f, + -0.793945f, -0.28891f, -0.765747f, -0.574554f, 0.058319f, + 0.291382f, 0.954803f, 0.946136f, -0.303925f, 0.111267f, -0.078156f, + 0.443695f, -0.892731f, 0.182098f, 0.89389f, 0.409515f, -0.680298f, + -0.213318f, 0.701141f, 0.062469f, 0.848389f, -0.525635f, -0.72879f, + -0.641846f, 0.238342f, -0.88089f, 0.427673f, 0.202637f, -0.532501f, + -0.21405f, 0.818878f, 0.948975f, -0.305084f, 0.07962f, 0.925446f, + 0.374664f, 0.055817f, 0.820923f, 0.565491f, 0.079102f, 0.25882f, + 0.099792f, -0.960724f, -0.294617f, 0.910522f, 0.289978f, 0.137115f, + 0.320038f, -0.937408f, -0.908386f, 0.345276f, -0.235718f, + -0.936218f, 0.138763f, 0.322754f, 0.366577f, 0.925934f, -0.090637f, + 0.309296f, -0.686829f, -0.657684f, 0.66983f, 0.024445f, 0.742065f, + -0.917999f, -0.059113f, -0.392059f, 0.365509f, 0.462158f, + -0.807922f, 0.083374f, 0.996399f, -0.014801f, 0.593842f, 0.253143f, + -0.763672f, 0.974976f, -0.165466f, 0.148285f, 0.918976f, 0.137299f, + 0.369537f, 0.294952f, 0.694977f, 0.655731f, 0.943085f, 0.152618f, + -0.295319f, 0.58783f, -0.598236f, 0.544495f, 0.203796f, 0.678223f, + 0.705994f, -0.478821f, -0.661011f, 0.577667f, 0.719055f, -0.1698f, + -0.673828f, -0.132172f, -0.965332f, 0.225006f, -0.981873f, + -0.14502f, 0.121979f, 0.763458f, 0.579742f, 0.284546f, -0.893188f, + 0.079681f, 0.442474f, -0.795776f, -0.523804f, 0.303802f, 0.734955f, + 0.67804f, -0.007446f, 0.15506f, 0.986267f, -0.056183f, 0.258026f, + 0.571503f, -0.778931f, -0.681549f, -0.702087f, -0.206116f, + -0.96286f, -0.177185f, 0.203613f, -0.470978f, -0.515106f, + 0.716095f, -0.740326f, 0.57135f, 0.354095f, -0.56012f, -0.824982f, + -0.074982f, -0.507874f, 0.753204f, 0.417969f, -0.503113f, + 0.038147f, 0.863342f, 0.594025f, 0.673553f, -0.439758f, -0.119873f, + -0.005524f, -0.992737f, 0.098267f, -0.213776f, 0.971893f, + -0.615631f, 0.643951f, 0.454163f, 0.896851f, -0.441071f, 0.032166f, + -0.555023f, 0.750763f, -0.358093f, 0.398773f, 0.304688f, 0.864929f, + -0.722961f, 0.303589f, 0.620544f, -0.63559f, -0.621948f, + -0.457306f, -0.293243f, 0.072327f, 0.953278f, -0.491638f, + 0.661041f, -0.566772f, -0.304199f, -0.572083f, -0.761688f, + 0.908081f, -0.398956f, 0.127014f, -0.523621f, -0.549683f, + -0.650848f, -0.932922f, -0.19986f, 0.299408f, 0.099426f, 0.140869f, + 0.984985f, -0.020325f, -0.999756f, -0.002319f, 0.952667f, + 0.280853f, -0.11615f, -0.971893f, 0.082581f, 0.220337f, 0.65921f, + 0.705292f, -0.260651f, 0.733063f, -0.175537f, 0.657043f, + -0.555206f, 0.429504f, -0.712189f, 0.400421f, -0.89859f, 0.179352f, + 0.750885f, -0.19696f, 0.630341f, 0.785675f, -0.569336f, 0.241821f, + -0.058899f, -0.464111f, 0.883789f, 0.129608f, -0.94519f, 0.299622f, + -0.357819f, 0.907654f, 0.219238f, -0.842133f, -0.439117f, + -0.312927f, -0.313477f, 0.84433f, 0.434479f, -0.241211f, 0.053253f, + 0.968994f, 0.063873f, 0.823273f, 0.563965f, 0.476288f, 0.862152f, + -0.172516f, 0.620941f, -0.298126f, 0.724915f, 0.25238f, -0.749359f, + -0.612122f, -0.577545f, 0.386566f, 0.718994f, -0.406342f, + -0.737976f, 0.538696f, 0.04718f, 0.556305f, 0.82959f, -0.802856f, + 0.587463f, 0.101166f, -0.707733f, -0.705963f, 0.026428f, 0.374908f, + 0.68457f, 0.625092f, 0.472137f, 0.208405f, -0.856506f, -0.703064f, + -0.581085f, -0.409821f, -0.417206f, -0.736328f, 0.532623f, + -0.447876f, -0.20285f, -0.870728f, 0.086945f, -0.990417f, + 0.107086f, 0.183685f, 0.018341f, -0.982788f, 0.560638f, -0.428864f, + 0.708282f, 0.296722f, -0.952576f, -0.0672f, 0.135773f, 0.990265f, + 0.030243f, -0.068787f, 0.654724f, 0.752686f, 0.762604f, -0.551758f, + 0.337585f, -0.819611f, -0.407684f, 0.402466f, -0.727844f, + -0.55072f, -0.408539f, -0.855774f, -0.480011f, 0.19281f, 0.693176f, + -0.079285f, 0.716339f, 0.226013f, 0.650116f, -0.725433f, 0.246704f, + 0.953369f, -0.173553f, -0.970398f, -0.239227f, -0.03244f, + 0.136383f, -0.394318f, 0.908752f, 0.813232f, 0.558167f, 0.164368f, + 0.40451f, 0.549042f, -0.731323f, -0.380249f, -0.566711f, 0.730865f, + 0.022156f, 0.932739f, 0.359741f, 0.00824f, 0.996552f, -0.082306f, + 0.956635f, -0.065338f, -0.283722f, -0.743561f, 0.008209f, + 0.668579f, -0.859589f, -0.509674f, 0.035767f, -0.852234f, + 0.363678f, -0.375977f, -0.201965f, -0.970795f, -0.12915f, + 0.313477f, 0.947327f, 0.06546f, -0.254028f, -0.528259f, 0.81015f, + 0.628052f, 0.601105f, 0.49411f, -0.494385f, 0.868378f, 0.037933f, + 0.275635f, -0.086426f, 0.957336f, -0.197937f, 0.468903f, + -0.860748f, 0.895599f, 0.399384f, 0.195801f, 0.560791f, 0.825012f, + -0.069214f, 0.304199f, -0.849487f, 0.43103f, 0.096375f, 0.93576f, + 0.339111f, -0.051422f, 0.408966f, -0.911072f, 0.330444f, 0.942841f, + -0.042389f, -0.452362f, -0.786407f, 0.420563f, 0.134308f, + -0.933472f, -0.332489f, 0.80191f, -0.566711f, -0.188934f, + -0.987946f, -0.105988f, 0.112518f, -0.24408f, 0.892242f, + -0.379791f, -0.920502f, 0.229095f, -0.316376f, 0.7789f, 0.325958f, + 0.535706f, -0.912872f, 0.185211f, -0.36377f, -0.184784f, 0.565369f, + -0.803833f, -0.018463f, 0.119537f, 0.992615f, -0.259247f, + -0.935608f, 0.239532f, -0.82373f, -0.449127f, -0.345947f, + -0.433105f, 0.659515f, 0.614349f, -0.822754f, 0.378845f, + -0.423676f, 0.687195f, -0.674835f, -0.26889f, -0.246582f, + -0.800842f, 0.545715f, -0.729187f, -0.207794f, 0.651978f, + 0.653534f, -0.610443f, -0.447388f, 0.492584f, -0.023346f, + 0.869934f, 0.609039f, 0.009094f, -0.79306f, 0.962494f, -0.271088f, + -0.00885f, 0.2659f, -0.004913f, 0.963959f, 0.651245f, 0.553619f, + -0.518951f, 0.280548f, -0.84314f, 0.458618f, -0.175293f, + -0.983215f, 0.049805f, 0.035339f, -0.979919f, 0.196045f, + -0.982941f, 0.164307f, -0.082245f, 0.233734f, -0.97226f, + -0.005005f, -0.747253f, -0.611328f, 0.260437f, 0.645599f, + 0.592773f, 0.481384f, 0.117706f, -0.949524f, -0.29068f, -0.535004f, + -0.791901f, -0.294312f, -0.627167f, -0.214447f, 0.748718f, + -0.047974f, -0.813477f, -0.57959f, -0.175537f, 0.477264f, + -0.860992f, 0.738556f, -0.414246f, -0.53183f, 0.562561f, + -0.704071f, 0.433289f, -0.754944f, 0.64801f, -0.100586f, 0.114716f, + 0.044525f, -0.992371f, 0.966003f, 0.244873f, -0.082764f }; + + /* ********************* FROM PERLIN HIMSELF: ******************** */ + + // 512 + 2 + private static short[] p = new short[] { 0xA2, 0xA0, 0x19, 0x3B, 0xF8, + 0xEB, 0xAA, 0xEE, 0xF3, 0x1C, 0x67, 0x28, 0x1D, 0xED, 0x0, 0xDE, + 0x95, 0x2E, 0xDC, 0x3F, 0x3A, 0x82, 0x35, 0x4D, 0x6C, 0xBA, 0x36, + 0xD0, 0xF6, 0xC, 0x79, 0x32, 0xD1, 0x59, 0xF4, 0x8, 0x8B, 0x63, + 0x89, 0x2F, 0xB8, 0xB4, 0x97, 0x83, 0xF2, 0x8F, 0x18, 0xC7, 0x51, + 0x14, 0x65, 0x87, 0x48, 0x20, 0x42, 0xA8, 0x80, 0xB5, 0x40, 0x13, + 0xB2, 0x22, 0x7E, 0x57, 0xBC, 0x7F, 0x6B, 0x9D, 0x86, 0x4C, 0xC8, + 0xDB, 0x7C, 0xD5, 0x25, 0x4E, 0x5A, 0x55, 0x74, 0x50, 0xCD, 0xB3, + 0x7A, 0xBB, 0xC3, 0xCB, 0xB6, 0xE2, 0xE4, 0xEC, 0xFD, 0x98, 0xB, + 0x96, 0xD3, 0x9E, 0x5C, 0xA1, 0x64, 0xF1, 0x81, 0x61, 0xE1, 0xC4, + 0x24, 0x72, 0x49, 0x8C, 0x90, 0x4B, 0x84, 0x34, 0x38, 0xAB, 0x78, + 0xCA, 0x1F, 0x1, 0xD7, 0x93, 0x11, 0xC1, 0x58, 0xA9, 0x31, 0xF9, + 0x44, 0x6D, 0xBF, 0x33, 0x9C, 0x5F, 0x9, 0x94, 0xA3, 0x85, 0x6, + 0xC6, 0x9A, 0x1E, 0x7B, 0x46, 0x15, 0x30, 0x27, 0x2B, 0x1B, 0x71, + 0x3C, 0x5B, 0xD6, 0x6F, 0x62, 0xAC, 0x4F, 0xC2, 0xC0, 0xE, 0xB1, + 0x23, 0xA7, 0xDF, 0x47, 0xB0, 0x77, 0x69, 0x5, 0xE9, 0xE6, 0xE7, + 0x76, 0x73, 0xF, 0xFE, 0x6E, 0x9B, 0x56, 0xEF, 0x12, 0xA5, 0x37, + 0xFC, 0xAE, 0xD9, 0x3, 0x8E, 0xDD, 0x10, 0xB9, 0xCE, 0xC9, 0x8D, + 0xDA, 0x2A, 0xBD, 0x68, 0x17, 0x9F, 0xBE, 0xD4, 0xA, 0xCC, 0xD2, + 0xE8, 0x43, 0x3D, 0x70, 0xB7, 0x2, 0x7D, 0x99, 0xD8, 0xD, 0x60, + 0x8A, 0x4, 0x2C, 0x3E, 0x92, 0xE5, 0xAF, 0x53, 0x7, 0xE0, 0x29, + 0xA6, 0xC5, 0xE3, 0xF5, 0xF7, 0x4A, 0x41, 0x26, 0x6A, 0x16, 0x5E, + 0x52, 0x2D, 0x21, 0xAD, 0xF0, 0x91, 0xFF, 0xEA, 0x54, 0xFA, 0x66, + 0x1A, 0x45, 0x39, 0xCF, 0x75, 0xA4, 0x88, 0xFB, 0x5D, 0xA2, 0xA0, + 0x19, 0x3B, 0xF8, 0xEB, 0xAA, 0xEE, 0xF3, 0x1C, 0x67, 0x28, 0x1D, + 0xED, 0x0, 0xDE, 0x95, 0x2E, 0xDC, 0x3F, 0x3A, 0x82, 0x35, 0x4D, + 0x6C, 0xBA, 0x36, 0xD0, 0xF6, 0xC, 0x79, 0x32, 0xD1, 0x59, 0xF4, + 0x8, 0x8B, 0x63, 0x89, 0x2F, 0xB8, 0xB4, 0x97, 0x83, 0xF2, 0x8F, + 0x18, 0xC7, 0x51, 0x14, 0x65, 0x87, 0x48, 0x20, 0x42, 0xA8, 0x80, + 0xB5, 0x40, 0x13, 0xB2, 0x22, 0x7E, 0x57, 0xBC, 0x7F, 0x6B, 0x9D, + 0x86, 0x4C, 0xC8, 0xDB, 0x7C, 0xD5, 0x25, 0x4E, 0x5A, 0x55, 0x74, + 0x50, 0xCD, 0xB3, 0x7A, 0xBB, 0xC3, 0xCB, 0xB6, 0xE2, 0xE4, 0xEC, + 0xFD, 0x98, 0xB, 0x96, 0xD3, 0x9E, 0x5C, 0xA1, 0x64, 0xF1, 0x81, + 0x61, 0xE1, 0xC4, 0x24, 0x72, 0x49, 0x8C, 0x90, 0x4B, 0x84, 0x34, + 0x38, 0xAB, 0x78, 0xCA, 0x1F, 0x1, 0xD7, 0x93, 0x11, 0xC1, 0x58, + 0xA9, 0x31, 0xF9, 0x44, 0x6D, 0xBF, 0x33, 0x9C, 0x5F, 0x9, 0x94, + 0xA3, 0x85, 0x6, 0xC6, 0x9A, 0x1E, 0x7B, 0x46, 0x15, 0x30, 0x27, + 0x2B, 0x1B, 0x71, 0x3C, 0x5B, 0xD6, 0x6F, 0x62, 0xAC, 0x4F, 0xC2, + 0xC0, 0xE, 0xB1, 0x23, 0xA7, 0xDF, 0x47, 0xB0, 0x77, 0x69, 0x5, + 0xE9, 0xE6, 0xE7, 0x76, 0x73, 0xF, 0xFE, 0x6E, 0x9B, 0x56, 0xEF, + 0x12, 0xA5, 0x37, 0xFC, 0xAE, 0xD9, 0x3, 0x8E, 0xDD, 0x10, 0xB9, + 0xCE, 0xC9, 0x8D, 0xDA, 0x2A, 0xBD, 0x68, 0x17, 0x9F, 0xBE, 0xD4, + 0xA, 0xCC, 0xD2, 0xE8, 0x43, 0x3D, 0x70, 0xB7, 0x2, 0x7D, 0x99, + 0xD8, 0xD, 0x60, 0x8A, 0x4, 0x2C, 0x3E, 0x92, 0xE5, 0xAF, 0x53, + 0x7, 0xE0, 0x29, 0xA6, 0xC5, 0xE3, 0xF5, 0xF7, 0x4A, 0x41, 0x26, + 0x6A, 0x16, 0x5E, 0x52, 0x2D, 0x21, 0xAD, 0xF0, 0x91, 0xFF, 0xEA, + 0x54, 0xFA, 0x66, 0x1A, 0x45, 0x39, 0xCF, 0x75, 0xA4, 0x88, 0xFB, + 0x5D, 0xA2, 0xA0 }; + + // [512+2][3] + private static float[][] g = new float[][] { + { 0.33783f, 0.715698f, -0.611206f }, + { -0.944031f, -0.326599f, -0.045624f }, + { -0.101074f, -0.416443f, -0.903503f }, + { 0.799286f, 0.49411f, -0.341949f }, + { -0.854645f, 0.518036f, 0.033936f }, + { 0.42514f, -0.437866f, -0.792114f }, + { -0.358948f, 0.597046f, 0.717377f }, + { -0.985413f, 0.144714f, 0.089294f }, + { -0.601776f, -0.33728f, -0.723907f }, + { -0.449921f, 0.594513f, 0.666382f }, + { 0.208313f, -0.10791f, 0.972076f }, + { 0.575317f, 0.060425f, 0.815643f }, + { 0.293365f, -0.875702f, -0.383453f }, + { 0.293762f, 0.465759f, 0.834686f }, + { -0.846008f, -0.233398f, -0.47934f }, + { -0.115814f, 0.143036f, -0.98291f }, + { 0.204681f, -0.949036f, -0.239532f }, + { 0.946716f, -0.263947f, 0.184326f }, + { -0.235596f, 0.573822f, 0.784332f }, + { 0.203705f, -0.372253f, -0.905487f }, + { 0.756989f, -0.651031f, 0.055298f }, + { 0.497803f, 0.814697f, -0.297363f }, + { -0.16214f, 0.063995f, -0.98468f }, + { -0.329254f, 0.834381f, 0.441925f }, + { 0.703827f, -0.527039f, -0.476227f }, + { 0.956421f, 0.266113f, 0.119781f }, + { 0.480133f, 0.482849f, 0.7323f }, + { -0.18631f, 0.961212f, -0.203125f }, + { -0.748474f, -0.656921f, -0.090393f }, + { -0.085052f, -0.165253f, 0.982544f }, + { -0.76947f, 0.628174f, -0.115234f }, + { 0.383148f, 0.537659f, 0.751068f }, + { 0.616486f, -0.668488f, -0.415924f }, + { -0.259979f, -0.630005f, 0.73175f }, + { 0.570953f, -0.087952f, 0.816223f }, + { -0.458008f, 0.023254f, 0.888611f }, + { -0.196167f, 0.976563f, -0.088287f }, + { -0.263885f, -0.69812f, -0.665527f }, + { 0.437134f, -0.892273f, -0.112793f }, + { -0.621674f, -0.230438f, 0.748566f }, + { 0.232422f, 0.900574f, -0.367249f }, + { 0.22229f, -0.796143f, 0.562744f }, + { -0.665497f, -0.73764f, 0.11377f }, + { 0.670135f, 0.704803f, 0.232605f }, + { 0.895599f, 0.429749f, -0.114655f }, + { -0.11557f, -0.474243f, 0.872742f }, + { 0.621826f, 0.604004f, -0.498444f }, + { -0.832214f, 0.012756f, 0.55426f }, + { -0.702484f, 0.705994f, -0.089661f }, + { -0.692017f, 0.649292f, 0.315399f }, + { -0.175995f, -0.977997f, 0.111877f }, + { 0.096954f, -0.04953f, 0.994019f }, + { 0.635284f, -0.606689f, -0.477783f }, + { -0.261261f, -0.607422f, -0.750153f }, + { 0.983276f, 0.165436f, 0.075958f }, + { -0.29837f, 0.404083f, -0.864655f }, + { -0.638672f, 0.507721f, 0.578156f }, + { 0.388214f, 0.412079f, 0.824249f }, + { 0.556183f, -0.208832f, 0.804352f }, + { 0.778442f, 0.562012f, 0.27951f }, + { -0.616577f, 0.781921f, -0.091522f }, + { 0.196289f, 0.051056f, 0.979187f }, + { -0.121216f, 0.207153f, -0.970734f }, + { -0.173401f, -0.384735f, 0.906555f }, + { 0.161499f, -0.723236f, -0.671387f }, + { 0.178497f, -0.006226f, -0.983887f }, + { -0.126038f, 0.15799f, 0.97934f }, + { 0.830475f, -0.024811f, 0.556458f }, + { -0.510132f, -0.76944f, 0.384247f }, + { 0.81424f, 0.200104f, -0.544891f }, + { -0.112549f, -0.393311f, -0.912445f }, + { 0.56189f, 0.152222f, -0.813049f }, + { 0.198914f, -0.254517f, -0.946381f }, + { -0.41217f, 0.690979f, -0.593811f }, + { -0.407257f, 0.324524f, 0.853668f }, + { -0.690186f, 0.366119f, -0.624115f }, + { -0.428345f, 0.844147f, -0.322296f }, + { -0.21228f, -0.297546f, -0.930756f }, + { -0.273071f, 0.516113f, 0.811798f }, + { 0.928314f, 0.371643f, 0.007233f }, + { 0.785828f, -0.479218f, -0.390778f }, + { -0.704895f, 0.058929f, 0.706818f }, + { 0.173248f, 0.203583f, 0.963562f }, + { 0.422211f, -0.904297f, -0.062469f }, + { -0.363312f, -0.182465f, 0.913605f }, + { 0.254028f, -0.552307f, -0.793945f }, + { -0.28891f, -0.765747f, -0.574554f }, + { 0.058319f, 0.291382f, 0.954803f }, + { 0.946136f, -0.303925f, 0.111267f }, + { -0.078156f, 0.443695f, -0.892731f }, + { 0.182098f, 0.89389f, 0.409515f }, + { -0.680298f, -0.213318f, 0.701141f }, + { 0.062469f, 0.848389f, -0.525635f }, + { -0.72879f, -0.641846f, 0.238342f }, + { -0.88089f, 0.427673f, 0.202637f }, + { -0.532501f, -0.21405f, 0.818878f }, + { 0.948975f, -0.305084f, 0.07962f }, + { 0.925446f, 0.374664f, 0.055817f }, + { 0.820923f, 0.565491f, 0.079102f }, + { 0.25882f, 0.099792f, -0.960724f }, + { -0.294617f, 0.910522f, 0.289978f }, + { 0.137115f, 0.320038f, -0.937408f }, + { -0.908386f, 0.345276f, -0.235718f }, + { -0.936218f, 0.138763f, 0.322754f }, + { 0.366577f, 0.925934f, -0.090637f }, + { 0.309296f, -0.686829f, -0.657684f }, + { 0.66983f, 0.024445f, 0.742065f }, + { -0.917999f, -0.059113f, -0.392059f }, + { 0.365509f, 0.462158f, -0.807922f }, + { 0.083374f, 0.996399f, -0.014801f }, + { 0.593842f, 0.253143f, -0.763672f }, + { 0.974976f, -0.165466f, 0.148285f }, + { 0.918976f, 0.137299f, 0.369537f }, + { 0.294952f, 0.694977f, 0.655731f }, + { 0.943085f, 0.152618f, -0.295319f }, + { 0.58783f, -0.598236f, 0.544495f }, + { 0.203796f, 0.678223f, 0.705994f }, + { -0.478821f, -0.661011f, 0.577667f }, + { 0.719055f, -0.1698f, -0.673828f }, + { -0.132172f, -0.965332f, 0.225006f }, + { -0.981873f, -0.14502f, 0.121979f }, + { 0.763458f, 0.579742f, 0.284546f }, + { -0.893188f, 0.079681f, 0.442474f }, + { -0.795776f, -0.523804f, 0.303802f }, + { 0.734955f, 0.67804f, -0.007446f }, + { 0.15506f, 0.986267f, -0.056183f }, + { 0.258026f, 0.571503f, -0.778931f }, + { -0.681549f, -0.702087f, -0.206116f }, + { -0.96286f, -0.177185f, 0.203613f }, + { -0.470978f, -0.515106f, 0.716095f }, + { -0.740326f, 0.57135f, 0.354095f }, + { -0.56012f, -0.824982f, -0.074982f }, + { -0.507874f, 0.753204f, 0.417969f }, + { -0.503113f, 0.038147f, 0.863342f }, + { 0.594025f, 0.673553f, -0.439758f }, + { -0.119873f, -0.005524f, -0.992737f }, + { 0.098267f, -0.213776f, 0.971893f }, + { -0.615631f, 0.643951f, 0.454163f }, + { 0.896851f, -0.441071f, 0.032166f }, + { -0.555023f, 0.750763f, -0.358093f }, + { 0.398773f, 0.304688f, 0.864929f }, + { -0.722961f, 0.303589f, 0.620544f }, + { -0.63559f, -0.621948f, -0.457306f }, + { -0.293243f, 0.072327f, 0.953278f }, + { -0.491638f, 0.661041f, -0.566772f }, + { -0.304199f, -0.572083f, -0.761688f }, + { 0.908081f, -0.398956f, 0.127014f }, + { -0.523621f, -0.549683f, -0.650848f }, + { -0.932922f, -0.19986f, 0.299408f }, + { 0.099426f, 0.140869f, 0.984985f }, + { -0.020325f, -0.999756f, -0.002319f }, + { 0.952667f, 0.280853f, -0.11615f }, + { -0.971893f, 0.082581f, 0.220337f }, + { 0.65921f, 0.705292f, -0.260651f }, + { 0.733063f, -0.175537f, 0.657043f }, + { -0.555206f, 0.429504f, -0.712189f }, + { 0.400421f, -0.89859f, 0.179352f }, + { 0.750885f, -0.19696f, 0.630341f }, + { 0.785675f, -0.569336f, 0.241821f }, + { -0.058899f, -0.464111f, 0.883789f }, + { 0.129608f, -0.94519f, 0.299622f }, + { -0.357819f, 0.907654f, 0.219238f }, + { -0.842133f, -0.439117f, -0.312927f }, + { -0.313477f, 0.84433f, 0.434479f }, + { -0.241211f, 0.053253f, 0.968994f }, + { 0.063873f, 0.823273f, 0.563965f }, + { 0.476288f, 0.862152f, -0.172516f }, + { 0.620941f, -0.298126f, 0.724915f }, + { 0.25238f, -0.749359f, -0.612122f }, + { -0.577545f, 0.386566f, 0.718994f }, + { -0.406342f, -0.737976f, 0.538696f }, + { 0.04718f, 0.556305f, 0.82959f }, + { -0.802856f, 0.587463f, 0.101166f }, + { -0.707733f, -0.705963f, 0.026428f }, + { 0.374908f, 0.68457f, 0.625092f }, + { 0.472137f, 0.208405f, -0.856506f }, + { -0.703064f, -0.581085f, -0.409821f }, + { -0.417206f, -0.736328f, 0.532623f }, + { -0.447876f, -0.20285f, -0.870728f }, + { 0.086945f, -0.990417f, 0.107086f }, + { 0.183685f, 0.018341f, -0.982788f }, + { 0.560638f, -0.428864f, 0.708282f }, + { 0.296722f, -0.952576f, -0.0672f }, + { 0.135773f, 0.990265f, 0.030243f }, + { -0.068787f, 0.654724f, 0.752686f }, + { 0.762604f, -0.551758f, 0.337585f }, + { -0.819611f, -0.407684f, 0.402466f }, + { -0.727844f, -0.55072f, -0.408539f }, + { -0.855774f, -0.480011f, 0.19281f }, + { 0.693176f, -0.079285f, 0.716339f }, + { 0.226013f, 0.650116f, -0.725433f }, + { 0.246704f, 0.953369f, -0.173553f }, + { -0.970398f, -0.239227f, -0.03244f }, + { 0.136383f, -0.394318f, 0.908752f }, + { 0.813232f, 0.558167f, 0.164368f }, + { 0.40451f, 0.549042f, -0.731323f }, + { -0.380249f, -0.566711f, 0.730865f }, + { 0.022156f, 0.932739f, 0.359741f }, + { 0.00824f, 0.996552f, -0.082306f }, + { 0.956635f, -0.065338f, -0.283722f }, + { -0.743561f, 0.008209f, 0.668579f }, + { -0.859589f, -0.509674f, 0.035767f }, + { -0.852234f, 0.363678f, -0.375977f }, + { -0.201965f, -0.970795f, -0.12915f }, + { 0.313477f, 0.947327f, 0.06546f }, + { -0.254028f, -0.528259f, 0.81015f }, + { 0.628052f, 0.601105f, 0.49411f }, + { -0.494385f, 0.868378f, 0.037933f }, + { 0.275635f, -0.086426f, 0.957336f }, + { -0.197937f, 0.468903f, -0.860748f }, + { 0.895599f, 0.399384f, 0.195801f }, + { 0.560791f, 0.825012f, -0.069214f }, + { 0.304199f, -0.849487f, 0.43103f }, + { 0.096375f, 0.93576f, 0.339111f }, + { -0.051422f, 0.408966f, -0.911072f }, + { 0.330444f, 0.942841f, -0.042389f }, + { -0.452362f, -0.786407f, 0.420563f }, + { 0.134308f, -0.933472f, -0.332489f }, + { 0.80191f, -0.566711f, -0.188934f }, + { -0.987946f, -0.105988f, 0.112518f }, + { -0.24408f, 0.892242f, -0.379791f }, + { -0.920502f, 0.229095f, -0.316376f }, + { 0.7789f, 0.325958f, 0.535706f }, + { -0.912872f, 0.185211f, -0.36377f }, + { -0.184784f, 0.565369f, -0.803833f }, + { -0.018463f, 0.119537f, 0.992615f }, + { -0.259247f, -0.935608f, 0.239532f }, + { -0.82373f, -0.449127f, -0.345947f }, + { -0.433105f, 0.659515f, 0.614349f }, + { -0.822754f, 0.378845f, -0.423676f }, + { 0.687195f, -0.674835f, -0.26889f }, + { -0.246582f, -0.800842f, 0.545715f }, + { -0.729187f, -0.207794f, 0.651978f }, + { 0.653534f, -0.610443f, -0.447388f }, + { 0.492584f, -0.023346f, 0.869934f }, + { 0.609039f, 0.009094f, -0.79306f }, + { 0.962494f, -0.271088f, -0.00885f }, + { 0.2659f, -0.004913f, 0.963959f }, + { 0.651245f, 0.553619f, -0.518951f }, + { 0.280548f, -0.84314f, 0.458618f }, + { -0.175293f, -0.983215f, 0.049805f }, + { 0.035339f, -0.979919f, 0.196045f }, + { -0.982941f, 0.164307f, -0.082245f }, + { 0.233734f, -0.97226f, -0.005005f }, + { -0.747253f, -0.611328f, 0.260437f }, + { 0.645599f, 0.592773f, 0.481384f }, + { 0.117706f, -0.949524f, -0.29068f }, + { -0.535004f, -0.791901f, -0.294312f }, + { -0.627167f, -0.214447f, 0.748718f }, + { -0.047974f, -0.813477f, -0.57959f }, + { -0.175537f, 0.477264f, -0.860992f }, + { 0.738556f, -0.414246f, -0.53183f }, + { 0.562561f, -0.704071f, 0.433289f }, + { -0.754944f, 0.64801f, -0.100586f }, + { 0.114716f, 0.044525f, -0.992371f }, + { 0.966003f, 0.244873f, -0.082764f }, + { 0.33783f, 0.715698f, -0.611206f }, + { -0.944031f, -0.326599f, -0.045624f }, + { -0.101074f, -0.416443f, -0.903503f }, + { 0.799286f, 0.49411f, -0.341949f }, + { -0.854645f, 0.518036f, 0.033936f }, + { 0.42514f, -0.437866f, -0.792114f }, + { -0.358948f, 0.597046f, 0.717377f }, + { -0.985413f, 0.144714f, 0.089294f }, + { -0.601776f, -0.33728f, -0.723907f }, + { -0.449921f, 0.594513f, 0.666382f }, + { 0.208313f, -0.10791f, 0.972076f }, + { 0.575317f, 0.060425f, 0.815643f }, + { 0.293365f, -0.875702f, -0.383453f }, + { 0.293762f, 0.465759f, 0.834686f }, + { -0.846008f, -0.233398f, -0.47934f }, + { -0.115814f, 0.143036f, -0.98291f }, + { 0.204681f, -0.949036f, -0.239532f }, + { 0.946716f, -0.263947f, 0.184326f }, + { -0.235596f, 0.573822f, 0.784332f }, + { 0.203705f, -0.372253f, -0.905487f }, + { 0.756989f, -0.651031f, 0.055298f }, + { 0.497803f, 0.814697f, -0.297363f }, + { -0.16214f, 0.063995f, -0.98468f }, + { -0.329254f, 0.834381f, 0.441925f }, + { 0.703827f, -0.527039f, -0.476227f }, + { 0.956421f, 0.266113f, 0.119781f }, + { 0.480133f, 0.482849f, 0.7323f }, + { -0.18631f, 0.961212f, -0.203125f }, + { -0.748474f, -0.656921f, -0.090393f }, + { -0.085052f, -0.165253f, 0.982544f }, + { -0.76947f, 0.628174f, -0.115234f }, + { 0.383148f, 0.537659f, 0.751068f }, + { 0.616486f, -0.668488f, -0.415924f }, + { -0.259979f, -0.630005f, 0.73175f }, + { 0.570953f, -0.087952f, 0.816223f }, + { -0.458008f, 0.023254f, 0.888611f }, + { -0.196167f, 0.976563f, -0.088287f }, + { -0.263885f, -0.69812f, -0.665527f }, + { 0.437134f, -0.892273f, -0.112793f }, + { -0.621674f, -0.230438f, 0.748566f }, + { 0.232422f, 0.900574f, -0.367249f }, + { 0.22229f, -0.796143f, 0.562744f }, + { -0.665497f, -0.73764f, 0.11377f }, + { 0.670135f, 0.704803f, 0.232605f }, + { 0.895599f, 0.429749f, -0.114655f }, + { -0.11557f, -0.474243f, 0.872742f }, + { 0.621826f, 0.604004f, -0.498444f }, + { -0.832214f, 0.012756f, 0.55426f }, + { -0.702484f, 0.705994f, -0.089661f }, + { -0.692017f, 0.649292f, 0.315399f }, + { -0.175995f, -0.977997f, 0.111877f }, + { 0.096954f, -0.04953f, 0.994019f }, + { 0.635284f, -0.606689f, -0.477783f }, + { -0.261261f, -0.607422f, -0.750153f }, + { 0.983276f, 0.165436f, 0.075958f }, + { -0.29837f, 0.404083f, -0.864655f }, + { -0.638672f, 0.507721f, 0.578156f }, + { 0.388214f, 0.412079f, 0.824249f }, + { 0.556183f, -0.208832f, 0.804352f }, + { 0.778442f, 0.562012f, 0.27951f }, + { -0.616577f, 0.781921f, -0.091522f }, + { 0.196289f, 0.051056f, 0.979187f }, + { -0.121216f, 0.207153f, -0.970734f }, + { -0.173401f, -0.384735f, 0.906555f }, + { 0.161499f, -0.723236f, -0.671387f }, + { 0.178497f, -0.006226f, -0.983887f }, + { -0.126038f, 0.15799f, 0.97934f }, + { 0.830475f, -0.024811f, 0.556458f }, + { -0.510132f, -0.76944f, 0.384247f }, + { 0.81424f, 0.200104f, -0.544891f }, + { -0.112549f, -0.393311f, -0.912445f }, + { 0.56189f, 0.152222f, -0.813049f }, + { 0.198914f, -0.254517f, -0.946381f }, + { -0.41217f, 0.690979f, -0.593811f }, + { -0.407257f, 0.324524f, 0.853668f }, + { -0.690186f, 0.366119f, -0.624115f }, + { -0.428345f, 0.844147f, -0.322296f }, + { -0.21228f, -0.297546f, -0.930756f }, + { -0.273071f, 0.516113f, 0.811798f }, + { 0.928314f, 0.371643f, 0.007233f }, + { 0.785828f, -0.479218f, -0.390778f }, + { -0.704895f, 0.058929f, 0.706818f }, + { 0.173248f, 0.203583f, 0.963562f }, + { 0.422211f, -0.904297f, -0.062469f }, + { -0.363312f, -0.182465f, 0.913605f }, + { 0.254028f, -0.552307f, -0.793945f }, + { -0.28891f, -0.765747f, -0.574554f }, + { 0.058319f, 0.291382f, 0.954803f }, + { 0.946136f, -0.303925f, 0.111267f }, + { -0.078156f, 0.443695f, -0.892731f }, + { 0.182098f, 0.89389f, 0.409515f }, + { -0.680298f, -0.213318f, 0.701141f }, + { 0.062469f, 0.848389f, -0.525635f }, + { -0.72879f, -0.641846f, 0.238342f }, + { -0.88089f, 0.427673f, 0.202637f }, + { -0.532501f, -0.21405f, 0.818878f }, + { 0.948975f, -0.305084f, 0.07962f }, + { 0.925446f, 0.374664f, 0.055817f }, + { 0.820923f, 0.565491f, 0.079102f }, + { 0.25882f, 0.099792f, -0.960724f }, + { -0.294617f, 0.910522f, 0.289978f }, + { 0.137115f, 0.320038f, -0.937408f }, + { -0.908386f, 0.345276f, -0.235718f }, + { -0.936218f, 0.138763f, 0.322754f }, + { 0.366577f, 0.925934f, -0.090637f }, + { 0.309296f, -0.686829f, -0.657684f }, + { 0.66983f, 0.024445f, 0.742065f }, + { -0.917999f, -0.059113f, -0.392059f }, + { 0.365509f, 0.462158f, -0.807922f }, + { 0.083374f, 0.996399f, -0.014801f }, + { 0.593842f, 0.253143f, -0.763672f }, + { 0.974976f, -0.165466f, 0.148285f }, + { 0.918976f, 0.137299f, 0.369537f }, + { 0.294952f, 0.694977f, 0.655731f }, + { 0.943085f, 0.152618f, -0.295319f }, + { 0.58783f, -0.598236f, 0.544495f }, + { 0.203796f, 0.678223f, 0.705994f }, + { -0.478821f, -0.661011f, 0.577667f }, + { 0.719055f, -0.1698f, -0.673828f }, + { -0.132172f, -0.965332f, 0.225006f }, + { -0.981873f, -0.14502f, 0.121979f }, + { 0.763458f, 0.579742f, 0.284546f }, + { -0.893188f, 0.079681f, 0.442474f }, + { -0.795776f, -0.523804f, 0.303802f }, + { 0.734955f, 0.67804f, -0.007446f }, + { 0.15506f, 0.986267f, -0.056183f }, + { 0.258026f, 0.571503f, -0.778931f }, + { -0.681549f, -0.702087f, -0.206116f }, + { -0.96286f, -0.177185f, 0.203613f }, + { -0.470978f, -0.515106f, 0.716095f }, + { -0.740326f, 0.57135f, 0.354095f }, + { -0.56012f, -0.824982f, -0.074982f }, + { -0.507874f, 0.753204f, 0.417969f }, + { -0.503113f, 0.038147f, 0.863342f }, + { 0.594025f, 0.673553f, -0.439758f }, + { -0.119873f, -0.005524f, -0.992737f }, + { 0.098267f, -0.213776f, 0.971893f }, + { -0.615631f, 0.643951f, 0.454163f }, + { 0.896851f, -0.441071f, 0.032166f }, + { -0.555023f, 0.750763f, -0.358093f }, + { 0.398773f, 0.304688f, 0.864929f }, + { -0.722961f, 0.303589f, 0.620544f }, + { -0.63559f, -0.621948f, -0.457306f }, + { -0.293243f, 0.072327f, 0.953278f }, + { -0.491638f, 0.661041f, -0.566772f }, + { -0.304199f, -0.572083f, -0.761688f }, + { 0.908081f, -0.398956f, 0.127014f }, + { -0.523621f, -0.549683f, -0.650848f }, + { -0.932922f, -0.19986f, 0.299408f }, + { 0.099426f, 0.140869f, 0.984985f }, + { -0.020325f, -0.999756f, -0.002319f }, + { 0.952667f, 0.280853f, -0.11615f }, + { -0.971893f, 0.082581f, 0.220337f }, + { 0.65921f, 0.705292f, -0.260651f }, + { 0.733063f, -0.175537f, 0.657043f }, + { -0.555206f, 0.429504f, -0.712189f }, + { 0.400421f, -0.89859f, 0.179352f }, + { 0.750885f, -0.19696f, 0.630341f }, + { 0.785675f, -0.569336f, 0.241821f }, + { -0.058899f, -0.464111f, 0.883789f }, + { 0.129608f, -0.94519f, 0.299622f }, + { -0.357819f, 0.907654f, 0.219238f }, + { -0.842133f, -0.439117f, -0.312927f }, + { -0.313477f, 0.84433f, 0.434479f }, + { -0.241211f, 0.053253f, 0.968994f }, + { 0.063873f, 0.823273f, 0.563965f }, + { 0.476288f, 0.862152f, -0.172516f }, + { 0.620941f, -0.298126f, 0.724915f }, + { 0.25238f, -0.749359f, -0.612122f }, + { -0.577545f, 0.386566f, 0.718994f }, + { -0.406342f, -0.737976f, 0.538696f }, + { 0.04718f, 0.556305f, 0.82959f }, + { -0.802856f, 0.587463f, 0.101166f }, + { -0.707733f, -0.705963f, 0.026428f }, + { 0.374908f, 0.68457f, 0.625092f }, + { 0.472137f, 0.208405f, -0.856506f }, + { -0.703064f, -0.581085f, -0.409821f }, + { -0.417206f, -0.736328f, 0.532623f }, + { -0.447876f, -0.20285f, -0.870728f }, + { 0.086945f, -0.990417f, 0.107086f }, + { 0.183685f, 0.018341f, -0.982788f }, + { 0.560638f, -0.428864f, 0.708282f }, + { 0.296722f, -0.952576f, -0.0672f }, + { 0.135773f, 0.990265f, 0.030243f }, + { -0.068787f, 0.654724f, 0.752686f }, + { 0.762604f, -0.551758f, 0.337585f }, + { -0.819611f, -0.407684f, 0.402466f }, + { -0.727844f, -0.55072f, -0.408539f }, + { -0.855774f, -0.480011f, 0.19281f }, + { 0.693176f, -0.079285f, 0.716339f }, + { 0.226013f, 0.650116f, -0.725433f }, + { 0.246704f, 0.953369f, -0.173553f }, + { -0.970398f, -0.239227f, -0.03244f }, + { 0.136383f, -0.394318f, 0.908752f }, + { 0.813232f, 0.558167f, 0.164368f }, + { 0.40451f, 0.549042f, -0.731323f }, + { -0.380249f, -0.566711f, 0.730865f }, + { 0.022156f, 0.932739f, 0.359741f }, + { 0.00824f, 0.996552f, -0.082306f }, + { 0.956635f, -0.065338f, -0.283722f }, + { -0.743561f, 0.008209f, 0.668579f }, + { -0.859589f, -0.509674f, 0.035767f }, + { -0.852234f, 0.363678f, -0.375977f }, + { -0.201965f, -0.970795f, -0.12915f }, + { 0.313477f, 0.947327f, 0.06546f }, + { -0.254028f, -0.528259f, 0.81015f }, + { 0.628052f, 0.601105f, 0.49411f }, + { -0.494385f, 0.868378f, 0.037933f }, + { 0.275635f, -0.086426f, 0.957336f }, + { -0.197937f, 0.468903f, -0.860748f }, + { 0.895599f, 0.399384f, 0.195801f }, + { 0.560791f, 0.825012f, -0.069214f }, + { 0.304199f, -0.849487f, 0.43103f }, + { 0.096375f, 0.93576f, 0.339111f }, + { -0.051422f, 0.408966f, -0.911072f }, + { 0.330444f, 0.942841f, -0.042389f }, + { -0.452362f, -0.786407f, 0.420563f }, + { 0.134308f, -0.933472f, -0.332489f }, + { 0.80191f, -0.566711f, -0.188934f }, + { -0.987946f, -0.105988f, 0.112518f }, + { -0.24408f, 0.892242f, -0.379791f }, + { -0.920502f, 0.229095f, -0.316376f }, + { 0.7789f, 0.325958f, 0.535706f }, + { -0.912872f, 0.185211f, -0.36377f }, + { -0.184784f, 0.565369f, -0.803833f }, + { -0.018463f, 0.119537f, 0.992615f }, + { -0.259247f, -0.935608f, 0.239532f }, + { -0.82373f, -0.449127f, -0.345947f }, + { -0.433105f, 0.659515f, 0.614349f }, + { -0.822754f, 0.378845f, -0.423676f }, + { 0.687195f, -0.674835f, -0.26889f }, + { -0.246582f, -0.800842f, 0.545715f }, + { -0.729187f, -0.207794f, 0.651978f }, + { 0.653534f, -0.610443f, -0.447388f }, + { 0.492584f, -0.023346f, 0.869934f }, + { 0.609039f, 0.009094f, -0.79306f }, + { 0.962494f, -0.271088f, -0.00885f }, + { 0.2659f, -0.004913f, 0.963959f }, + { 0.651245f, 0.553619f, -0.518951f }, + { 0.280548f, -0.84314f, 0.458618f }, + { -0.175293f, -0.983215f, 0.049805f }, + { 0.035339f, -0.979919f, 0.196045f }, + { -0.982941f, 0.164307f, -0.082245f }, + { 0.233734f, -0.97226f, -0.005005f }, + { -0.747253f, -0.611328f, 0.260437f }, + { 0.645599f, 0.592773f, 0.481384f }, + { 0.117706f, -0.949524f, -0.29068f }, + { -0.535004f, -0.791901f, -0.294312f }, + { -0.627167f, -0.214447f, 0.748718f }, + { -0.047974f, -0.813477f, -0.57959f }, + { -0.175537f, 0.477264f, -0.860992f }, + { 0.738556f, -0.414246f, -0.53183f }, + { 0.562561f, -0.704071f, 0.433289f }, + { -0.754944f, 0.64801f, -0.100586f }, + { 0.114716f, 0.044525f, -0.992371f }, + { 0.966003f, 0.244873f, -0.082764f }, + { 0.33783f, 0.715698f, -0.611206f }, + { -0.944031f, -0.326599f, -0.045624f } }; + +} diff --git a/engine/src/test/jme3test/blender/scene/Pivot.java b/engine/src/test/jme3test/blender/scene/Pivot.java new file mode 100644 index 000000000..ecb14defb --- /dev/null +++ b/engine/src/test/jme3test/blender/scene/Pivot.java @@ -0,0 +1,53 @@ +package jme3test.blender.scene; + +import com.jme3.asset.AssetManager; +import com.jme3.material.Material; +import com.jme3.math.ColorRGBA; +import com.jme3.math.Vector3f; +import com.jme3.scene.Geometry; +import com.jme3.scene.Node; +import com.jme3.scene.shape.Line; +import com.jme3.scene.shape.Sphere; + +/** + * The pivot displayed in the scene. + * @author Marcin Roguski + */ +public class Pivot extends Node { + public Pivot(AssetManager assetManager) { + this.attachChild(this.getAxis("x", new Vector3f(10, 0, 0), ColorRGBA.Red, assetManager)); + this.attachChild(this.getAxis("y", new Vector3f(0, 10, 0), ColorRGBA.Green, assetManager)); + this.attachChild(this.getAxis("z", new Vector3f(0, 0, 10), ColorRGBA.Blue, assetManager)); + this.assignPoints(assetManager); + } + + private void assignPoints(AssetManager assetManager) { + Material defaultMaterial = new Material(assetManager, "Common/MatDefs/Misc/SolidColor.j3md"); + defaultMaterial.setColor("m_Color", ColorRGBA.DarkGray); + for(int i = -10; i <= 10; ++i) { + Geometry g = new Geometry("", new Sphere(3, 3, 0.05f)); + g.setLocalTranslation(i, 0, 0); + g.setMaterial(defaultMaterial); + this.attachChild(g); + + g = new Geometry("", new Sphere(3, 3, 0.05f)); + g.setLocalTranslation(0, i, 0); + g.setMaterial(defaultMaterial); + this.attachChild(g); + + g = new Geometry("", new Sphere(3, 3, 0.05f)); + g.setLocalTranslation(0, 0, i); + g.setMaterial(defaultMaterial); + this.attachChild(g); + } + } + + private Geometry getAxis(String name, Vector3f endPoint, ColorRGBA color, AssetManager assetManager) { + Line axis = new Line(new Vector3f(0, 0, 0), endPoint); + Material mat = new Material(assetManager, "Common/MatDefs/Misc/SolidColor.j3md"); + mat.setColor("m_Color", color); + Geometry geom = new Geometry(name, axis); + geom.setMaterial(mat); + return geom; + } +} \ No newline at end of file diff --git a/engine/src/test/jme3test/blender/scene/VisibleBone.java b/engine/src/test/jme3test/blender/scene/VisibleBone.java new file mode 100644 index 000000000..18ee7649b --- /dev/null +++ b/engine/src/test/jme3test/blender/scene/VisibleBone.java @@ -0,0 +1,47 @@ +package jme3test.blender.scene; + +import com.jme3.animation.Bone; +import com.jme3.asset.AssetManager; +import com.jme3.material.Material; +import com.jme3.math.ColorRGBA; +import com.jme3.math.Quaternion; +import com.jme3.math.Vector3f; +import com.jme3.scene.Geometry; +import com.jme3.scene.Node; +import com.jme3.scene.shape.Line; +import com.jme3.scene.shape.Sphere; + +/** + * A simple class to create visualization of a skeleton. + * @author Marcin Roguski + */ +public class VisibleBone extends Node { + private Vector3f globalPosition; + + public VisibleBone(Bone bone, Vector3f parentLocation, Quaternion parentRotation, AssetManager assetManager) { + Material redMat = new Material(assetManager, "Common/MatDefs/Misc/SolidColor.j3md"); + redMat.setColor("m_Color", ColorRGBA.Red); + + Material whiteMat = new Material(assetManager, "Common/MatDefs/Misc/SolidColor.j3md"); + whiteMat.setColor("m_Color", ColorRGBA.White); + + Geometry g = new Geometry(bone.getName(), new Sphere(9, 9, 0.01f)); + globalPosition = bone.getLocalPosition().add(parentLocation); + g.setLocalTranslation(globalPosition); + g.setLocalRotation(bone.getLocalRotation().mult(parentRotation)); + g.setMaterial(redMat); + this.attachChild(g); + + if(bone.getChildren() != null) { + for(Bone child : bone.getChildren()) { + VisibleBone vb = new VisibleBone(child, bone.getLocalPosition(), bone.getLocalRotation(), assetManager); + this.attachChild(vb); + Line line = new Line(globalPosition, vb.globalPosition); + line.setLineWidth(2); + Geometry geom = new Geometry("", line); + geom.setMaterial(whiteMat); + this.attachChild(geom); + } + } + } +} \ No newline at end of file