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

Pelmeska

Известный
931
232
sampRegisterChatCommand("flood", function() flood = not flood end)
Теперь скрипт загрузился без ошибок, но команда не работает, при вводе команды /flood ничего не происходит
Lua:
local color1 = "0xFFC080"

function main()
  while not isSampAvailable() do wait(100) end
  sampAddChatMessage("Скрипт флудир успешно загружен", color1)
  thr = lua_thread.create_suspended(thread_create)
  local flood = false
  sampRegisterChatCommand("flood", function() flood = not flood end)
  while true do
    wait(0)
  end
end

function flood(arg)
  if not arg:match("(%d)") then
    sampAddChatMessage("Ошибка. Введите аргумент.", color1)
  else
    thr:run(arg)
 end
end

function thread_create(arg)
  while true do
    wait(0)
      sampSendChat("Я ввел аргумент -  " ..  arg)
    end
end
 

PanSeek

t.me/dailypanseek
Всефорумный модератор
908
1,776
Теперь скрипт загрузился без ошибок, но команда не работает, при вводе команды /flood ничего не происходит
Потому что человек выше бурду написал. Сейчас попробую помочь.
 
  • Нравится
Реакции: James Saula и Pelmeska

Vintik

Через тернии к звёздам
Проверенный
1,556
1,027
Хм, у меня вышло как то странно, при значении scr = false выводится "Скрипт деактивирован", а если поставить значение True, то будет писать что скрипт активирован.
Lua:
-- где-то в самом начале кода
scr = false

-- в imgui.OnDrawFrame()
if imgui.Button('Кнопка активации') then
  -- тут сам код активации, например:
  scr = not scr
  sampAddChatMessage(scr and 'Скрипт активирован' or 'Скрипт деактивирован', -1)
end
 
  • Нравится
Реакции: Gorskin и ollydbg

PanSeek

t.me/dailypanseek
Всефорумный модератор
908
1,776
Если не сложно, можешь добавить обьяснение к тому что ты добавил пожалуйста?) Чтоб мне понимать что ты сделал, на будущее мне)
Не знаю как надо, но я понял так:
1. При вводе аргумента, будет отправляться флуд с сообщением.
2. Если аргумент пуст, то вывод сообщения, чтоб ввели аргумент и скрипт приостанавливается.
Если так, то вот:
Lua:
local color1 = 0xFFC080
local param, active = nil, false

function main()
    while not isSampAvailable() do wait(100) end
    sampAddChatMessage("Скрипт флудир успешно загружен", color1)
    sampRegisterChatCommand("flood", function(arg)
        if not arg:match("(%d)") then
            sampAddChatMessage("Ошибка. Введите аргумент.", color1)
            param, active = nil, false
        else
            param, active = arg, true
        end
    end)
    while true do
        wait(0)
        if active then
            sampSendChat("Я ввел аргумент -  " ..  param)
        end
    end
end
можешь добавить обьяснение
Тут понятно вроде.
 

sloniksky

Участник
42
13
как получить корды такой метки?
1618597850077.png
 

Pelmeska

Известный
931
232
Не знаю как надо, но я понял так:
1. При вводе аргумента, будет отправляться флуд с сообщением.
2. Если аргумент пуст, то вывод сообщения, чтоб ввели аргумент и скрипт приостанавливается.
Если так, то вот:
Lua:
local color1 = 0xFFC080
local param, active = nil, false

function main()
    while not isSampAvailable() do wait(100) end
    sampAddChatMessage("Скрипт флудир успешно загружен", color1)
    sampRegisterChatCommand("flood", function(arg)
        if not arg:match("(%d)") then
            sampAddChatMessage("Ошибка. Введите аргумент.", color1)
            param, active = nil, false
        else
            param, active = arg, true
        end
    end)
    while true do
        wait(0)
        if active then
            sampSendChat("Я ввел аргумент -  " ..  param)
        end
    end
end

