Вопросы по Lua скриптингу

Общая тема для вопросов по разработке скриптов на языке программирования Lua, в частности под MoonLoader.
  • Задавая вопрос, убедитесь, что его нет в списке частых вопросов и что на него ещё не отвечали (воспользуйтесь поиском).
  • Поищите ответ в теме посвященной разработке Lua скриптов в MoonLoader
  • Отвечая, убедитесь, что ваш ответ корректен.
  • Старайтесь как можно точнее выразить мысль, а если проблема связана с кодом, то обязательно прикрепите его к сообщению, используя блок [code=lua]здесь мог бы быть ваш код[/code].
  • Если вопрос связан с MoonLoader-ом первым делом желательно поискать решение на wiki.

Частые вопросы

Как научиться писать скрипты? С чего начать?
Информация - Гайд - Всё о Lua скриптинге для MoonLoader(https://blast.hk/threads/22707/)
Как вывести текст на русском? Вместо русского текста у меня какие-то каракули.
Изменить кодировку файла скрипта на Windows-1251. В Atom: комбинация клавиш Ctrl+Shift+U, в Notepad++: меню Кодировки -> Кодировки -> Кириллица -> Windows-1251.
Как получить транспорт, в котором сидит игрок?
Lua:
local veh = storeCarCharIsInNoSave(PLAYER_PED)
Как получить свой id или id другого игрока?
Lua:
local _, id = sampGetPlayerIdByCharHandle(PLAYER_PED) -- получить свой ид
local _, id = sampGetPlayerIdByCharHandle(ped) -- получить ид другого игрока. ped - это хендл персонажа
Как проверить, что строка содержит какой-то текст?
Lua:
if string.find(str, 'текст', 1, true) then
-- строка str содержит "текст"
end
Как эмулировать нажатие игровой клавиши?
Lua:
local game_keys = require 'game.keys' -- где-нибудь в начале скрипта вне функции main

setGameKeyState(game_keys.player.FIREWEAPON, -1) -- будет сэмулировано нажатие клавиши атаки
Все иды клавиш находятся в файле moonloader/lib/game/keys.lua.
Подробнее о функции setGameKeyState здесь: lua - setgamekeystate | BlastHack — DEV_WIKI(https://www.blast.hk/wiki/lua:setgamekeystate)
Как получить id другого игрока, в которого целюсь я?
Lua:
local valid, ped = getCharPlayerIsTargeting(PLAYER_HANDLE) -- получить хендл персонажа, в которого целится игрок
if valid and doesCharExist(ped) then -- если цель есть и персонаж существует
  local result, id = sampGetPlayerIdByCharHandle(ped) -- получить samp-ид игрока по хендлу персонажа
  if result then -- проверить, прошло ли получение ида успешно
    -- здесь любые действия с полученным идом игрока
  end
end
Как зарегистрировать команду чата SAMP?
Lua:
-- До бесконечного цикла/задержки
sampRegisterChatCommand("mycommand", function (param)
     -- param будет содержать весь текст введенный после команды, чтобы разделить его на аргументы используйте string.match()
    sampAddChatMessage("MyCMD", -1)
end)
Крашит игру при вызове sampSendChat. Как это исправить?
Это происходит из-за бага в SAMPFUNCS, когда производится попытка отправки пакета определенными функциями изнутри события исходящих RPC и пакетов. Исправления для этого бага нет, но есть способ не провоцировать его. Вызов sampSendChat изнутри обработчика исходящих RPC/пакетов нужно обернуть в скриптовый поток с нулевой задержкой:
Lua:
function onSendRpc(id)
  -- крашит:
  -- sampSendChat('Send RPC: ' .. id)

  -- норм:
  lua_thread.create(function()
    wait(0)
    sampSendChat('Send RPC: ' .. id)
  end)
end
 
Последнее редактирование:

DZONE

Известный
187
198
Lua:
local function nformat(allowed, fmt, ...)
    local output = ""
    local vararg = { ... }
    local pos = 1
    local iterated = false

    local start = 1
    while start <= #fmt do
        local ch = string.sub(fmt, start, start)
        local nextCh = string.sub(fmt, start + 1, start + 1)
        if ch == "%" and nextCh ~= "%" then
            for _, directive in ipairs(allowed) do
                local directiveInFmt = string.sub(fmt, start + 1, start + #directive)
                if directiveInFmt == directive then
                    output = output .. string.format(ch .. directiveInFmt, vararg[pos])
                    pos, iterated, start = pos + 1, true, start + #directiveInFmt + 1
                    break
                end
            end
            if not iterated then
                output, start = output .. ch .. nextCh, start + 2
            else
                iterated = false
            end
        else
            output, start = output .. ch, start + 1
        end
    end
  
    return output
end

print(nformat({"d", "s"}, "Hello, %s%f! Your number is %d", "world", 14.1, 5))
result:
Hello, world%f! Your number is 5
 
Последнее редактирование:
  • Нравится
Реакции: de_clain

Gorskin

♥ Love Lua ♥
Проверенный
1,334
1,172
Lua:
local function nformat(allowed, fmt, ...)
    local output = ""
    local vararg = { ... }
    local pos = 1
    local iterated = false

    local start = 1
    while start <= #fmt do
        local ch = string.sub(fmt, start, start)
        local nextCh = string.sub(fmt, start + 1, start + 1)
        if ch == "%" and nextCh ~= "%" then
            for _, directive in ipairs(allowed) do
                local directiveInFmt = string.sub(fmt, start + 1, start + #directive)
                if directiveInFmt == directive then
                    output = output .. string.format(ch .. directiveInFmt, vararg[pos])
                    pos, iterated, start = pos + 1, true, start + #directiveInFmt + 1
                    break
                end
            end
            if not iterated then
                output, start, pos = output .. ch .. nextCh, start + 2, pos + 1
            end
        else
            output, start = output .. ch, start + 1
        end
        iterated = false
    end
   
    return output
end

print(nformat({"d", "s"}, "Hello, %s%f! Your number is %d", "world", 14.1, 5))
result:
Hello, world%f! Your number is 5
%f нельзя да и вообще любой символ кроме d. Мне нужно что бы можно было в формате ставить только %d и любой текст с числами. Всё остальное с %a, %c, %k и т.д игнорировать.
 

DZONE

Известный
187
198
%f нельзя да и вообще любой символ кроме d. Мне нужно что бы можно было в формате ставить только %d и любой текст с числами. Всё остальное с %a, %c, %k и т.д игнорировать.
это же так и будет работать, в первом аргументе прописываешь {"d", "02d"} и функция будет реагировать только на эти директивы
%f как пример игнорирования

чутка изменил функцию

Lua:
local hour = os.date("*t").hour
local minute = os.date("*t").min
local result = nformat({"d", "02d"}, "%s: %d | %s: %d", hour, minute)

print(result)

>>> %s: 14 | %s: 58
 
Последнее редактирование:

YarikVL

Известный
Проверенный
4,751
1,814
есть ли Fskin с возможностью выдачу скинов с лаунчера аризоны
Бан в Гугле? Бан в разделе помощи гта?
 

tsunamiqq

Участник
433
17
Работает пиар только после перезагрузки скрипта, и выключается также:

Lua:
local inicfg = require('inicfg')
local directIni = 'CNNHelper.ini'
local mainIni = inicfg.load(inicfg.load({
    autopiar = {
        vrchecked = false,
        vrtext = u8'',
        vrdelay = 60000
        checkedautopiar = false
}, directIni))
inicfg.save(mainIni, directIni)

local AUTOPIAR = {
    vrchecked = new.bool(mainIni.autopiar.vrchecked),
    vrtext = new.char[256](u8(mainIni.autopiar.vrtext)),
    vrdelay = new.int(mainIni.autopiar.vrdelay),
    checkedautopiar = new.bool(mainIni.autopiar.checkedautopiar)
}

--Окно

        if imgui.Checkbox(u8' Вкл/Выкл AutoPiar', AUTOPIAR.checkedautopiar) then
            mainIni.autopiar.checkedautopiar = AUTOPIAR.checkedautopiar[0]
        end

        if imgui.Checkbox('##vrchecked', AUTOPIAR.vrchecked) then
            mainIni.autopiar.vrchecked = AUTOPIAR.vrchecked[0]
        end

        if imgui.InputTextWithHint(faicons('USER')..u8' Текст /vr', u8'Введите текст', AUTOPIAR.vrtext, 256) then
            mainIni.autopiar.vrtext = u8:decode(ffi.string(AUTOPIAR.vrtext))
        end

        if imgui.InputInt(faicons('CLOCK_NINE')..u8' Задержка /vr', AUTOPIAR.vrdelay) then
            mainIni.autopiar.vrdelay = AUTOPIAR.vrdelay[0]
        end

--Вне окна

if mainIni.autopiar.checkedautopiar then
    if mainIni.autopiar.vrchecked then
        lua_thread.create(function()
            sampSendChat('/vr '..mainIni.autopiar.vrtext)
            wait(mainIni.autopiar.vrdelay)
            return true
        end)
    end
end
хелпаните плз
 

chromiusj

Известный
Модератор
5,606
3,916
ну не флаги, хотя бы обводку...
просто на сервере он как-то создаётся с обводкой, а в луа про это не слово.
1691958529733.png

может у тебя что-то с шрифтом?у меня обводка есть
Lua:
sampCreate3dText('тут был похоронен здравый смысл', 0xFFffffff, x, y, z, 100, false, -1, -1)
 
  • Нравится
Реакции: alarm0

Dmitriy Makarov

25.05.2021
Проверенный
2,500
1,132
Работает пиар только после перезагрузки скрипта, и выключается также:

Lua:
local inicfg = require('inicfg')
local directIni = 'CNNHelper.ini'
local mainIni = inicfg.load(inicfg.load({
    autopiar = {
        vrchecked = false,
        vrtext = u8'',
        vrdelay = 60000
        checkedautopiar = false
}, directIni))
inicfg.save(mainIni, directIni)

local AUTOPIAR = {
    vrchecked = new.bool(mainIni.autopiar.vrchecked),
    vrtext = new.char[256](u8(mainIni.autopiar.vrtext)),
    vrdelay = new.int(mainIni.autopiar.vrdelay),
    checkedautopiar = new.bool(mainIni.autopiar.checkedautopiar)
}

--Окно

        if imgui.Checkbox(u8' Вкл/Выкл AutoPiar', AUTOPIAR.checkedautopiar) then
            mainIni.autopiar.checkedautopiar = AUTOPIAR.checkedautopiar[0]
        end

        if imgui.Checkbox('##vrchecked', AUTOPIAR.vrchecked) then
            mainIni.autopiar.vrchecked = AUTOPIAR.vrchecked[0]
        end

        if imgui.InputTextWithHint(faicons('USER')..u8' Текст /vr', u8'Введите текст', AUTOPIAR.vrtext, 256) then
            mainIni.autopiar.vrtext = u8:decode(ffi.string(AUTOPIAR.vrtext))
        end

        if imgui.InputInt(faicons('CLOCK_NINE')..u8' Задержка /vr', AUTOPIAR.vrdelay) then
            mainIni.autopiar.vrdelay = AUTOPIAR.vrdelay[0]
        end

--Вне окна

if mainIni.autopiar.checkedautopiar then
    if mainIni.autopiar.vrchecked then
        lua_thread.create(function()
            sampSendChat('/vr '..mainIni.autopiar.vrtext)
            wait(mainIni.autopiar.vrdelay)
            return true
        end)
    end
end
Странные дела. Ты не сохраняешь данные и после перезагрузки скрипта у тебя наоборот не должно работать. Уверен, что работает только после перезагрузки?
После перезаписи данных добавь сохранение.
 

Дядя Энрик.

Активный
337
81
Lua:
local sampev = require "lib.samp.events"
function sampev.onServerMessage(color, text)
    if text:find('Вы авторизовались.') then
        sampAddChatMessage('ЕСТЬ КОНТАКТ', -1)
     end
 end
vrode rabotaet

использую /relvl , каким образом получить количество игроков с таким же уровнем который у меня указан в поиске?
JF3KZfpNGHA.jpg
актуально
 

chapo

чопа сребдс // @moujeek
Модератор
8,879
11,601
возвращает массив с айдишниками лошпедусов
Lua:
---@param min number
---@param max number?
---@return number[]
function getPlayersWithLvl(min, max)
    local result = {};
    for id = 0, 1003 do
        if (sampIsPlayerConnected(id)) then
            local lvl = sampGetPlayerScore(id);
            if (lvl >= min and (not max or lvl <= max)) then
                table.insert(result, id);
            end
        end
    end
    return result;
end
 

Дядя Энрик.

Активный
337
81
возвращает массив с айдишниками лошпедусов
Lua:
---@param min number
---@param max number?
---@return number[]
function getPlayersWithLvl(min, max)
    local result = {};
    for id = 0, 1003 do
        if (sampIsPlayerConnected(id)) then
            local lvl = sampGetPlayerScore(id);
            if (lvl >= min and (not max or lvl <= max)) then
                table.insert(result, id);
            end
        end
    end
    return result;
end
и что это, это разве то что нужно? н-ый игрок из н-го числа остатка? 1 из 30 допустим или 5 изи 30