Вопросы по 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
 
Последнее редактирование:

damag

Женюсь на официантке в моем любимом баре
Проверенный
1,152
1,199
Как вариант, проверять заспавнен ли твой персонаж или нет
Если заспавнен тогда продолжить код
Lua:
function sampev.onPlayerJoin()
   if sampIsLocalPlayerSpawned() then
      -- code
   end
end
Так onPlayerJoin это не когда ты заходишь, а игрок.
 

enyag

Известный
345
12
как проверить наличие какого то файла в папке с moonloader и если нет его то скачать?
 

neverlane

t.me/neverlane00
Друг
1,010
1,161
Так onPlayerJoin это не когда ты заходишь, а игрок.
Так у него добавлялись игроки которые уже на сервере а ему это не надо (как я понял)
как проверить наличие какого то файла в папке с moonloader и если нет его то скачать?
Lua:
if doesFileExist(getWorkingDirectory()..'\\file.lua') then
   --code
end
 

Rei

Известный
Друг
1,610
1,666
Lua:
config.settings.test1 = 'asfas'
config.settings.test2 = 'asasf21fas'
config.settings.test3 = 'as412fas'
config.settings.test4 = 'asfgaas'

можно как-то обращаться к нужному значению с помощью переменной? типа так
Код:
var = 3
print(config.settings.test..var)
----------------------
as412fas
 

trefa

Известный
Всефорумный модератор
2,104
1,249
Lua:
config.settings.test1 = 'asfas'
config.settings.test2 = 'asasf21fas'
config.settings.test3 = 'as412fas'
config.settings.test4 = 'asfgaas'

можно как-то обращаться к нужному значению с помощью переменной? типа так
Код:
var = 3
print(config.settings.test..var)
----------------------
as412fas
config.settings["test"..var]
 
  • Нравится
Реакции: Rei

Anton Nixon

Активный
474
48
почему ники не переносятся на новую строку?
sa-mp-031.png