Тут понятно вроде.
Почти все понял кроме пару моментов:
для чего переменная local param, active = nil, false,

за что отвечает:
param, active = nil false
else
param, active = arg, true
обьясни мне пожалуйста

и зачем if active then ?
 

PanSeek

t.me/dailypanseek
Всефорумный модератор
908
1,776
для чего переменная local param, active = nil, false,
param - параметр
active - состояние flood
param, active = nil false
else
param, active = arg, true
Если не найден аргумент, то присваиваем значения: param и active - nil и false
Если аргумент найден, то param присваивает значение из arg, а active становится true
и зачем if active then ?
Если active равен true, то следующий код будет работать, иначе не будет.
 
  • Нравится
Реакции: James Saula и Pelmeska

Dashok.

Участник
228
9
Как сделать так что-бы когда вводишь имя кнопки в поисковую строку, снизу появлялись кнопки с похожим названием
код:
if imgui.InputText(u8"Поиск", ans_ans_ans) then
         for key, v in pairs(i_ans) do
            if key == "default" then
                for key_2, v_2 in pairs(ans_ans_ans[key]) do
                    if imgui.Button(key_2, btn_size) then
                        if not i_back_prefix.v then
                            local settext = '{FFFFFF}' .. v_2
                            sampSendDialogResponse(2351, 1, 0, settext)
                        else
                            local settext = '{FFFFFF}' .. v_2 .. ' {AAAAAA}// Приятной игры на "RDS"!'
                            sampSendDialogResponse(2351, 1, 0, settext)
                        end
                    end
                end
            end
        end
        end

