mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-10 21:09:38 +01:00
Fixed the bone editor's bone tree.
This commit is contained in:
parent
b352060a62
commit
73fa94274b
@ -285,6 +285,8 @@ void ModuleBoneTransformEditor::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("_value_changed_vector3"), &ModuleBoneTransformEditor::_value_changed_vector3);
|
ClassDB::bind_method(D_METHOD("_value_changed_vector3"), &ModuleBoneTransformEditor::_value_changed_vector3);
|
||||||
ClassDB::bind_method(D_METHOD("_value_changed_transform"), &ModuleBoneTransformEditor::_value_changed_transform);
|
ClassDB::bind_method(D_METHOD("_value_changed_transform"), &ModuleBoneTransformEditor::_value_changed_transform);
|
||||||
ClassDB::bind_method(D_METHOD("_change_transform"), &ModuleBoneTransformEditor::_change_transform);
|
ClassDB::bind_method(D_METHOD("_change_transform"), &ModuleBoneTransformEditor::_change_transform);
|
||||||
|
|
||||||
|
//ClassDB::bind_method(D_METHOD("update_joint_tree"), &ModuleBoneTransformEditor::update_joint_tree);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModuleBoneTransformEditor::_update_properties() {
|
void ModuleBoneTransformEditor::_update_properties() {
|
||||||
@ -632,6 +634,7 @@ void ModuleSkeletonEditor::move_skeleton_bone(NodePath p_skeleton_path, int32_t
|
|||||||
ERR_FAIL_NULL(skeleton);
|
ERR_FAIL_NULL(skeleton);
|
||||||
UndoRedo *ur = EditorNode::get_singleton()->get_undo_redo();
|
UndoRedo *ur = EditorNode::get_singleton()->get_undo_redo();
|
||||||
ur->create_action(TTR("Set Bone Parentage"));
|
ur->create_action(TTR("Set Bone Parentage"));
|
||||||
|
|
||||||
// If the target is a child of ourselves, we move only *us* and not our children
|
// If the target is a child of ourselves, we move only *us* and not our children
|
||||||
if (skeleton->is_bone_parent_of(p_target_boneidx, p_selected_boneidx)) {
|
if (skeleton->is_bone_parent_of(p_target_boneidx, p_selected_boneidx)) {
|
||||||
const BoneId parent_idx = skeleton->get_bone_parent(p_selected_boneidx);
|
const BoneId parent_idx = skeleton->get_bone_parent(p_selected_boneidx);
|
||||||
@ -644,19 +647,23 @@ void ModuleSkeletonEditor::move_skeleton_bone(NodePath p_skeleton_path, int32_t
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ur->add_undo_method(skeleton, "set_bone_parent", p_selected_boneidx, skeleton->get_bone_parent(p_selected_boneidx));
|
ur->add_undo_method(skeleton, "set_bone_parent", p_selected_boneidx, skeleton->get_bone_parent(p_selected_boneidx));
|
||||||
ur->add_do_method(skeleton, "set_bone_parent", p_selected_boneidx, p_target_boneidx);
|
ur->add_do_method(skeleton, "set_bone_parent", p_selected_boneidx, p_target_boneidx);
|
||||||
skeleton->set_bone_parent(p_selected_boneidx, p_target_boneidx);
|
skeleton->set_bone_parent(p_selected_boneidx, p_target_boneidx);
|
||||||
|
|
||||||
ur->commit_action();
|
ur->commit_action();
|
||||||
|
|
||||||
update_joint_tree();
|
update_joint_tree();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModuleSkeletonEditor::_update_spatial_transform_gizmo() {
|
void ModuleSkeletonEditor::_update_spatial_transform_gizmo() {
|
||||||
SpatialEditor::get_singleton()->clear_externals();
|
SpatialEditor::get_singleton()->clear_externals();
|
||||||
|
|
||||||
if (skeleton->get_selected_bone() >= 0) {
|
if (skeleton->get_selected_bone() >= 0) {
|
||||||
SpatialEditor::get_singleton()->append_to_externals(skeleton->get_global_transform() * skeleton->get_bone_global_pose(skeleton->get_selected_bone()));
|
SpatialEditor::get_singleton()->append_to_externals(skeleton->get_global_transform() * skeleton->get_bone_global_pose(skeleton->get_selected_bone()));
|
||||||
}
|
}
|
||||||
|
|
||||||
SpatialEditor::get_singleton()->update_transform_gizmo();
|
SpatialEditor::get_singleton()->update_transform_gizmo();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -688,16 +695,24 @@ void ModuleSkeletonEditor::_joint_tree_rmb_select(const Vector2 &p_pos) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ModuleSkeletonEditor::_update_properties() {
|
void ModuleSkeletonEditor::_update_properties() {
|
||||||
if (rest_editor)
|
if (rest_editor) {
|
||||||
rest_editor->_update_properties();
|
rest_editor->_update_properties();
|
||||||
if (pose_editor)
|
}
|
||||||
|
|
||||||
|
if (pose_editor) {
|
||||||
pose_editor->_update_properties();
|
pose_editor->_update_properties();
|
||||||
if (custom_pose_editor)
|
}
|
||||||
|
|
||||||
|
if (custom_pose_editor) {
|
||||||
custom_pose_editor->_update_custom_pose_properties();
|
custom_pose_editor->_update_custom_pose_properties();
|
||||||
|
}
|
||||||
|
|
||||||
_update_spatial_transform_gizmo();
|
_update_spatial_transform_gizmo();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ModuleSkeletonEditor::update_joint_tree() {
|
void ModuleSkeletonEditor::update_joint_tree() {
|
||||||
|
skeleton->force_update_all_bone_transforms();
|
||||||
|
|
||||||
joint_tree->clear();
|
joint_tree->clear();
|
||||||
|
|
||||||
if (skeleton == nullptr)
|
if (skeleton == nullptr)
|
||||||
@ -994,8 +1009,10 @@ ModuleSkeletonEditor::ModuleSkeletonEditor(ModuleEditorInspectorPluginSkeleton *
|
|||||||
editor(p_editor),
|
editor(p_editor),
|
||||||
editor_plugin(e_plugin),
|
editor_plugin(e_plugin),
|
||||||
skeleton(p_skeleton) {
|
skeleton(p_skeleton) {
|
||||||
|
|
||||||
handle_material = Ref<ShaderMaterial>(memnew(ShaderMaterial));
|
handle_material = Ref<ShaderMaterial>(memnew(ShaderMaterial));
|
||||||
handle_shader = Ref<Shader>(memnew(Shader));
|
handle_shader = Ref<Shader>(memnew(Shader));
|
||||||
|
|
||||||
handle_shader->set_code(" \
|
handle_shader->set_code(" \
|
||||||
shader_type spatial; \
|
shader_type spatial; \
|
||||||
render_mode unshaded; \
|
render_mode unshaded; \
|
||||||
@ -1019,6 +1036,7 @@ ModuleSkeletonEditor::ModuleSkeletonEditor(ModuleEditorInspectorPluginSkeleton *
|
|||||||
ALBEDO = albedo.rgb * col; \
|
ALBEDO = albedo.rgb * col; \
|
||||||
} \
|
} \
|
||||||
");
|
");
|
||||||
|
|
||||||
handle_material->set_shader(handle_shader);
|
handle_material->set_shader(handle_shader);
|
||||||
// handle_material->set_flag(SpatialMaterial::FLAG_DISABLE_DEPTH_TEST, true);
|
// handle_material->set_flag(SpatialMaterial::FLAG_DISABLE_DEPTH_TEST, true);
|
||||||
handle_material->set_render_priority(SpatialMaterial::RENDER_PRIORITY_MIN);
|
handle_material->set_render_priority(SpatialMaterial::RENDER_PRIORITY_MIN);
|
||||||
@ -1041,35 +1059,43 @@ ModuleSkeletonEditor::ModuleSkeletonEditor(ModuleEditorInspectorPluginSkeleton *
|
|||||||
ModuleSkeletonEditor::~ModuleSkeletonEditor() {
|
ModuleSkeletonEditor::~ModuleSkeletonEditor() {
|
||||||
set_rest_mode_toggled(false);
|
set_rest_mode_toggled(false);
|
||||||
SpatialEditor::get_singleton()->disconnect("change_tool_mode", this, "_menu_tool_item_pressed");
|
SpatialEditor::get_singleton()->disconnect("change_tool_mode", this, "_menu_tool_item_pressed");
|
||||||
|
|
||||||
if (skeleton) {
|
if (skeleton) {
|
||||||
pointsm->get_parent()->remove_child(pointsm);
|
pointsm->get_parent()->remove_child(pointsm);
|
||||||
skeleton->set_selected_bone(-1);
|
skeleton->set_selected_bone(-1);
|
||||||
skeleton->disconnect("pose_updated", this, "_draw_handles");
|
skeleton->disconnect("pose_updated", this, "_draw_handles");
|
||||||
memdelete(pointsm);
|
memdelete(pointsm);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
if (separators[i]) {
|
if (separators[i]) {
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(separators[i]);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(separators[i]);
|
||||||
memdelete(separators[i]);
|
memdelete(separators[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (options) {
|
if (options) {
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(options);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(options);
|
||||||
memdelete(options);
|
memdelete(options);
|
||||||
}
|
}
|
||||||
|
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_SELECT]);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_SELECT]);
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_MOVE]);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_MOVE]);
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_ROTATE]);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_ROTATE]);
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_SCALE]);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(tool_button[TOOL_MODE_BONE_SCALE]);
|
||||||
|
|
||||||
for (int i = 0; i < TOOL_MODE_BONE_MAX; i++) {
|
for (int i = 0; i < TOOL_MODE_BONE_MAX; i++) {
|
||||||
if (tool_button[i]) {
|
if (tool_button[i]) {
|
||||||
memdelete(tool_button[i]);
|
memdelete(tool_button[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SpatialEditor::get_singleton()->remove_control_from_menu_panel(rest_mode_button);
|
SpatialEditor::get_singleton()->remove_control_from_menu_panel(rest_mode_button);
|
||||||
|
|
||||||
if (rest_mode_button) {
|
if (rest_mode_button) {
|
||||||
memdelete(rest_mode_button);
|
memdelete(rest_mode_button);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SpatialEditor::get_singleton()->is_tool_external()) {
|
if (SpatialEditor::get_singleton()->is_tool_external()) {
|
||||||
SpatialEditor::get_singleton()->set_tool_mode(SpatialEditor::TOOL_MODE_SELECT);
|
SpatialEditor::get_singleton()->set_tool_mode(SpatialEditor::TOOL_MODE_SELECT);
|
||||||
SpatialEditor::get_singleton()->set_external_tool_mode(SpatialEditor::EX_TOOL_MODE_SELECT);
|
SpatialEditor::get_singleton()->set_external_tool_mode(SpatialEditor::EX_TOOL_MODE_SELECT);
|
||||||
@ -1077,8 +1103,9 @@ ModuleSkeletonEditor::~ModuleSkeletonEditor() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ModuleSkeletonEditor::_hide_handles() {
|
void ModuleSkeletonEditor::_hide_handles() {
|
||||||
if (!skeleton)
|
if (!skeleton) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
pointsm->hide();
|
pointsm->hide();
|
||||||
}
|
}
|
||||||
@ -1097,6 +1124,7 @@ void ModuleSkeletonEditor::_draw_handles() {
|
|||||||
a.resize(Mesh::ARRAY_MAX);
|
a.resize(Mesh::ARRAY_MAX);
|
||||||
PoolVector<Vector3> va;
|
PoolVector<Vector3> va;
|
||||||
PoolVector<Color> ca;
|
PoolVector<Color> ca;
|
||||||
|
|
||||||
{
|
{
|
||||||
const int bone_len = skeleton->get_bone_count();
|
const int bone_len = skeleton->get_bone_count();
|
||||||
va.resize(bone_len);
|
va.resize(bone_len);
|
||||||
@ -1116,6 +1144,7 @@ void ModuleSkeletonEditor::_draw_handles() {
|
|||||||
caw[i] = c;
|
caw[i] = c;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
a[Mesh::ARRAY_VERTEX] = va;
|
a[Mesh::ARRAY_VERTEX] = va;
|
||||||
a[Mesh::ARRAY_COLOR] = ca;
|
a[Mesh::ARRAY_COLOR] = ca;
|
||||||
am->add_surface_from_arrays(Mesh::PRIMITIVE_POINTS, a);
|
am->add_surface_from_arrays(Mesh::PRIMITIVE_POINTS, a);
|
||||||
@ -1123,8 +1152,9 @@ void ModuleSkeletonEditor::_draw_handles() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool ModuleSkeletonEditor::forward_spatial_gui_input(int p_index, Camera *p_camera, const Ref<InputEvent> &p_event) {
|
bool ModuleSkeletonEditor::forward_spatial_gui_input(int p_index, Camera *p_camera, const Ref<InputEvent> &p_event) {
|
||||||
if (!skeleton || tool_mode == TOOL_MODE_BONE_NONE)
|
if (!skeleton || tool_mode == TOOL_MODE_BONE_NONE) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
SpatialEditor *se = SpatialEditor::get_singleton();
|
SpatialEditor *se = SpatialEditor::get_singleton();
|
||||||
SpatialEditorViewport *sev = se->get_editor_viewport(p_index);
|
SpatialEditorViewport *sev = se->get_editor_viewport(p_index);
|
||||||
@ -1198,9 +1228,11 @@ bool ModuleSkeletonEditor::forward_spatial_gui_input(int p_index, Camera *p_came
|
|||||||
Ref<InputEventMouseMotion> mm = p_event;
|
Ref<InputEventMouseMotion> mm = p_event;
|
||||||
if (mm.is_valid()) {
|
if (mm.is_valid()) {
|
||||||
_edit.mouse_pos = mm->get_position();
|
_edit.mouse_pos = mm->get_position();
|
||||||
|
|
||||||
if (!(mm->get_button_mask() & 1)) {
|
if (!(mm->get_button_mask() & 1)) {
|
||||||
_gizmo_select(p_index, _edit.mouse_pos, true);
|
_gizmo_select(p_index, _edit.mouse_pos, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mm->get_button_mask() & BUTTON_MASK_LEFT) {
|
if (mm->get_button_mask() & BUTTON_MASK_LEFT) {
|
||||||
if (_edit.mode == SpatialEditorViewport::TRANSFORM_NONE)
|
if (_edit.mode == SpatialEditorViewport::TRANSFORM_NONE)
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user