Add bone Translation

- Uses MMD Tools Dictionary to convert things into English then uses Translation service to do the rest

This i useful for the rest of our converter, it's better to have standard english names then trying to use a service first as each service translate things differnetly my orignal approach was bad due to this.
This commit is contained in:
Yusarina
2025-11-22 16:57:26 +00:00
parent 95cb726485
commit 53d2ac10b7
5 changed files with 378 additions and 4 deletions
+34 -3
View File
@@ -6,7 +6,8 @@ import bpy
from bpy.types import Operator
from ...core.common import get_active_armature
from ...core.translations import t
from ...core.mmd_converter import convert_mmd_armature, detect_mmd_armature
from ...core.mmd_converter import (convert_mmd_armature, detect_mmd_armature,
translate_mmd_everything)
from ...core.logging_setup import logger
@@ -37,12 +38,21 @@ class AvatarToolkit_OT_ConvertMMDArmature(Operator):
self.report({'WARNING'}, t("MMD.not_mmd_armature"))
return {'CANCELLED'}
# conversion settings
# Get conversion settings
toolkit = context.scene.avatar_toolkit
make_parent = toolkit.mmd_make_parent
rename_armature = toolkit.mmd_rename_armature
translate_names = toolkit.mmd_translate_names
translate_bones = toolkit.mmd_translate_bones
translate_materials = toolkit.mmd_translate_materials
translate_shapekeys = toolkit.mmd_translate_shapekeys
translate_objects = toolkit.mmd_translate_objects
logger.info(f"Conversion settings - Make parent: {make_parent}, Rename: {rename_armature}")
logger.info(f"Translation settings - Enabled: {translate_names}, Bones: {translate_bones}, " +
f"Materials: {translate_materials}, Shapekeys: {translate_shapekeys}, Objects: {translate_objects}")
# Step 1: Basic conversion (parent and rename)
success, messages = convert_mmd_armature(armature, make_parent, rename_armature)
if not success:
@@ -51,8 +61,29 @@ class AvatarToolkit_OT_ConvertMMDArmature(Operator):
self.report({'WARNING'}, msg)
return {'CANCELLED'}
logger.info(f"MMD conversion completed successfully")
logger.info(f"MMD basic conversion completed successfully")
for msg in messages:
self.report({'INFO'}, msg)
# Step 2: Translation (if enabled)
if translate_names:
logger.info("Starting MMD name translation")
self.report({'INFO'}, t("MMD.translation_starting"))
trans_success, trans_messages = translate_mmd_everything(
armature,
translate_bones=translate_bones,
translate_materials=translate_materials,
translate_shapekeys=translate_shapekeys,
translate_objects=translate_objects
)
if trans_success:
logger.info("MMD name translation completed successfully")
else:
logger.warning("MMD name translation completed with some failures")
for msg in trans_messages:
self.report({'INFO'}, msg)
return {'FINISHED'}