henrique 2 months ago
parent f52a3c8b46
commit e7b5426d8e

@ -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()
Loading…
Cancel
Save