|
| 1 | +package com.ss.editor.ui.control.model.tree.action; |
| 2 | + |
| 3 | +import com.jme3.asset.AssetManager; |
| 4 | +import com.jme3.scene.Spatial; |
| 5 | +import com.ss.editor.FileExtensions; |
| 6 | +import com.ss.editor.Messages; |
| 7 | +import com.ss.editor.ui.control.model.tree.ModelNodeTree; |
| 8 | +import com.ss.editor.ui.control.model.tree.node.ModelNode; |
| 9 | +import com.ss.editor.ui.control.model.tree.node.ModelNodeFactory; |
| 10 | +import com.ss.editor.ui.dialog.asset.AssetEditorDialog; |
| 11 | +import com.ss.editor.ui.scene.EditorFXScene; |
| 12 | +import com.ss.editor.util.EditorUtil; |
| 13 | + |
| 14 | +import java.nio.file.Path; |
| 15 | + |
| 16 | +import rlib.util.array.Array; |
| 17 | +import rlib.util.array.ArrayFactory; |
| 18 | + |
| 19 | +/** |
| 20 | + * Реализация действия по загрузки другой модели в эту. |
| 21 | + * |
| 22 | + * @author Ronn |
| 23 | + */ |
| 24 | +public class LoadModelAction extends AbstractNodeAction { |
| 25 | + |
| 26 | + private static final Array<String> MODEL_EXTENSIONS = ArrayFactory.newArray(String.class); |
| 27 | + |
| 28 | + static { |
| 29 | + MODEL_EXTENSIONS.add(FileExtensions.JME_OBJECT); |
| 30 | + } |
| 31 | + |
| 32 | + public LoadModelAction(final ModelNodeTree nodeTree, final ModelNode<?> node) { |
| 33 | + super(nodeTree, node); |
| 34 | + } |
| 35 | + |
| 36 | + @Override |
| 37 | + protected String getName() { |
| 38 | + return Messages.MODEL_NODE_TREE_ACTION_LOAD_MODEL; |
| 39 | + } |
| 40 | + |
| 41 | + @Override |
| 42 | + protected void process() { |
| 43 | + |
| 44 | + final EditorFXScene scene = EDITOR.getScene(); |
| 45 | + |
| 46 | + final AssetEditorDialog dialog = new AssetEditorDialog(this::processOpen); |
| 47 | + dialog.setExtensionFilter(MODEL_EXTENSIONS); |
| 48 | + dialog.show(scene.getWindow()); |
| 49 | + } |
| 50 | + |
| 51 | + /** |
| 52 | + * Процесс открытия файла. |
| 53 | + */ |
| 54 | + protected void processOpen(final Path file) { |
| 55 | + |
| 56 | + final Path assetFile = EditorUtil.getAssetFile(file); |
| 57 | + final String assetPath = EditorUtil.toAssetPath(assetFile); |
| 58 | + |
| 59 | + final AssetManager assetManager = EDITOR.getAssetManager(); |
| 60 | + assetManager.clearCache(); |
| 61 | + |
| 62 | + final Spatial loadedModel = assetManager.loadModel(assetPath); |
| 63 | + |
| 64 | + EXECUTOR_MANAGER.addEditorThreadTask(() -> { |
| 65 | + |
| 66 | + final ModelNode<Spatial> newNode = ModelNodeFactory.createFor(loadedModel); |
| 67 | + final ModelNode<?> modelNode = getNode(); |
| 68 | + modelNode.add(newNode); |
| 69 | + |
| 70 | + EXECUTOR_MANAGER.addFXTask(() -> { |
| 71 | + final ModelNodeTree nodeTree = getNodeTree(); |
| 72 | + nodeTree.notifyAdded(modelNode, newNode); |
| 73 | + }); |
| 74 | + }); |
| 75 | + } |
| 76 | +} |
0 commit comments