asrzkj

Members
  • Content Count

    156
  • Joined

  • Last visited

  • Days Won

    1

Everything posted by asrzkj

  1. Há várias formas de não carregar texturas e modelos no cache do cliente. Uma delas é usar o conteúdo do txd/dff na função engineLoadTXD. Outra forma seria usar loadstring() e pcall() juntamente com um sandbox (ambiente/environment), que seria totalmente mais seguro, porém um pouco mais complexo.
  2. Você tem duas opções: não usar o parâmetro ou pulá-lo. Acho que é melhor eu responder a sua pergunta. Faça deste jeito: addCommandHandler('veh', function(player) local x, y, z = getElementPosition(player) vehicle = createVehicle(411, x, y, z, _, _, _, 'ABC-1337') end ) Na situação acima, suponhamos que você queira apenas criar o veículo com uma placa diferente. Porém, antes do parâmetro da placa, você tem 3 outros parâmetros: Rotação X, Rotação Y e Rotação Z. Para ignorar, basta adicionar um underline (_), como no exemplo acima.
  3. local spawns = { {2926, 681, 1000}, {1876, 633, 1000}, {1193, 1125, 1000}, {1927, 2028, 1000}, {2682, 2299, 1000}, {1887, 2654, 1000}, {918, 2491, 1000} } local current = 0 function spawn(p) current = math.min(current + 1, #spawns) local x, y, z = spawns[current][1], spawns[current][2], spawns[current][3] fadeCamera(p, true) spawnPlayer(p, x, y, z, 360, 0, 0, 0) if current == #spawns then current = 0 end end addEventHandler('onPlayerWasted', root, function() setTimer(spawn, 2000, 1, source) end )
  4. Percebi isso agora, Lord. Obrigado! (edite para mim se possível, eu não tenho a função de editar nessa thread)
  5. -- client-side local canvas = Vector2(guiGetScreenSize()) local ads = { -- ['Tipo'] = {caminho do arquivo de voz, texto} ['Welcome'] = {'sounds/voice1.mp3', 'Seja bem-vindo(a) ao servidor.'}, } local messageType local voiceElement local startTick addEvent('tts:play()', true) addEventHandler('tts:play()', root, function(type) if ads[type] then if not voiceElement then local voice = fileExists(ads[type][1]) and ads[type][1] or 'https://translate.google.com/translate_tts?ie=UTF-8&tl=pt-BR&client=tw-ob&q='..string.gsub(ads[type][2], ' ', '+') messageType = ads[type][2] startTick = {getTickCount(), 8} voiceElement = playSound(voice, false) addEventHandler('onClientRender', root, draw) end else if _debug then outputDebugString('Não foi possível reproduzir o som.') end end end) function draw() if messageType ~= nil then dxDrawText(messageType, 0, 0, canvas.x, canvas.y, 0xffffffff, 1.20, 'default-bold', 'center', 'center') if startTick[1] + (startTick[2] * 1000) < getTickCount() then messageType = nil startTick = nil voiceElement = nil removeEventHandler('onClientRender', root, draw) end end end -- server-side (apenas uma base de como você chamaria o evento) triggerClientEvent(player, 'tts:play()', player, 'Welcome') Fiz esse script sem testar, deve funcionar se você usar corretamente. Se o sistema não encontrar o arquivo de som, ele irá executar a voz do Google Tradutor.
  6. engineSetModelLODDistance
  7. Tente desabilitar a colisão do objeto. -> setElementCollisionsEnabled
  8. Há um erro de lógica no seu código. Sempre que a latência do jogador estiver acima de 100, uma nova imagem será criada. Este é o porquê da imagem não estar sendo destruída. Você deve verificar se o jogador está com a imagem na tela. Fiz um código rápido, só pra mostrar. local highPing = false setTimer( function( ) if ( not highPing ) then -- // Verificar se ele não esta na tela de "ping alto". Não tem mensagem? Então passemos para a linha de baixo. if ( getPlayerPing( localPlayer ) > 100 ) then -- // O ping é maior que 100? Se sim, vamos avisar ao jogador, mostrando uma mensagem na tela. highPing = true -- // Salvar a informação de que ele está com uma mensagem na tela. addEventHandler( "onClientRender", root, show, true, "low-128" ) -- // Adicionar o evento, para que mostre a mensagem. end else -- // Se o jogador estiver na tela, então: if ( getPlayerPing( localPlayer ) <= 100 ) then -- // O ping dele é menor ou igual a 100? Se sim, podemos retirar a mensagem da tela. highPing = false -- // Salvar a informação que retiramos a mensagem da tela do jogador. O ping dele já se normalizou. removeEventHandler( "onClientRender", root, show ) -- // Remover o evento, nenhuma mensagem está sendo mostrada mais. end end end, 666, 0 ) function show() local screen = Vector2( guiGetScreenSize( ) ) dxDrawRectangle( 0, 0, screen.x, screen.y, tocolor( 32, 32, 32, 64 ), false ) dxDrawText( "Sua conexão está ruim", 0, 0, screen.x, screen.y, tocolor( 255, 255, 255, 255 ), 1.80, "clear", "center", "center" ) end
  9. Creio eu que não exista um automático. Além do mais, desculpe a pergunta mas... qual é a dificuldade de apertar TAB?
  10. Ah, desculpe. Remova o string.len(r) < 1 Não é necessário.
  11. function kikarplayer (theClient, commandName, kickedName, ...) local account = getAccountName (getPlayerAccount (theClient)) if isObjectInACLGroup ("user."..account, aclGetGroup ("Admin")) then local r = {...} if not r or string.len(r) < 1 then return outputChatBox ("#bf2e2e* Erro: /kick [nick] [motivo]",theClient,255,255,255,true) end local reason = table.concat(r," ") local kickerName = getPlayerName(theClient):gsub("#%x%x%x%x%x%x","") local kickedPlayer = getPlayerFromName(kickedName) if not isElement(kickedPlayer) then outputChatBox ("#bf2e2e* Erro: Player Invalido!",theClient,255,255,255,true) end outputChatBox ( "#c9c9c9[#1a6cefFW-INFORMA#c9c9c9]O #1a6cef" .. kickerName .. " #c9c9c9Kickou o Player #1a6cef" ..getPlayerName(kickedPlayer):gsub("#%x%x%x%x%x%x","").. "#c9c9c9 | Motivo #1a6cef" ..reason.. "#c9c9c9", getRootElement(), 255, 0, 0, true ) banPlayer ( kickedPlayer, theClient, reason ) else outputChatBox ("#bf2e2e* Erro: Você Não tem Permissão!",theClient,255,255,255,true) end end addCommandHandler ( "kick", kikarplayer )
  12. Troque isto: function setLevelLogin () local account = getPlayerAccount(source) if ( account ) then local Level = (getAccountData(account,"Level") or 0) local minutes = (getAccountData(account,"minutes") or 0) setElementData(source,"Level",Level) setElementData(source,"minutes",minutes) end end addEventHandler("onPlayerLogin",getRootElement(),setLevelLogin) Por isto: function setLevelLogin (_, account) local Level = (getAccountData(account,"Level") or 0) local minutes = (getAccountData(account,"minutes") or 0) setElementData(source,"Level",Level) setElementData(source,"minutes",minutes) end addEventHandler("onPlayerLogin",getRootElement(),setLevelLogin) O primeiro argumento da sua função getAccountData está incorreto. O evento onPlayerLogin já fornece a conta do jogador, não é necessário usar getPlayerAccount. Aliás, esta função não retorna a conta, e sim o objeto dela, no caso o jogador responsável. Se você quer obter a conta do jogador, use getAccount.
  13. local string = "12345678" local encrypt = sha256(md5(string)) outputChatBox(encrypt) Exatamente dessa forma.
  14. local _minutes = 10 -- // O salário será entregue a cada quantos minutos? function payday() for _, v in pairs(getElementsByType("player")) do if isPlayerInACL(v, "nome_da_acl") then givePlayerMoney(v, 5000) outputChatBox("Você recebeu um salário no total de 5000 R$", v, 255, 255, 255, true) end end end setTimer(payday, _minutes * 60000, 0) function isPlayerInACL(player, acl) local accountName = getAccountName(getPlayerAccount(player)) if accountName ~= "guest" and type(aclGetGroup(acl)) == "userdata" then return isObjectInACLGroup("user."..accountName, aclGetGroup(acl)) end return false end Apenas troque nome_da_acl para a ACL que você deseja.
  15. Provavelmente a função Liberar() está dentro de um evento onPlayerConnect. Mude o nome do evento para onPlayerJoin.
  16. Opa! getPlayerName( namePlayer ); Coloque isto acima ^ no lugar de namePlayer, apenas naquelas mensagens de output, pois namePlayer é um elemento.
  17. O código ficaria mais organizado se a janelinha da conversa fosse criada no client, sem usar trigger. O trigger só seria usado para enviar e receber mensagens.
  18. Nunca tentei. Uso DX para a maioria dos scripts que faço. Concordo plenamente. É BEM considerável. Mas não existe apenas essas formas de criptografia de arquivo. MTA dá bastante caminhos para o desenvolvedor proteger os scripts.
  19. O MTA é capaz de carregar sim! Como eu disse, é necessário ativar o SD #22 e #23 para que eles sejam carregados de forma correta. Para carregar uma imagem com o formato YUV, por exemplo, ao invés de usar o dxDrawImage, a princípio você irá usar o dxCreateTexture, daí sim você irá carregar no dxDrawImage. Já com arquivos de áudio, é um pouco mais complexo. Você irá converter o áudio (criptografando-o). Para carregar o áudio, você terá de fazer a conversão inversa. Digamos que você converteu um arquivo de áudio de MP3 para CMF (não é lido pelo MTA). Para convertê-lo e fazer o MTA ler, você irá converter de CMF para MP3, obter a data/resultado do fetchRemote, gerar um arquivo aleatório com a extensão .mp3, incluir neste arquivo o resultado obtido. Após isso, adicionar no meta.xml e carregar o áudio onde quiser. (lembrando que após o carregamento do áudio, você deve deletá-lo do cache/pasta e retirá-lo do meta.xml)
  20. É sim! Porém, para usar serviços SMS, é necessário pagar uma pequena taxa por SMS enviado. Neste caso, o melhor método para ser usado é o e-mail. Há várias opções totalmente gratuitas e confiáveis.
  21. Olá. Sobre proteção de scripts, a melhor forma, em minha opinião, é usando fetchRemote + SMS/E-mail. O script só será ativado se o responsável pelo número de telefone ou e-mail aceitar que ele seja ligado, recebendo um código ou algo do gênero. Se você deseja criptografar arquivos como áudios (.mp3, .ogg, .cmf), imagens (.png, .jpg), shaders (.fx), o que eu recomendo e uso até hoje, é esta API: https://developers.convertio.co/pt/. É necessário algum conhecimento para trabalhar com este. (E lembrando que para fazer isso, é preciso ativar o SD #22 e #23, dentro do seu servidor, para que arquivos com extensões desconhecidas pelo MTA sejam carregadas.)
  22. local message = "Seja bem-vindo ao servidor MrShadows Race."; addEventHandler( "onResourceStart", root, function( res ) local res_type = getResourceInfo( res, "type" ); if ( res_type and res_type == "map" ) then outputChatBox( message, root, 255, 255, 255, true ); end end ); Server-side.
  23. local sx,sy = guiGetScreenSize() local px,py = 1366,768 local x,y = (sx/px), (sy/py) local dxfont1_font = dxCreateFont("Images/fonte.ttf", 12) function Vel() local vehicle = getPedOccupiedVehicle( getLocalPlayer() ) if ( vehicle ) then local speedX, speedY, speedZ = getElementVelocity ( vehicle ) local actualSpeed = (speedX^2 + speedY^2 + speedZ^2)^(0.5) local KMH = math.floor(actualSpeed*180) local vehHealth = math.min( math.floor( getElementHealth( vehicle ) / 10 ), 100 ); dxDrawRectangle(x*1134, y*710, x*222, y*32, tocolor(0, 0, 0, 100), false) if KMH < 250 then dxDrawRectangle(x*1140, y*716, x*211/250*KMH, y*19, tocolor(5, 106, 204, 255), false) end dxDrawText(KMH.." KM/h", x*1140, y*715, x*1351, y*735, tocolor(254, 254, 254, 227), 1.00, dxfont1_font, "center", "center", false, false, false, false, false) dxDrawRectangle(x*1134, y*674, x*222, y*32, tocolor(0, 0, 0, 100), false) dxDrawImage(x*1055, y*674, x*71, y*32, "Images/1.png", 0, 0, 0, tocolor(255, 255, 255, 170), false) dxDrawRectangle(x*1140, y*680, x*211/1*vehHealth, y*19, tocolor(5, 106, 204, 255), false) dxDrawText("Durabilidade: "..vehHealth, x*1140, y*679, x*1351, y*699, tocolor(254, 254, 254, 227), 1.00, dxfont1_font, "center", "center", false, false, false, false, false) dxDrawImage(x*1098, y*710, x*33, y*32, "Images/3.png", 0, 0, 0, tocolor(255, 255, 255, 170), false) end end addEventHandler("onClientRender", root, Vel) Testado.
  24. addEventHandler( "onPlayerWeaponSwitch", root, function( _prev, _next ) if ( _next > 0 ) then setElementData( source, "hasWeapon", true ); else setElementData( source, "hasWeapon", false ); end end ); Server-side.