Allow changing importers in the import dock.
Still needs a major refactor to allow editing the properties of the new importer without having to reimport and re-select the items again.
This commit is contained in:
parent
19b1ff0fc5
commit
21b3d62237
@ -263,6 +263,14 @@ void ImportDock::set_edit_multiple_paths(const Vector<String> &p_paths) {
|
|||||||
imported->set_text(itos(p_paths.size()) + TTR(" Files"));
|
imported->set_text(itos(p_paths.size()) + TTR(" Files"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ImportDock::_importer_selected(int i_idx) {
|
||||||
|
String name = import_as->get_selected_metadata();
|
||||||
|
Ref<ResourceImporter> importer = ResourceFormatImporter::get_singleton()->get_importer_by_name(name);
|
||||||
|
ERR_FAIL_COND(importer.is_null());
|
||||||
|
|
||||||
|
params->importer = importer;
|
||||||
|
}
|
||||||
|
|
||||||
void ImportDock::_preset_selected(int p_idx) {
|
void ImportDock::_preset_selected(int p_idx) {
|
||||||
|
|
||||||
int item_id = preset->get_popup()->get_item_id(p_idx);
|
int item_id = preset->get_popup()->get_item_id(p_idx);
|
||||||
@ -336,6 +344,7 @@ void ImportDock::_reimport() {
|
|||||||
Error err = config->load(params->paths[i] + ".import");
|
Error err = config->load(params->paths[i] + ".import");
|
||||||
ERR_CONTINUE(err != OK);
|
ERR_CONTINUE(err != OK);
|
||||||
|
|
||||||
|
config->set_value("remap", "importer", params->importer->get_importer_name());
|
||||||
config->erase_section("params");
|
config->erase_section("params");
|
||||||
|
|
||||||
for (List<PropertyInfo>::Element *E = params->properties.front(); E; E = E->next()) {
|
for (List<PropertyInfo>::Element *E = params->properties.front(); E; E = E->next()) {
|
||||||
@ -367,6 +376,7 @@ void ImportDock::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("_reimport"), &ImportDock::_reimport);
|
ClassDB::bind_method(D_METHOD("_reimport"), &ImportDock::_reimport);
|
||||||
ClassDB::bind_method(D_METHOD("_preset_selected"), &ImportDock::_preset_selected);
|
ClassDB::bind_method(D_METHOD("_preset_selected"), &ImportDock::_preset_selected);
|
||||||
|
ClassDB::bind_method(D_METHOD("_importer_selected"), &ImportDock::_importer_selected);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImportDock::initialize_import_options() const {
|
void ImportDock::initialize_import_options() const {
|
||||||
@ -384,6 +394,7 @@ ImportDock::ImportDock() {
|
|||||||
HBoxContainer *hb = memnew(HBoxContainer);
|
HBoxContainer *hb = memnew(HBoxContainer);
|
||||||
add_margin_child(TTR("Import As:"), hb);
|
add_margin_child(TTR("Import As:"), hb);
|
||||||
import_as = memnew(OptionButton);
|
import_as = memnew(OptionButton);
|
||||||
|
import_as->connect("item_selected", this, "_importer_selected");
|
||||||
hb->add_child(import_as);
|
hb->add_child(import_as);
|
||||||
import_as->set_h_size_flags(SIZE_EXPAND_FILL);
|
import_as->set_h_size_flags(SIZE_EXPAND_FILL);
|
||||||
preset = memnew(MenuButton);
|
preset = memnew(MenuButton);
|
||||||
|
@ -54,6 +54,7 @@ class ImportDock : public VBoxContainer {
|
|||||||
ImportDockParameters *params;
|
ImportDockParameters *params;
|
||||||
|
|
||||||
void _preset_selected(int p_idx);
|
void _preset_selected(int p_idx);
|
||||||
|
void _importer_selected(int i_idx);
|
||||||
|
|
||||||
void _reimport();
|
void _reimport();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user