diff --git a/install_vr4life.py b/install_vr4life.py index 087d6b7..b7eff62 100644 --- a/install_vr4life.py +++ b/install_vr4life.py @@ -2,23 +2,32 @@ import os import sys from pymxs import runtime as rt +def log(msg): + """Função auxiliar para imprimir logs claros no Listener (F11)""" + print(f"[VR4Life Install Log] {msg}") + def install_plugin(): - # Caminhos de instalação local + rt.clearListener() + log("Iniciando fase final de instalação e configuração de interface...") + + # 1. Configuração de Caminhos user_scripts_dir = rt.getDir(rt.name("userScripts")) plugin_dir = os.path.join(user_scripts_dir, "VR4Life_Plugin").replace("\\", "/") - # Adiciona ao path para evitar o erro 'ModuleNotFoundError' que apareceu nos logs if plugin_dir not in sys.path: sys.path.append(plugin_dir) + log(f"Pasta adicionada ao Path do Python: {plugin_dir}") run_script = os.path.join(plugin_dir, "run_vr4life.py").replace("\\", "/") - - # Nomes solicitados para aparecer no topo + log(f"Caminho do script de execução: {run_script}") + + # Nome solicitado para o topo da lista product_name = "1-VR4Life" category = "Immerse Games" macro_name = "VR4Life_Launcher" - # 1. Registro da Macro (Base para todas as versões) + # 2. Registo da Macro (MacroScript) + log(f"A registar MacroScript '{macro_name}' na categoria '{category}'...") macro_code = f''' macroScript {macro_name} category:"{category}" @@ -28,51 +37,67 @@ def install_plugin(): on execute do ( python.ExecuteFile @"{run_script}" ) ) ''' - rt.execute(macro_code) + try: + rt.execute(macro_code) + log("MacroScript registado com sucesso.") + except Exception as e: + log(f"ERRO ao registar MacroScript: {str(e)}") - # 2. Lógica para 3ds Max 2025 e 2026 (Sistema CUI Moderno) + # 3. Lógica de Menu para 3ds Max 2025/2026 (Sistema CUI) try: + log("A tentar detetar sistema CUI (3ds Max 2025+)...") cui_mgr = rt.cui.getContentManager() main_menu_bar = cui_mgr.mainMenuBar + log("Sistema CUI detetado.") - # Verifica se o menu já existe + # Verificação de duplicados menu_exists = False for i in range(main_menu_bar.numItems): if main_menu_bar.getItem(i).displayText == product_name: menu_exists = True + log("O menu já existe na barra CUI. A ignorar criação para evitar duplicados.") break if not menu_exists: - # Cria o menu customizado moderno + log(f"A criar novo menu '{product_name}' no 3ds Max 2026...") new_menu = cui_mgr.createCustomMenu(product_name) new_menu.addActionItem(macro_name, category) - # Posição 1 coloca logo após o menu 'File' + # Insere logo após o menu 'File' main_menu_bar.addItem(new_menu, 1) - print(f"[LOG] {product_name} instalado via CUI.") + log("Menu CUI criado e inserido na posição 1.") except AttributeError: - # 3. Lógica para 3ds Max 2024 e anteriores (menuMan) - main_menu = rt.menuMan.getMainMenuBar() - existing_menu = rt.menuMan.findMenu(product_name) - - if existing_menu: - rt.menuMan.unRegisterMenu(existing_menu) + # 4. Lógica Legada para 3ds Max 2024 e anteriores + log("Sistema CUI não encontrado. A mudar para modo legado (menuMan)...") + try: + main_menu = rt.menuMan.getMainMenuBar() + existing_menu = rt.menuMan.findMenu(product_name) - new_menu = rt.menuMan.createMenu(product_name) - menu_item = rt.menuMan.createActionItem(macro_name, category) - new_menu.addItem(menu_item, -1) - - sub_menu_item = rt.menuMan.createSubMenuItem(product_name, new_menu) - main_menu.addItem(sub_menu_item, 1) - rt.menuMan.updateMenuBar() - print(f"[LOG] {product_name} instalado via menuMan.") + if existing_menu: + rt.menuMan.unRegisterMenu(existing_menu) + log("Menu antigo removido para atualização.") + + new_menu = rt.menuMan.createMenu(product_name) + menu_item = rt.menuMan.createActionItem(macro_name, category) + new_menu.addItem(menu_item, -1) + + sub_menu_item = rt.menuMan.createSubMenuItem(product_name, new_menu) + main_menu.addItem(sub_menu_item, 1) + rt.menuMan.updateMenuBar() + log("Menu legado criado com sucesso via menuMan.") + except Exception as e: + log(f"ERRO FATAL ao criar menu legado: {str(e)}") - # Abre a ferramenta automaticamente após instalar + # 5. Execução Automática if os.path.exists(run_script): + log("A abrir a interface do VR4Life pela primeira vez...") rt.python.ExecuteFile(run_script) + else: + log(f"AVISO: O ficheiro {run_script} não foi encontrado para execução imediata.") - rt.messageBox(f"Instalação do '{product_name}' finalizada!", title=product_name) + log("PROCESSO DE INSTALAÇÃO FINALIZADO.") + rt.messageBox(f"Instalação do '{product_name}' concluída!\nConsulte o log (F11) em caso de dúvidas.", title=product_name) if __name__ == "__main__": install_plugin() \ No newline at end of file