mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-11 05:19:50 +01:00
The MMCreateNamePopup should be finished now.
This commit is contained in:
parent
7af9c93c3f
commit
0f7a6fb070
@ -308,21 +308,6 @@ public:
|
|||||||
|
|
||||||
static Vector<MMNodeRegistryCategory> mm_node_registry;
|
static Vector<MMNodeRegistryCategory> mm_node_registry;
|
||||||
|
|
||||||
//register, unregister etc.
|
|
||||||
|
|
||||||
// Add it to the MMAlgos bing class instead.;
|
|
||||||
// Not a perfect fit, but a better fit.;
|
|
||||||
//func editor_register_node_class(category : String, cls : String);
|
|
||||||
// -> c++ method, adds node to the editor gui (add button);
|
|
||||||
// in gdscript a plugin should instance an MMNode and call it to populate the add menu;
|
|
||||||
// with MMNodes;
|
|
||||||
// in c++ it should have a static counterpart.;
|
|
||||||
// register_types should populate c++ types with this;
|
|
||||||
//func editor_unregister_node_class(category : String, cls : String);
|
|
||||||
//func editor_register_node_script(category : String, script_path : String);
|
|
||||||
// same as the above, but for scripts;
|
|
||||||
//func editor_unregister_node_script(category : String, cls : String);
|
|
||||||
|
|
||||||
MMAlgos();
|
MMAlgos();
|
||||||
~MMAlgos();
|
~MMAlgos();
|
||||||
|
|
||||||
|
@ -1,65 +1,66 @@
|
|||||||
|
|
||||||
#include "mm_create_name_popup.h"
|
#include "mm_create_name_popup.h"
|
||||||
|
|
||||||
|
#include "../algos/mm_algos.h"
|
||||||
#include "scene/gui/box_container.h"
|
#include "scene/gui/box_container.h"
|
||||||
#include "scene/gui/label.h"
|
#include "scene/gui/label.h"
|
||||||
#include "scene/gui/tree.h"
|
#include "scene/gui/tree.h"
|
||||||
|
|
||||||
void MMCreateNamePopup::about_to_show() {
|
void MMCreateNamePopup::about_to_show() {
|
||||||
|
if (_initialized) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_initialized = true;
|
||||||
|
|
||||||
_tree->clear();
|
_tree->clear();
|
||||||
TreeItem *root = _tree->create_item();
|
TreeItem *root = _tree->create_item();
|
||||||
|
|
||||||
//for (s in type_folders) {
|
for (int i = 0; i < MMAlgos::mm_node_registry.size(); ++i) {
|
||||||
// evaluate_folder(s, root);
|
const MMAlgos::MMNodeRegistryCategory &category = MMAlgos::mm_node_registry[i];
|
||||||
//}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
TreeItem *ti = _tree->create_item(root);
|
||||||
void MMCreateNamePopup::evaluate_folder(const String &folder, const TreeItem &root) {
|
ti->set_text(0, category.category_name);
|
||||||
TreeItem *ti = _tree.create_item(root);
|
|
||||||
ti.set_text(0, folder.substr(folder.find_last("/") + 1));
|
|
||||||
Variant = Directory.new();
|
|
||||||
|
|
||||||
if (dir.open(folder) == OK) {
|
for (int j = 0; j < category.entries.size(); ++j) {
|
||||||
dir.list_dir_begin();
|
const MMAlgos::MMNodeRegistryEntry &e = category.entries[j];
|
||||||
Variant = dir.get_next();
|
|
||||||
|
|
||||||
while (file_name != "") {
|
TreeItem *ce = _tree->create_item(ti);
|
||||||
if (!dir.current_is_dir()) {
|
|
||||||
print("Found file: " + file_name);
|
if (e.type == MMAlgos::MMNODE_REGISTRY_TYPE_CLASS) {
|
||||||
TreeItem *e = _tree.create_item(ti);
|
ce->set_text(0, e.data);
|
||||||
e.set_text(0, file_name.get_file());
|
ce->set_meta("node_type", static_cast<int>(MMAlgos::MMNODE_REGISTRY_TYPE_CLASS));
|
||||||
e.set_meta("file", folder + "/" + file_name);
|
} else if (e.type == MMAlgos::MMNODE_REGISTRY_TYPE_SCRIPT) {
|
||||||
|
ce->set_text(0, e.data.get_file());
|
||||||
|
ce->set_meta("node_type", static_cast<int>(MMAlgos::MMNODE_REGISTRY_TYPE_SCRIPT));
|
||||||
}
|
}
|
||||||
|
|
||||||
file_name = dir.get_next();
|
ce->set_meta("data", e.data);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
else {
|
|
||||||
print("An error occurred when trying to access the path.");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
||||||
void MMCreateNamePopup::_on_OK_pressed() {
|
void MMCreateNamePopup::_on_OK_pressed() {
|
||||||
TreeItem *selected = _tree->get_selected();
|
TreeItem *selected = _tree->get_selected();
|
||||||
|
|
||||||
if (selected) {
|
if (selected) {
|
||||||
if (!selected->has_meta("file")) {
|
if (!selected->has_meta("node_type")) {
|
||||||
hide();
|
hide();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
String file_name = selected->get_meta("file");
|
int type = selected->get_meta("node_type");
|
||||||
emit_signal("ok_pressed", file_name);
|
String data = selected->get_meta("data");
|
||||||
|
|
||||||
|
emit_signal("ok_pressed", type, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
hide();
|
hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
MMCreateNamePopup::MMCreateNamePopup() {
|
MMCreateNamePopup::MMCreateNamePopup() {
|
||||||
|
_initialized = false;
|
||||||
|
|
||||||
set_anchors_and_margins_preset(LayoutPreset::PRESET_CENTER);
|
set_anchors_and_margins_preset(LayoutPreset::PRESET_CENTER);
|
||||||
set_size(Vector2(491, 440));
|
set_size(Vector2(491, 440));
|
||||||
set_title("Create New Resource");
|
set_title("Create New Resource");
|
||||||
|
@ -33,6 +33,7 @@ protected:
|
|||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
Tree *_tree;
|
Tree *_tree;
|
||||||
|
bool _initialized;
|
||||||
};
|
};
|
||||||
|
|
||||||
VARIANT_ENUM_CAST(MMCreateNamePopup::OKPressedType);
|
VARIANT_ENUM_CAST(MMCreateNamePopup::OKPressedType);
|
||||||
|
Loading…
Reference in New Issue
Block a user