Jump to content

Lord Henry

Other Languages Moderators
  • Posts

    3,603
  • Joined

  • Last visited

  • Days Won

    132

Lord Henry last won the day on May 15

Lord Henry had the most liked content!

About Lord Henry

  • Birthday 16/01/1996

Member Title

  • Portuguese Section Moderator

Details

  • Gang
    MTA Simpsons
  • Location
    Brazil
  • Occupation
    Game Developer
  • Interests
    Resource Development, Gamer, Map Design, Staff Management, MTA Forum Portuguese Section Helper

Recent Profile Visitors

12,095 profile views

Lord Henry's Achievements

Soldier

Soldier (43/54)

1.5k

Reputation

  1. Ou você pode simplesmente usar um elementData no jogador, onde cada gamemode só funciona nos jogadores que possuam um valor específico nesse elementData. É claro que isso será muito complexo, visto que todos os resources que dependem do gamemode precisarão fazer essa verificação de data também, o que vai prejudicar seu desempenho no servidor. Outra alternativa seria existir uma tabela global de jogadores onde cada jogador entra em um índice diferente após escolher o Gamemode no painel de login. Então cada gamemode e cada resource que dependa de gamemode irá verificar essa tabela usando um call (exports). gamemodeDeGeral = { ["Freeroam"] = {}, ["Race"] = {}, ["DM"] = {}, ["DayZ"] = {}, ["RPG"] = {}, } addEventHandler("onPlayerLogin", root, function(thePlayer) table.insert(gamemodeDeGeral["Freeroam"], thePlayer) -- Exemplo para inserir um player que acabou de logar no Freeroam. end) addEventHandler("onPlayerLogout", root, function(thePlayer) for i,p in pairs (gamemodeDeGeral["Freeroam"]) do if (p == thePlayer) then gamemodeDeGeral["Freeroam"][i] = nil -- Exemplo para remover um player da tabela Freeroam ao deslogar. return end end end)
  2. O parâmetro id vai ser sempre o que o jogador digitou após o comando, então ele pode ser tanto o ID de um jogador ou valor de dinheiro. O parâmetro qnt só vai existir se dois valores forem especificados após o comando. Se o jogador apenas especificar um, então qnt será nil. Ou seja, o comando /money 123123 fará com que id seja 123123 e qnt seja nil Falta verificações de segurança, você precisa garantir que tanto o id quanto qnt sejam números. Além de verificar se os valores informados são números, você precisa garantir que eles sejam inteiros (o player pode tentar informar números decimais, passando pelo tonumber). Adicione uma condição verificando se qnt existe. Caso não exista, considere o parâmetro id como sendo a quantidade e então use o ID de si mesmo. Adicione uma condição verificando se id existe. Caso não exista, dê feedback de erro de sintaxe. O segundo erro acontece pois id não deve estar depois do targetPlayer. Basta removê-lo dali que resolve o erro. Não use nome de função igual ao comando que ativa ela. Para facilitar de entender: function myMoney(thePlayer, cmd, id, qnt) -- thePlayer é quem executou o comando. if (qnt) then -- Se qtd existe (se foram especificados dois valores após o comando), então: local playerQTD = tonumber(qtd) -- Torna a string qtd em um número. if (playerQTD) then -- Se qtd é um número, então: if (math.floor(playerQTD) == playerQTD) then -- Se qtd é um integer, então: if (id) then -- Se id existe, então: local playerID = tonumber(id) -- Torna a string id em um número. if (playerID) then -- Se id é um número, então: if (math.floor(playerID) == playerID) then -- Se id é um integer, então: local targetPlayer = getPlayerID(playerID) -- Espero que você tenha essa função criada em outro lugar, pois ela não existe nativamente. if (targetPlayer) then -- Se existe um jogador com este ID, então: setPlayerMoney(targetPlayer, playerQTD) -- Dá o dinheiro pro jogador com este ID. else outputChatBox ("Erro: Jogador com o ID '"..id.."' não foi encontrado.", thePlayer, 255, 0, 0) end else outputChatBox ("Erro: ID '"..id.."' precisa ser um número inteiro.", thePlayer, 255, 0, 0) end else outputChatBox ("Erro: ID '"..id.."' precisa ser um número.", thePlayer, 255, 0, 0) end else -- Se id não existe, então: outputChatBox ("Erro de sintaxe: #ffffff/money <ID> <quantidade>", thePlayer, 255, 0, 0, true) end else outputChatBox ("Erro: A quantidade de dinheiro precisa ser um número inteiro.", thePlayer, 255, 0, 0) end else outputChatBox ("Erro: A quantidade de dinheiro precisa ser um número.", thePlayer, 255, 0, 0) end elseif (id) then -- Se não existe qnt mas existe id (só foi especificado um valor após o comando), então: local playerQTD = tonumber(id) -- Torna a string id em um número. Usando o valor de id como quantidade. if (playerQTD) then -- Se id é um número, então: if (math.floor(playerQTD) == playerQTD) then -- Se id é um integer, então: setPlayerMoney(thePlayer, playerQTD) -- Dá o dinheiro pra si mesmo. else outputChatBox ("Erro: O valor especificado após o comando precisa ser um número inteiro.", thePlayer, 255, 0, 0) end else outputChatBox ("Erro: O valor especificado após o comando precisa ser um número.", thePlayer, 255, 0, 0) end else -- Se não existe id e nem qtd, então: outputChatBox ("Erro de sintaxe: #ffffff/money <ID> <quantidade>", thePlayer, 255, 0, 0, true) end end addCommandHandler("money", myMoney) -- Não se usa nome de função igual ao comando. Mude um dos dois para não dar conflito. Obs: É recomendável restringir esse comando, caso contrário qualquer player pode dar dinheiro pra si mesmo ou pros outros. Versão resumida sem nenhuma verificação de segurança: (pode gerar erros no debugscript) function myMoney(thePlayer, cmd, id, qnt) if (qnt) then -- Se qnt existe, então: local targetPlayer = getPlayerID(tonumber(id)) -- Obtém o jogador que tem o ID especificado. setPlayerMoney(targetPlayer, qnt) -- Dá o dinheiro de valor qnt para quem tem o ID de valor id. else -- Se qnt não existe, então: setPlayerMoney(thePlayer, id) -- Dá o dinheiro de valor id em si mesmo. end end addCommandHandler("money", myMoney) Obs: Vale lembrar que setPlayerMoney vai deixar o dinheiro do jogador igual a quantidade especificada. Enquanto que givePlayerMoney vai somar o valor especificado no dinheiro atual do jogador e a função takePlayerMoney vai subtrair o valor especificado no dinheiro atual do jogador.
  3. Defina a dimensão e interior do jogador que logou como 0. setElementDimension setElementInterior
  4. Mostre a parte do código que vc está usando para criar a minigun e também a parte que seta a propriedade.
  5. @Sr. BruxoMostre o que vc já tentou fazer.
  6. Você precisa criar a versão LOD desse objeto e substituir o LOD original também.
  7. setElementHealth (player, 100) setPedArmor (player, 100)
  8. Ban appeals must be in English. Revisões de banimentos precisam ser feitos em inglês.
  9. Interessante e bem detalhado. Porém faltou a informação mais importante para os candidatos à vaga: Ganhos e benefícios. Se esperam que as pessoas trabalhem de graça, então estão completamente fora da realidade ou precisam diminuir muito os requisitos.
  10. @Paulo Mikhael Gomes S. Favor não reviver tópicos antigos.
  11. Desculpe, esqueci de mencionar que a função split retorna uma tabela em vez dos valores separados. Dai você precisa acessar os valores da tabela pelos índices. function SetarCor (playerSource, getMsg) local uVehicle = getPedOccupiedVehicle (playerSource) if (uVehicle) then local cores = split (getMsg, ',') local r = cores[1] or 0 local g = cores[2] or 0 local b = cores[3] or 0 setVehicleColor (uVehicle, r, g, b) iprint (r, g, b) end end addEvent ("SetarCor", true) addEventHandler ("SetarCor", root, SetarCor)
  12. vehTimers = {} -- Tabela de timers anexados aos veículos. addEventHandler ("onVehicleExit", root, function (thePed, seat) -- Função ativada quando alguém sair de algum veículo. if (seat == 0) then -- Se quem saiu do veículo era o motorista, então: for i,v in pairs (Carro) do -- Para cada veículo da tabela Carro, faça: if not (isElement(v)) then -- Se um veículo da tabela Carro não existe mais, então limpa ele da tabela. Carro[i] = nil end if (theSource == v) then -- Se o veículo que o jogador saiu é o mesmo que este veículo específico da tabela, então: vehTimers[source] = setTimer (function (theSource) -- Inicia um timer de 10 segundos, vinculado ao veículo da tabela. (theSource = source) vehTimers[theSource] = nil -- Limpa a variável deste timer. if not (isElement(theSource)) then return end -- Se o veículo que o player saiu já não existe mais, então cancela essa função e nada acontece. destroyElement (v) -- Destrói o veículo. Carro[i] = nil -- Limpa ele da tabela Carro. end, 10000, 1, source) -- Passa o source por parâmetro para dentro do setTimer, pois dentro do setTimer o source original não existe. break -- Encerra o looping para não precisar verificar os demais veículos, pois ele já foi encontrado. end end end end) addEventHandler ("onVehicleEnter", root, function (thePed, seat) -- Função ativada quando alguém entrar em algum veículo. if (seat == 0) then if (isTimer(vehTimers[source])) then killTimer (vehTimers[source]) -- Cancela o timer caso alguém entre de motorista no veículo antes do tempo acabar. vehTimers[source] = nil end end end) Obs: Tenha um sistema que impeça que outros players entrem no veículo que não é deles.
  13. @DaddyMTAvocê não pode converter um texto único em 3 números usando apenas o tonumber. Se o texto possuir algum símbolo entre os números, dará erro. Você pode fazer de 2 formas: Mais recomendada: criar 3 editboxes. Um para a cor Red, outro pra cor Green e outro pra cor Blue. E depois use tonumber em cada valor. Opcional: Limite o número de caracteres deles em no máximo 3. Bloqueie qualquer caractere que não seja número de ser digitado nos campos. Considere campos vazios como 0. Evitando erros. Mais fácil: pegue o texto digitado nos campos e separe-o em 3 sub-textos usando a função split. Para isso ser possível, é necessário que o texto tenha algum caractere separando os valores, por exemplo uma vírgula. Então é só dar tonumber em cada uma delas. Opcional: Verifique sempre se o split retornou 3 valores. Se só encontrar 2 strings, considere o terceiro como 0. Se encontrar só 1 string, considere o segundo e terceiro como 0.
×
×
  • Create New...