#include "editor_import_collada_mdr.h" String EditorImportColladaMdr::get_importer_name() const { return "collada_mdr"; } String EditorImportColladaMdr::get_visible_name() const { return "Collada MDR"; } void EditorImportColladaMdr::get_recognized_extensions(List *p_extensions) const { p_extensions->push_back("dae"); } String EditorImportColladaMdr::get_save_extension() const { return "res"; } String EditorImportColladaMdr::get_resource_type() const { return "MeshDataResource"; } float EditorImportColladaMdr::get_priority() const { return 1.0; } int EditorImportColladaMdr::get_preset_count() const { return 0; } String EditorImportColladaMdr::get_preset_name(int p_idx) const { return ""; } void EditorImportColladaMdr::get_import_options(List *r_options, int p_preset) const { r_options->push_back(ImportOption(PropertyInfo(Variant::VECTOR3, "offset"), Vector3(0, 0, 0))); r_options->push_back(ImportOption(PropertyInfo(Variant::VECTOR3, "rotation"), Vector3(0, 0, -(3.141592 / 2.0)))); r_options->push_back(ImportOption(PropertyInfo(Variant::VECTOR3, "scale"), Vector3(0.011, 0.011, 0.011))); } bool EditorImportColladaMdr::get_option_visibility(const String &p_option, const Map &p_options) const { return true; } Error EditorImportColladaMdr::import(const String &p_source_file, const String &p_save_path, const Map &p_options, List *r_platform_variants, List *r_gen_files, Variant *r_metadata) { Node *n = _importer->import_scene(p_source_file, 0, 15); if (n == NULL) { n->queue_delete(); return Error::ERR_PARSE_ERROR; } for (int i = 0; i < n->get_child_count(); ++i) { Node *c = n->get_child(i); print_error(String::num(i)); if (c == NULL) { continue; } if (Object::cast_to(c)) { MeshInstance *mi = Object::cast_to(c); Ref mesh = mi->get_mesh(); if (mesh.is_valid()) { Ref mdr; mdr.instance(); Array arrays = mesh->surface_get_arrays(0); mdr->set_array(apply_transforms(arrays, p_options)); n->queue_delete(); return ResourceSaver::save(p_save_path + "." + get_save_extension(), mdr); } } } n->queue_delete(); return Error::ERR_PARSE_ERROR; } Array EditorImportColladaMdr::apply_transforms(Array &array, const Map &p_options) { Vector3 offset = p_options["offset"]; Vector3 rotation = p_options["rotation"]; Vector3 scale = p_options["scale"]; Transform transform = Transform(Basis(rotation).scaled(scale), offset); Array verts = array.get(Mesh::ARRAY_VERTEX); for (int i = 0; i < verts.size(); ++i) { Vector3 vert = verts[i]; vert = transform.xform(vert); verts.set(i, (vert)); } Array normals = array.get(Mesh::ARRAY_NORMAL); for (int i = 0; i < normals.size(); ++i) { Vector3 normal = normals[i]; normal = transform.basis.xform(normal); normals.set(i, normal); } Array tangents = array.get(Mesh::ARRAY_TANGENT); if (tangents.size() == verts.size() * 4) { for (int i = 0; i < verts.size(); ++i) { Plane p(tangents[i * 4 + 0], tangents[i * 4 + 1], tangents[i * 4 + 2], tangents[i * 4 + 3]); Vector3 tangent = p.normal; tangent = transform.basis.xform(tangent); tangents.set(i, tangent); } } array.set(Mesh::ARRAY_VERTEX, verts); array.set(Mesh::ARRAY_NORMAL, normals); array.set(Mesh::ARRAY_TANGENT, tangents); return array; } EditorImportColladaMdr::EditorImportColladaMdr() { _importer.instance(); } EditorImportColladaMdr::~EditorImportColladaMdr() { _importer.unref(); }