i_ans:
local i_ans = {
    ["default"] =
    {
        [u8"Начать работу по жалобе."] = "Начинаю работать по вашей жалобе.",
        [u8"Уточните."] = "Пожалуйста уточните вашу жалобу.",
        [u8"Ожидайте."] = "Ожидайте.",
        [u8"Попробую помочь."] = "Сейчас попробую вам помочь.",
        [u8"Слежу."] = "Слежу.",
        [u8"Не оффтопте"] = "Не оффтопте!",
        [u8"Проверим"] = "Проверим.",
        [u8"Приятной игры"] = "Приятной игры на Russian Drift Server!",
        [u8"Где взять обычный вип"] = "У НПС на /trade за 10.000 очков.",
        [u8"Где взять премиум вип"] = "У НПС на /trade за 10.000 очков.",
        [u8"Где взять даймонд вип"] = "/donate > 4 пункт.",
        [u8"Где взять платинум вип"] = "/donate > 5 пункт.",
        [u8"Что может вип"] = "Данную информацию узнайте в /help > 7.",
        [u8"Где взять аксессуары"] = "На центральном рынке. /trade",
        [u8"Как одеть аксессуар"] = "/inv > эксклюзивные аксессуары",
        [u8"Как посмотреть аксессуары"] = "/inv > эксклюзивные аксессуары",
        [u8"Что делать с аксессуарами"] = "Одевать и продавать. /inv",
        [u8"Как заработать деньги, коины и очки"] = "Всю иформацию вы можете узнать в /help > 13.",
        [u8"Куда тратить коины"] = "На личное авто, клубы, аксесуары и т.д.",
        [u8"Куда тратить очки"] = "На личное авто, аксесуары, вип статусы, обменять и т.д.",
        [u8"Куда тратить деньги"] = "На личное покупку бизнесов, оружия и т.д.",
        [u8"Как передать очки"] = "/givescore При наличии Даймонд Вип.",
        [u8"Как передать коины"] = "/givecoin",
        [u8"Как передать деньги"] = "/givemoney id сумма.",
        [u8"Где обменять очки на вирыт или коины"] = "У Армана на /trade.",
        [u8"Как посмотреть очки"] = "/statpl",
        [u8"Как посмотреть коины"] = "/rdscoin",
        [u8"Как принять в банду"] = "/menu > система банд > пригласить в банду.",
        [u8"Как выйти из банды"] = "/gleave.",
        [u8"Система банд"] = "/menu > ситема банд.Там вы все найдете.",
        [u8"Как создать"] = "/menu > ситема банд > создать.",
        [u8"Где найти HTML-цвет."] = "Посмотрите в интернете. Ссылка - https://basicweb.ru/html/html_colors.php.",
        [u8"Как принять в семью"] = "/finvite.",
        [u8"Как создать"] = "/trade > у НПС Армана за 50.000 очков.",
        [u8"Как уйти из семью"] = "/familypanel > покинуть семью.",
        [u8"Меню семьи."] = "/familypanel, там вы сможете это найти.",
        [u8"Ссылка на основателя"] = "Ссылка на вк основателя > vk.com/empirerosso",
        [u8"Ссылка на кодера"] = "Кодер в ВК > vk.com/vipgamer228.",
        [u8"Ссылка группы сервера"] = "Группа в ВК > vk.com/dmdriftgta.",
        [u8"Как купить дом"] = "Найти свободный, всать на пикап, нажать F > Купить.",
        [u8"Как продать дом"] = "В гос - /hpanel > продать дом.Продать дом игроку /sellmyhouse id цена.",
        [u8"Как подселить в дом"] = "/hpanel > список жильцов > подселить.",
        [u8"Как взять авто"] = "/menu > транспорт > тип транспорта.",
        [u8"Как протюнинговать авто"] = "/menu > транспорт > тюнинг.",
        [u8"Как заспавнить л/ч авто"] = "/car > заспавнить.",
        [u8"Как купить личное авто"] = "/tp > разное > автосалоны.",
        [u8"Как продать л/ч авто"] = "В гос - /car > продать авто.Продать игроку - /autoyartp.",
        [u8"Как взять оружие"] = "/menu > оружия.",
        [u8"Как убрать оружие"] = "/menu > оружия > убрать оружие.",
        [u8"Вход/выход игроков"] = "/menu > настройки > 1 пункт.",
        [u8"Разрешение вызывать на дуель"] = "/menu > настройки > 2 пункт.",
        [u8"Вкл/откл личные сообщения"] = "/menu > настройки > 3 пункт.",
        [u8"Запросы на телепорт"] = "/menu > настройки > 4 пункт.",
        [u8"Показ DM Статистики"] = "/menu > настройки > 5 пункт.",
        [u8"Эфект при телепортации"] = "/menu > настройки > 6 пункт.",
        [u8"Показывать спидометр"] = "/menu > настройки > 7 пункт.",
        [u8"Показывать Дрифт Уровень"] = "/menu > настройки > 8 пункт.",
        [u8"Спавн в доме/доме семью"] = "/menu > настройки > 9 пункт.",
        [u8"Вызов главного меню"] = "/menu > настройки > 10 пункт.",
        [u8"Вкк/Выкл приглашение в банду"] = "/menu > настройки > 11 пункт.",
        [u8"Выбор ТС На текст драве"] = "/menu > настройки > 12 пункт.",
        [u8"Вкл/Выкл кейс"] = "/menu > настройки > 13 пункт.",
        [u8"Вкл/Выкл фпс показатель"] = "/menu > настройки > 15 пункт.",
        [u8"Пишите жалобу"] = "Пишите жалобу в группу вк > vk.com/dmdriftgta.",
        [u8"Посмотрите в интернете."] = "Посмотрите в интренете.",
        [u8"Нет"] = "Нет.",
        [u8"Не выдаем"] = "Не выдаем.",
        [u8"Не запрещенно"] = "Не запрещенно.",
        [u8"Где взять кейс"] = "Он появится при наличии 100 милилонов на руках.",
        [u8"Как вкл/выкл кейс"] = "/menu > настройки > 13 пункт.",
        [u8"Как отправлять дуель"] = "/duel id.",
        [u8"Перезайдите"] = "Попробйте перезайти на сервер.",
        [u8"Никак"] = "Никак."
    }
}