henrique 2 months ago
parent 0af058f092
commit c6be47e675

@ -3,87 +3,76 @@ import sys
from pymxs import runtime as rt from pymxs import runtime as rt
def log(msg): def log(msg):
"""Log detalhado no Listener (F11)"""
print(f"[VR4Life Install Log] {msg}") print(f"[VR4Life Install Log] {msg}")
def install_plugin(): def install_plugin():
rt.clearListener() rt.clearListener()
log("=== CONFIGURANDO MENU VR4Life (INSTALAÇÃO NO FINAL) ===") log("=== INICIANDO INSTALAÇÃO BLINDADA (VR4Life) ===")
# 1. Configuração de Caminhos # 1. FORÇAR O REGISTRO DA PASTA NO PYTHON (Resolve Imagem 3)
user_scripts_dir = rt.getDir(rt.name("userScripts")) user_scripts_dir = rt.getDir(rt.name("userScripts"))
plugin_dir = os.path.join(user_scripts_dir, "VR4Life_Plugin").replace("\\", "/") plugin_dir = os.path.join(user_scripts_dir, "VR4Life_Plugin").replace("\\", "/")
if plugin_dir not in sys.path: if plugin_dir not in sys.path:
sys.path.append(plugin_dir) sys.path.insert(0, plugin_dir) # Insere no topo para ter prioridade
log(f"Pasta registrada no Python: {plugin_dir}")
engine_script = os.path.join(plugin_dir, "run_vr4life.py").replace("\\", "/")
update_script = os.path.join(plugin_dir, "vr4life_updater.py").replace("\\", "/")
run_script = os.path.join(plugin_dir, "run_vr4life.py").replace("\\", "/")
product_name = "VR4Life" product_name = "VR4Life"
category = "Immerse Games" category = "Immerse Games"
macro_name = "VR4Life_Launcher"
# 2. Registro das Macros # 2. REGISTRO DA MACRO
log("Registrando Macros no sistema...") macro_code = f'''
rt.execute(f''' macroScript {macro_name}
macroScript VR4Life_Open category:"{category}" buttonText:"VR4Life Engine" category:"{category}"
( on execute do ( python.ExecuteFile @"{engine_script}" ) ) buttonText:"{product_name}"
''') ( on execute do ( python.ExecuteFile @"{run_script}" ) )
'''
rt.execute(f''' rt.execute(macro_code)
macroScript VR4Life_Update category:"{category}" buttonText:"Atualizar Plugin"
( on execute do ( python.ExecuteFile @"{update_script}" ) )
''')
# 3. Lógica de Menu para 3ds Max 2025/2026 (CUI) # 3. LÓGICA DE MENU COM ESCUDO ANTI-ERRO (Resolve Imagens 2, 4, 5)
try: try:
log("Gerenciando interface via CUI Manager (2025+)...") # Tenta o modo moderno do 2026 primeiro
cui_mgr = rt.cui.getContentManager() cui_mgr = rt.cui.getContentManager()
main_menu_bar = cui_mgr.mainMenuBar main_menu_bar = cui_mgr.mainMenuBar
# Limpeza de versões anteriores # Limpa qualquer resquício para evitar o "vai e vem"
for i in range(main_menu_bar.numItems - 1, -1, -1): for i in range(main_menu_bar.numItems - 1, -1, -1):
item = main_menu_bar.getItem(i) item = main_menu_bar.getItem(i)
if item.displayText == product_name or item.displayText == "1-VR4Life": if item.displayText in [product_name, "1-VR4Life"]:
main_menu_bar.removeItem(item) main_menu_bar.removeItem(item)
log(f"Limpando menu antigo: {item.displayText}")
# Criação do Menu log("Criando menu moderno...")
new_menu = cui_mgr.createCustomMenu(product_name) new_menu = cui_mgr.createCustomMenu(product_name)
new_menu.addActionItem("VR4Life_Open", category) new_menu.addActionItem(macro_name, category)
new_menu.addActionItem("VR4Life_Update", category) main_menu_bar.addItem(new_menu, -1) # Adiciona no final como solicitado
# addItem sem o segundo parâmetro ou com -1 coloca no FINAL da lista
main_menu_bar.addItem(new_menu, -1)
rt.execute("cui.getContentManager().updateMainMenuBar()") rt.execute("cui.getContentManager().updateMainMenuBar()")
log("Menu VR4Life adicionado ao final da barra principal.")
except AttributeError: except Exception as e:
# 4. Lógica Legada (2024 e anteriores) # Se falhar (versões antigas), tenta o menuMan de forma segura
log("Usando menuMan (Modo Legado)...") log("Tentando modo legado com segurança...")
main_menu = rt.menuMan.getMainMenuBar() try:
existing_menu = rt.menuMan.findMenu(product_name) # Usamos hasattr para evitar que o script 'estoure' o erro de atributo
if existing_menu: rt.menuMan.unRegisterMenu(existing_menu) if hasattr(rt, "menuMan"):
main_menu = rt.menuMan.getMainMenuBar()
new_menu = rt.menuMan.createMenu(product_name) existing = rt.menuMan.findMenu(product_name)
new_menu.addItem(rt.menuMan.createActionItem("VR4Life_Open", category), -1) if existing: rt.menuMan.unRegisterMenu(existing)
new_menu.addItem(rt.menuMan.createActionItem("VR4Life_Update", category), -1)
new_menu = rt.menuMan.createMenu(product_name)
sub_menu_item = rt.menuMan.createSubMenuItem(product_name, new_menu) new_menu.addItem(rt.menuMan.createActionItem(macro_name, category), -1)
sub_item = rt.menuMan.createSubMenuItem(product_name, new_menu)
# No menuMan, -1 também adiciona ao final main_menu.addItem(sub_item, -1)
main_menu.addItem(sub_menu_item, -1) rt.menuMan.updateMenuBar()
rt.menuMan.updateMenuBar() except:
log("Menu legado adicionado ao final.") log("Aviso: Não foi possível criar o menu superior, use o 'Customize User Interface'.")
# 5. Execução Automática # 4. EXECUÇÃO FINAL
if os.path.exists(engine_script): if os.path.exists(run_script):
log("Executando interface do plugin...") log("Executando motor...")
rt.python.ExecuteFile(engine_script) rt.python.ExecuteFile(run_script)
log("=== PROCESSO FINALIZADO COM LOGS ATIVOS ===") log("=== INSTALAÇÃO CONCLUÍDA ===")
rt.messageBox(f"Instalação do '{product_name}' concluída no final do menu!", title=product_name)
if __name__ == "__main__": if __name__ == "__main__":
install_plugin() install_plugin()
Loading…
Cancel
Save