-
Posts
3,978 -
Joined
-
Last visited
-
Days Won
181
Everything posted by Lord Henry
-
@JPzin deixa o like nas respostas, já que eu fiz o resource inteiro pra vc kkkkkkkk
-
Desta forma: Client-side: local screenW, screenH = guiGetScreenSize() local painel = false -- Layout Fixo: (centralizado) local layout = { -- posX, posY, sizeX, sizeY, colorRGBA, text, textColorRGBA, fontSize, fontFamily, alignX, alignY {-320, -180, 640, 360, tocolor(75, 75, 75, 255)}, -- Window {-320, -190, 426, 20, tocolor(23, 209, 248, 255)}, -- Tittle Line {-300, -160, 600, 60, tocolor(20, 20, 20, 255), "Arsenal", tocolor(255, 255, 255, 255), 3, "bankgothic", "center", "center"}, -- Tittle {-300, -80, 186, 100, tocolor(43, 43, 43, 255), "M4", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 1 {-300, 40, 186, 100, tocolor(43, 43, 43, 255), "AK", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 2 {-93, -80, 186, 100, tocolor(43, 43, 43, 255), "GLOCK", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 3 {-93, 40, 186, 100, tocolor(43, 43, 43, 255), "Skin 1", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 4 {114, -80, 186, 100, tocolor(43, 43, 43, 255), "Skin 2", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 5 {114, 40, 186, 100, tocolor(43, 43, 43, 255), "VEICULO", tocolor(255, 255, 255, 255), 2, "pricedown", "center", "center"}, -- Button 6 {-320, 140, 640, 40, false, "Para fechar aperte 'Backspace'", tocolor(255, 255, 255, 255), 2, "default", "center", "center"}, -- Close info } function paineldx () for i, infos in ipairs (layout) do -- Para cada item da tabela layout, faça: local posX, posY, sizeX, sizeY, colorRGBA, text, textColorRGBA, fontSize, fontFamily, alignX, alignY = unpack (infos) -- Separa as infos em variáveis. -- Layout Fixo: posX = (screenW / 2) + posX -- Faz com que o centro da tela seja a posição 0, 0. Centralizando as posições. posY = (screenH / 2) + posY -- Converte as posições centralizadas da tabela para posições absolutas. if colorRGBA then -- Só faz dxDrawRectangle se tiver o parâmetro colorRGBA. Se não tiver, é só um texto isolado. if i >= 4 and i <= 9 then -- Se for um botão, então: (se for do item 4 até o 9) if isMouseInPosition (posX, posY, sizeX, sizeY) then -- Se o mouse está em cima do botão, então: colorRGBA = tocolor(0, 0, 0, 255) -- Torna a cor do botão preto. end end dxDrawRectangle(posX, posY, sizeX, sizeY, colorRGBA, false) end if text then -- Só faz dxDrawText se tiver o parâmetro texto. sizeX = posX + sizeX sizeY = posY + sizeY dxDrawText(text, posX, posY, sizeX, sizeY, textColorRGBA, fontSize, fontFamily, alignX, alignY) end end end addEvent("HitM", true) addEventHandler("HitM", root, function() -- Função chamada pelo servidor quando este jogador colide no marker do server. if not painel then addEventHandler("onClientRender", root, paineldx) painel = true showCursor(true) end end) bindKey("backSpace", "down", function() -- Tecla que fecha o painel. if painel then removeEventHandler("onClientRender", root, paineldx) painel = false showCursor(false) end end) addEventHandler("onClientClick", root, function(button, state) if button == "left" and state == "down" then if painel then for i, infos in pairs (layout) do -- Neste caso uso pairs pois a ordem dos itens não importa. local posX, posY, sizeX, sizeY = unpack (infos) -- Separa as infos em variáveis. -- Layout Fixo: posX = (screenW / 2) + posX -- Converte a posição centralizada da tabela para posição absoluta. posY = (screenH / 2) + posY if isMouseInPosition(posX, posY, sizeX, sizeY) then if i == 4 then -- Se for o botão de M4, então: triggerServerEvent("setarAlgo", localPlayer, "weapon", 31, 9999) -- giveWeapon (source, 31, 9999) -- Não funciona client-side. elseif i == 5 then -- Se for o botão de AK, então: triggerServerEvent("setarAlgo", localPlayer, "weapon", 30, 9999) elseif i == 6 then -- Se for o botão de Glock, então: triggerServerEvent("setarAlgo", localPlayer, "weapon", 24, 9999) elseif i == 7 then -- Se for o botão de Skin 1, então: triggerServerEvent("setarAlgo", localPlayer, "skin", 28) elseif i == 8 then -- Se for o botão de Skin 2, então: triggerServerEvent("setarAlgo", localPlayer, "skin", 29) elseif i == 9 then -- Se for o botão de Vehicle, então: triggerServerEvent("setarAlgo", localPlayer, "vehicle", 560) end end end end end end) function isMouseInPosition (x, y, width, height) -- Função útil. if not isCursorShowing() then return false end local sx, sy = guiGetScreenSize() local cx, cy = getCursorPosition() local cx, cy = (cx * sx), (cy * sy) return ((cx >= x and cx <= x + width) and (cy >= y and cy <= y + height)) end Server-side: local m1 = createMarker(2027.903, 1545.603, 10.819 -1, "cylinder", 1.5, 0,195,255, 100) local vehicles = {} addEventHandler("onMarkerHit", m1, function(hit) if getElementType(hit) == "player" then -- Se quem colidiu no marker for um jogador, então: if isObjectInACLGroup ("user."..getAccountName (getPlayerAccount (hit)), aclGetGroup ("Admin")) then -- Se o jogador está na ACL Admin, então: setTimer(triggerClientEvent, 250, 1, hit, "HitM", hit) else outputChatBox("Acesso negado.", hit, 255, 0, 0) end end end) addEvent("setarAlgo", true) addEventHandler("setarAlgo", root, function (tipo, id, ammo) -- Função chamada pelo client. Seta algo no jogador. if tipo == "weapon" then giveWeapon(client, id, ammo, true) elseif tipo == "skin" then setElementModel (client, id) elseif tipo == "vehicle" then local x, y, z = getElementPosition(client) if isElement (vehicles[client]) then -- Se já existe um veículo criado por este jogador, então: destroyElement(vehicles[client]) -- Destrói esse veículo antes de criar outro. end vehicles[client] = createVehicle(id, x, y, z + 1) -- Cria o veículo em cima do jogador. end end) function limpaVehicle() -- Destrói o veículo criado pelo jogador quando ele sair do servidor. if isElement (vehicles[source]) then destroyElement(vehicles[source]) vehicles[source] = nil end end addEventHandler("onPlayerQuit", root, limpaVehicle) addEventHandler("onPlayerDisconnect", root, limpaVehicle)
-
@JPzin comece fazendo o seguinte: Corrija a indentação dos seus códigos para que eles fiquem legíveis. Para aprender a indentar código, veja este tópico. Troque todos os getRootElement() por root. Depois de fazer o básico, aí sim você pode começar a corrigir o painel. De cara, a função giveWeapon é server-side. Portanto não vai funcionar no seu script client-side. Vi que seu painel foi feito usando escala relativa para tentar manter o painel no mesmo tamanho em qualquer resolução, porém isso dará problema com os textos pois eles não acompanham a escala da tela e precisam que você declare tamanhos diferentes na fonte. Ou você faz um painel de tamanho fixo (no máximo 640x480), evitando problemas com os textos e evitando trabalho. Ou você calcula a resolução do jogador e aplica no tamanho da fonte junto, o que dará mais trabalho. Ao usar escala relativa, você também precisa se preocupar com a proporção da tela, algumas resoluções são mais quadradas (4:3), outras são mais retangulares (16:9), causando distorções no painel e deixando ele mais esticado ou comprimido na horizontal. Nestes casos, você precisa definir tamanhos de fonte diferente na horizontal também, saiba mais em dxDrawText. Evite repetição de código. Crie uma tabela com todas as posições e tamanhos de cada botão junto com os textos. Então dentro da função do onClientRender você apenas faz um "loop ipairs" entre os itens dessa tabela, gerando os botões com as propriedades da tabela. Na função do onClientClick, você usa a mesma tabela para verificar qual botão foi clicado, criando uma condição para cada índice da tabela. Ex: Se clicou no item 1 da tabela, faz tal coisa. Senão, se clicou no item 2 da tabela, faz outra coisa e assim por diante. Para facilitar na hora de fazer manutenção no painel, deixe cada dxDraw com comentários no final da linha dizendo o que é cada item. Por exemplo, no final da linha do primeiro dxDrawRectangle, adicione o comentário: -- Janela Só então, depois do painel pronto, você deve criar feedback visual ao passar o mouse pelas áreas clicáveis. Já que o objetivo de um painel DX é ser mais bonito do que funcional. Se fosse pra ser mais funcional do que bonito, você deveria usar CEGUI em vez de DXGUI. Ao passar o mouse em cima de um botão, mude a cor dele para o jogador saber que é uma área clicável. Ou então mude a cor do texto do botão.
-
Não crie diversos tópicos com assuntos parecidos. Irei fechar este tópico. Caso ainda precise de ajuda neste painel, continue no outro post sobre o outro painel DX.
-
Crie uma variável com valor 0. Por exemplo playersArena = 0 Sempre que um jogador entrar, aumente em +1 nessa variável: playersArena = playersArena + 1 Sempre que um jogador sair ou desconectar do servidor, diminua em -1 essa variável: playersArena = playersArena - 1 Dai no texto, apenas mostre o valor dessa variável com um tostring(playersArena).
-
Dê um nome para a função que você quer repetir e também deixe o timer numa variável. Ao desligar o infravermelho, cancele o timer usando killTimer na variável dele e depois execute essa função que seria chamada só mais tarde pelo timer.
-
Client: Server:
-
Olha... vc só mudou 1 variável. Mas não trocou os getElementData/setElementData para getPlayerMoney/setPlayerMoney. Além disso, getPlayerMoney e setPlayerMoney devem ser feitos server-side somente. Então você precisará de triggerServerEvent ali no script client-side para chamar um evento lá no server-side para mexer no dinheiro no jogador. Até pq tentar setar dinheiro no jogador via client-side só mudará na Hud, mas não vai mudar no servidor, então o dinheiro que aparece na Hud não será a quantidade real que ele tem no servidor.
-
Mostre o que você já tentou fazer.
-
Após analisar seu código, fiz um exemplo parecido com sua ideia. Independente da resolução, ele vai ter a mesma proporção e distância da borda da tela. local screen = Vector2 (guiGetScreenSize()) -- local screen.x, screen.y = guiGetScreenSize() local offset = screen.y * 0.01852 -- Distância relativa da borda da tela. (0 = colado na borda) --[[ ~20px = 0.01852 ~15px = 0.01389 ~10px = 0.00926 ]] local bgScale, circleScale = (screen.y * 0.04), 0.9 -- Raio dos círculos background relativos à tela | Raio dos círculos em relação aos círculos background. -- (1 = tamanho Y da tela | 1 = tamanho igual aos círculos de background) local iconScale = bgScale * 0.5 -- Tamanho relativo dos ícones em relação ao tamanho dos backgrounds. (1 = tamanho igual aos círculos de background) local circleAngle = 270 -- Ângulo que os backgrounds e os círculos começam a ser preenchidos. (0 = direita, 90 = abaixo, 180 = esquerda, 270 = acima) addEventHandler("onClientRender", root, function() local health = getElementHealth(localPlayer) local armor = getPedArmor(localPlayer) dxDrawCircle (offset + bgScale, screen.y - bgScale - offset, bgScale, 0, 360, tocolor(28, 28, 28, 170)) -- bg Health dxDrawCircle (offset + bgScale, screen.y - bgScale - offset, bgScale * circleScale, 0 + circleAngle, (360 * (health/100)) + circleAngle, tocolor(255, 32, 32)) -- Health -- dxDrawImage (ícone da vida) if armor > 0 then -- Faz com que o círculo de armor só apareça se não estiver em 0. dxDrawCircle ((offset + bgScale) + (bgScale * 1.4), screen.y - bgScale - offset, bgScale, 0, 360, tocolor(28, 28, 28, 170)) -- bg Armor dxDrawCircle ((offset + bgScale) + (bgScale * 1.4), screen.y - bgScale - offset, bgScale * circleScale, 0 + circleAngle, (360 * (armor/100)) + circleAngle, tocolor(255, 255, 255)) -- Armor -- dxDrawImage (ícone do colete) end end)
-
Mande uma imagem da sua tela inteira mostrando o painel. Não temos como testar sem as imagens das fontes e sem as funções úteis.
-
De nada.
-
objeto = createObject (1337, 2502, -1667, 12.36) -- Cria um objeto qualquer na Grove Street. addEventHandler("onClientRender", root, function() -- for _, objeto in ipairs(getElementsByType("object")) do -- DESATIVADOS APENAS PARA TESTES. -- if (getElementData(objeto,"objeto.element")) then -- local ID = getElementData(objeto, "objeto.id") -- local PD = getElementData(objeto, "objeto.produtos") local ID = 1337 -- APENAS PARA TESTES local PD = 1234567890 -- APENAS PARA TESTES local localPos = {getElementPosition(localPlayer)} local objetoPos = {getElementPosition(objeto)} local worldPosition = {getScreenFromWorldPosition(objetoPos[1], objetoPos[2], objetoPos[3] + 0.50)} local distance = getDistanceBetweenPoints3D(localPos[1], localPos[2], localPos[3], objetoPos[1], objetoPos[2], objetoPos[3]) if distance <= 15 then if worldPosition[1] and worldPosition[2] then dxDrawText("ID: "..ID.." | PD: "..PD, worldPosition[1], worldPosition[2], worldPosition[1], worldPosition[2], tocolor(255, 255, 255, 255), 1.0 , "default-bold", "center") end end -- end -- end -- DESATIVADOS APENAS PARA TESTES. end)
-
O seu 4º e 5º parâmetros não fazem sentido. (10, 20) Também não faz sentido vc colocar "center" fora de aspas duplas. Este parâmetro é uma string, portanto precisa estar entre aspas, exatamente como mencionei na minha resposta anterior. O primeiro "center" faz ele centralizar o texto na horizontal, o segundo "center" faz ele centralizar na vertical, mas não é necessário centralizar na vertical nesse caso, pois é só aumentar o diminuir aquele offset do + 0.50 para mudar a altura do texto. Então utilize apenas o primeiro "center" e delete o que tem depois.
-
Adicione o parâmetro , "center" depois do nome da fonte ali no dxDrawText.
-
Cadê o onClientPedsProcessed? Ele é necessário para atualizar a posição dos ossos a cada frame. Veja o exemplo da própria Wiki.
-
Melhorar proteção para pegar painel P
Lord Henry replied to igoor.66_'s topic in Portuguese / Português
A culpa é inteiramente da administração do servidor. As possíveis causas são as seguintes: 1) Não desenvolveram uma segurança decente para o servidor, permitindo que os jogadores violem os banimentos. 2) Desenvolveram resources com brechas de segurança que tornaram o servidor violável pelos clientes. 3) Deram permissão admin para algum resource desconhecido que está colocando usuários não autorizados na ACL Group Console. -
Nenhum desses exemplos vai funcionar pois faltou fechar o parênteses do addEventHandler. Adicione um ) depois do último end.
-
say Como remover o Chat Nativo do MTA para usar um chat local
Lord Henry replied to leaodon's topic in Programação em Lua
Para fazer com que o jogador não consiga abrir o chatbox pela tecla T (isso também vai impedir que ele use o teamsay pela tecla Y), você pode simplesmente desativar o controle de acesso do chatbox com isso: (client-side) -- CLIENT-SIDE addEventHandler("onClientResourceStart", resourceRoot, function() -- Executa essa função ao iniciar este resource no client. toggleControl("chatbox", false) -- Bloqueia o acesso ao chatbox pelas teclas T e Y, mas ainda é possível enviar mensagens e comandos pelo F8. showChat (false) -- Esta função torna o chat invisível para este client. -- O jogador ainda pode restaurar o chat pelo comando "showchat" no F8. Mas ele continuará inacessível pelo T e Y devido ao toggleControl. -- Após restaurar o chat pelo F8, o jogador pode mandar mensagens e comandos pelo F8 também. end) Para evitar as mensagens de "say" e "teamsay" pelo F8, use isso: (server-side) -- SERVER-SIDE local cmdBloqueados = {"say", "teamsay"} -- Lista de comandos bloqueados. addEventHandler("onPlayerCommand", root, function(command) for _,cmd in pairs(cmdBloqueados) do if (command == cmd) then cancelEvent() -- Só consegue bloquear comandos server-side. break end end end) Com isso você torna impossível usar o chatbox. Comandos server-side você pode bloquear adicionando ali na lista. Mas os comandos client-side não podem ser bloqueados por questões de segurança. -
say Como remover o Chat Nativo do MTA para usar um chat local
Lord Henry replied to leaodon's topic in Programação em Lua
Por medidas de segurança, não é possível desativar o F8. O evento onClientKey não chega a ser chamado ao apertar a tecla F8. Da mesma forma, não adianta bindar comandos no F8 pois eles não serão chamados. Essa tecla é para uso restrito do Client Console e não pode ser utilizada para outras finalidades. -
Tem. Basta cancelar o evento onClientPlayerDamage quando o tipo de dano for de queda. addEventHandler("onClientPlayerDamage", localPlayer, function (attacker, weapon) -- Ativa este evento sempre que o localPlayer tomar qualquer dano. if weapon == 54 then -- Se o dano for de queda, então: cancelEvent() -- Cancela este evento e não toma o dano. end end)
- 1 reply
-
- 1
-
Só verificar se o veículo existe com isElement.