Compare commits

..

No commits in common. 'd577713243eae403675b77063f58d78208252e8b' and '03377267aeca0587de77b04b9cca1538c2e279fa' have entirely different histories.

@ -2,18 +2,22 @@ import os
from pymxs import runtime as rt from pymxs import runtime as rt
def carregar_menu_mnx(): def carregar_menu_mnx():
rt.clearListener()
print("\n" + "="*50) print("\n" + "="*50)
print("AGENDANDO CARREGAMENTO - VR4LIFE (MODO SEGURO)") print("LOG DE INSTALAÇÃO DE INTERFACE - VR4LIFE")
print("="*50) print("="*50)
try: try:
# 1. Definir caminhos # 1. Definir caminhos (Usando barras normais / para evitar conflitos)
pasta_macros = rt.getDir(rt.name("userMacros")) pasta_macros = rt.getDir(rt.name("userMacros"))
pasta_enu = os.path.dirname(pasta_macros) pasta_enu = os.path.dirname(pasta_macros)
caminho_mnx = os.path.join(pasta_enu, "en-US", "UI", "vr4life.mnx").replace("\\", "/") caminho_mnx = os.path.join(pasta_enu, "en-US", "UI", "vr4life.mnx").replace("\\", "/")
plugin_dir = os.path.dirname(os.path.realpath(__file__)).replace("\\", "/") plugin_dir = os.path.dirname(os.path.realpath(__file__)).replace("\\", "/")
run_script = f"{plugin_dir}/run_vr4life.py" run_script = f"{plugin_dir}/run_vr4life.py"
print(f"[*] Pasta do Plugin: {plugin_dir}")
print(f"[*] Caminho do MNX: {caminho_mnx}")
# 2. Registrar MacroScript # 2. Registrar MacroScript
macro_cmd = ( macro_cmd = (
'macroScript VR4Life_Launcher\n' 'macroScript VR4Life_Launcher\n'
@ -25,34 +29,30 @@ def carregar_menu_mnx():
) )
rt.execute(macro_cmd) rt.execute(macro_cmd)
# 3. TIMER COM EXECUÇÃO TARDIA (Late Bound) # 3. Carregar MNX (Corrigido para evitar o erro de sintaxe @C)
# Usamos execute dentro do timer para o compilador não travar no 'menuMan' agora if os.path.exists(caminho_mnx):
timer_cmd = f""" print(f"[!] Arquivo MNX encontrado. Solicitando carregamento...")
(
global _vr4life_timer = dotNetObject "System.Windows.Forms.Timer"
_vr4life_timer.interval = 3000 -- 3 segundos para garantir
dotNet.addEventHandler _vr4life_timer "Tick" (fn onTick s e = (
-- tentamos acessar o menuMan aqui dentro, após o tempo passar
if (execute "menuMan") != undefined then (
execute "menuMan.loadMenuFile \\"{caminho_mnx}\\""
execute "menuMan.updateMenuBar()"
format ">> VR4Life: Menu carregado com sucesso apos espera.\\n"
s.stop()
s.dispose()
) else (
format ">> VR4Life: Interface ainda carregando...\\n"
)
))
_vr4life_timer.start() # Aqui usamos aspas duplas e formatamos o caminho para o MaxScript
format "[*] Aguardando 3 segundos para injetar o menu...\\n" cmd_load = (
'(\n'
' if menuMan != undefined then (\n'
f' local result = menuMan.loadMenuFile "{caminho_mnx}"\n'
' menuMan.updateMenuBar()\n'
' format ">> MaxScript: loadMenuFile result: %\\n" result\n'
' ) else (\n'
' format ">> MaxScript Erro: menuMan ainda e undefined\\n"\n'
' )\n'
')'
) )
""" rt.execute(cmd_load)
rt.execute(timer_cmd) else:
print(f"[X] ERRO: Arquivo {caminho_mnx} NAO existe no disco.")
print("="*50)
except Exception as e: except Exception as e:
print(f"\n[EXCEPTION] Falha no agendamento:\n{str(e)}") print(f"\n[EXCEPTION] Falha grave:\n{str(e)}")
if __name__ == "__main__": if __name__ == "__main__":
carregar_menu_mnx() carregar_menu_mnx()
Loading…
Cancel
Save