Lua:
if imgui_imbool.admin_online.v then -- админы в сети
            AdminTitle = "Администраторы в сети:"
            if not imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                renderFontDrawText(admin_title_font, AdminTitle, check_X, check_Y, 0xffffffff)
            elseif imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                local new_Y = renderGetFontDrawHeight(leadfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = lead_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            elseif not imgui_imbool.leader_online.v and imgui_imbool.friend_online.v then
                local new_Y = renderGetFontDrawHeight(friendfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = friend_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            else
                local new_Y = renderGetFontDrawHeight(friendfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = friend_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            end
            local count = 1
            for k, v in pairs(admins) do
                if sampIsPlayerConnected(idbynick(v.nick)) then
                    adminStreamed, _ = sampGetCharHandleBySampPlayerId(idbynick(v.nick))
                    adminPaused = sampIsPlayerPaused(idbynick(v.nick))
                    if adminStreamed then
                        if adminPaused then
                            adminList = string.format("{%s}%i. %s [%i] {FF0000}[AFK] {808080}[#]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                        else
                            adminList = string.format("{%s}%i. %s [%i] {808080}[#]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                        end
                    else
                        adminList = string.format("{%s}%i. %s [%i]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                    end
                    count = count + 1
                    AdminText = string.format("%s\n", adminList)
                    if not imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                        local new_Y = renderGetFontDrawHeight(admin_title_font)
                        local new_coord_Y = new_Y + 0.5
                        admin_check_Y = check_Y + new_coord_Y
                        renderFontDrawText(adminfont, AdminText, check_X, admin_check_Y, 0xffffffff)
                    else
                        local new_Y = renderGetFontDrawHeight(admin_title_font)
                        local new_coord_Y = new_Y + 0.5
                        admin_check_Y = admin_title_check_Y + new_coord_Y
                        renderFontDrawText(adminfont, AdminText, check_X, admin_check_Y, 0xffffffff)
                    end
                end
            end
        end
 

Carlos777

Потрачен
227
219
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
почему ники не переносятся на новую строку?
Посмотреть вложение 65664
Lua:
if imgui_imbool.admin_online.v then -- админы в сети
            AdminTitle = "Администраторы в сети:"
            if not imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                renderFontDrawText(admin_title_font, AdminTitle, check_X, check_Y, 0xffffffff)
            elseif imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                local new_Y = renderGetFontDrawHeight(leadfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = lead_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            elseif not imgui_imbool.leader_online.v and imgui_imbool.friend_online.v then
                local new_Y = renderGetFontDrawHeight(friendfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = friend_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            else
                local new_Y = renderGetFontDrawHeight(friendfont)
                local new_coord_Y = new_Y * 1.3
                admin_title_check_Y = friend_check_Y + new_coord_Y
                renderFontDrawText(admin_title_font, AdminTitle, check_X, admin_title_check_Y, 0xffffffff)
            end
            local count = 1
            for k, v in pairs(admins) do
                if sampIsPlayerConnected(idbynick(v.nick)) then
                    adminStreamed, _ = sampGetCharHandleBySampPlayerId(idbynick(v.nick))
                    adminPaused = sampIsPlayerPaused(idbynick(v.nick))
                    if adminStreamed then
                        if adminPaused then
                            adminList = string.format("{%s}%i. %s [%i] {FF0000}[AFK] {808080}[#]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                        else
                            adminList = string.format("{%s}%i. %s [%i] {808080}[#]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                        end
                    else
                        adminList = string.format("{%s}%i. %s [%i]", color_checker.admin[tonumber(v.lvl)], count, v.nick, idbynick(v.nick))
                    end
                    count = count + 1
                    AdminText = string.format("%s\n", adminList)
                    if not imgui_imbool.leader_online.v and not imgui_imbool.friend_online.v then
                        local new_Y = renderGetFontDrawHeight(admin_title_font)
                        local new_coord_Y = new_Y + 0.5
                        admin_check_Y = check_Y + new_coord_Y
                        renderFontDrawText(adminfont, AdminText, check_X, admin_check_Y, 0xffffffff)
                    else
                        local new_Y = renderGetFontDrawHeight(admin_title_font)
                        local new_coord_Y = new_Y + 0.5
                        admin_check_Y = admin_title_check_Y + new_coord_Y
                        renderFontDrawText(adminfont, AdminText, check_X, admin_check_Y, 0xffffffff)
                    end
                end
            end
        end

не Y а X
 

СоМиК

Известный
458
314
Йй, нужна помощь по ImGui.
Я думаю многие знают такой скрипт, MVD Helper. И я думаю, что очень много людей знают про функцию "виджет" в этом хелпере. Кто не понял, речь идёт о маленьком квадратике, в котором находится такая информация, как состояние здоровья, состояние брони и остальное (что выберет пользователь, то и будет там находится). Так вот, если вы поняли о чем я говорю, то вы наверняка знаете, что в меню скрипта есть кнопка, с помощью которой можно настроить расположение этого виджета. При нажатии на кнопку, этот маленький квадратик привязывается к мыши, затем пользователь выбирает нужное расположение для этого виджета и нажимает ЛКМ. После чего виджет становится на то место, куда его поставил игрок. Так вот. Кто подскажет, как сделать такое же?
 

DANIIL XPC

Известный
81
5
command / sp must go with id, how do I do that?
Код:
function sampev.onServerMessage(col, text)
    if text:find("Car from > DANIIL.XPC") then
        sampSendChat("/sp id or name from DANIIL.XPC")
    end
end
 

enyag

Известный
345
12
как сделаю проверку на наличие папки в lib и если её нет то скачать?
 

Fott

Простреленный
3,460
2,371
как сделаю проверку на наличие папки в lib и если её нет то скачать?
Вот пример
Lua:
local dlstatus = require('moonloader').download_status
if not doesFileExist("moonloader/resource/fonts/fa-solid-900.ttf") then
    sampAddChatMessage('[{f16c7d}AutoLogin{FFFFFF}]: Шрифт не был найден, началось автоматическое скачивание, не закрывайте игру!', -1)
    download_id = downloadUrlToFile('https://drive.google.com/uc?export=download&confirm=no_antivirus&id=1weBSdFiPb7YO7lLwSDyY-wGFr0SZT01I', getWorkingDirectory()..'/resource/fonts/fa-solid-900.ttf', function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then sampAddChatMessage('[{f16c7d}AutoLogin{FFFFFF}]: Скачивание успешно завершено.', -1) end
    end)
end
 
  • Нравится
Реакции: enyag

enyag

Известный
345
12
Вот пример
Lua:
local dlstatus = require('moonloader').download_status
if not doesFileExist("moonloader/resource/fonts/fa-solid-900.ttf") then
    sampAddChatMessage('[{f16c7d}AutoLogin{FFFFFF}]: Шрифт не был найден, началось автоматическое скачивание, не закрывайте игру!', -1)
    download_id = downloadUrlToFile('https://drive.google.com/uc?export=download&confirm=no_antivirus&id=1weBSdFiPb7YO7lLwSDyY-wGFr0SZT01I', getWorkingDirectory()..'/resource/fonts/fa-solid-900.ttf', function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then sampAddChatMessage('[{f16c7d}AutoLogin{FFFFFF}]: Скачивание успешно завершено.', -1) end
    end)
end
а как получить такую ссылку с google drive?