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

SashaKilin

Новичок
13
0
У меня проблема я написал небольшую функцию но когда я её запускаю с помощью команды у меня выводиться только 1 строка
Ошибка в кансоли:
[ML] (error) : C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:75: attempt to yield across C-call boundary
stack traceback:
[C]: in function 'wait'
C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:75: in function <C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:70>
[ML] (error) : Script died due to an error. (45ED1E04)
КОД:
Lua:
function cmd_hobzvon(arg)
    if arg == nil or arg == "" then
        sampAddChatMessage("Укажите на какую лидурку будет идти обзвон!", main_color)
    else
        sampSendChat("[Leaders] Уважаемые игроки!")
        wait(1500)
        sampSendChat("[Leaders] В данный момент проходит обзвон на лидерку " .. arg)
        wait(1500)
        sampSendChat("[Leaders] Критерии: Дискорд(рабочий микрофон), Знания правил, Адекватность!")
        wait(1500)
        sampSendChat("[Leaders] Жилающии писать 777 мне в /sms или в репорт!")
        wait(1500)
    end
end
 

astynk

Известный
Проверенный
742
530
есть функция, которая позволяет уходить в рекон за человеком?
Самое простое - setCameraInFrontOfChar(ped)
Не отправляет спектейт, может палиться по аим синхре.
При выходе игрока из зоны стрима/сервера сбрасывай камеру через restoreCamera(), иначе крашнет.
 

Rei

Известный
Друг
1,593
1,626
Самое простое - setCameraInFrontOfChar(ped)
Не отправляет спектейт, может палиться по аим синхре.
При выходе игрока из зоны стрима/сервера сбрасывай камеру через restoreCamera(), иначе крашнет.
а если запомнить свою последнюю аим синхру и отправлять ее пока следишь? а то меня на дрп банили по варнингам за спек собейтовский
 

CaJlaT

Овощ
Модератор
2,808
2,619
У меня проблема я написал небольшую функцию но когда я её запускаю с помощью команды у меня выводиться только 1 строка
Ошибка в кансоли:
[ML] (error) : C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:75: attempt to yield across C-call boundary
stack traceback:
[C]: in function 'wait'
C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:75: in function <C:\Users\à\Desktop\ñàìï\SAMP\moonloader\adminhelper.lua:70>
[ML] (error) : Script died due to an error. (45ED1E04)
КОД:
Lua:
function cmd_hobzvon(arg)
    if arg == nil or arg == "" then
        sampAddChatMessage("Укажите на какую лидурку будет идти обзвон!", main_color)
    else
        sampSendChat("[Leaders] Уважаемые игроки!")
        wait(1500)
        sampSendChat("[Leaders] В данный момент проходит обзвон на лидерку " .. arg)
        wait(1500)
        sampSendChat("[Leaders] Критерии: Дискорд(рабочий микрофон), Знания правил, Адекватность!")
        wait(1500)
        sampSendChat("[Leaders] Жилающии писать 777 мне в /sms или в репорт!")
        wait(1500)
    end
end
Lua:
function cmd_hobzvon(arg)
    if arg == nil or arg == "" then
        sampAddChatMessage("Укажите на какую лидурку будет идти обзвон!", main_color)
    else
        lua_thread.create(function()
            sampSendChat("[Leaders] Уважаемые игроки!")
            wait(1500)
            sampSendChat("[Leaders] В данный момент проходит обзвон на лидерку " .. arg)
            wait(1500)
            sampSendChat("[Leaders] Критерии: Дискорд(рабочий микрофон), Знания правил, Адекватность!")
            wait(1500)
            sampSendChat("[Leaders] Жилающии писать 777 мне в /sms или в репорт!")
            wait(1500)
        end)
    end
end
Можно ли как-то получить ширину в imvec2 imgui текста? Имеется сам текст и размер шрифта.
Lua:
imgui.CalcTextSize(u8"Твой текст").x
хелп я почти полный 0 в lua как сделать пойск по словам в imgui text
Например как тут(кликабельно) разбить каждую строку на отдельный imgui.Text, потом если переменная поиска не пустая выводить только строки, содержащие символы из переменной поиска
 
Последнее редактирование:
  • Нравится
Реакции: SashaKilin

Мира

Участник
455
9
Возможно сделать считывание ID в "/members" и чьи ID отсутствуют в зоне прорисовки - тем прописывается команда "/fwarn ID TEXT"?
 

paulohardy

вы еще постите говно? тогда я иду к вам
Всефорумный модератор
1,892
1,256
На вики поищи в следеющий раз)
класс, как создание 3д текста связано с его поиском?
Как искать 3d текст?
Lua:
for v = 1, 2048 do
 if sampIs3dTextDefined(v) then
  --тут получай все что нужно с помощью sampGet3dTextInfoById
 end
end
 

Zan1ks

Активный
203
91
класс, как создание 3д текста связано с его поиском?

Lua:
for v = 1, 2048 do
if sampIs3dTextDefined(v) then
  --тут получай все что нужно с помощью sampGet3dTextInfoById
end
end

Ну хоть один понял.Вот теперь вопрос в другом,как искать 3d text по тексту в нем
 

paulohardy

вы еще постите говно? тогда я иду к вам
Всефорумный модератор
1,892
1,256
Ну хоть один понял.Вот теперь вопрос в другом,как искать 3d text по тексту в нем
я скинул перебор по айди, дальше получай инфу о 3дтексте с помощью функции, она возвращает и текст 3дтекста, ставь нужные условия и делай
 
  • Нравится
Реакции: Zan1ks

CaJlaT

Овощ
Модератор
2,808
2,619
Ну хоть один понял.Вот теперь вопрос в другом,как искать 3d text по тексту в нем
Lua:
local samp = require "samp.events"
function samp.onCreate3DText(id, color, position, distance, testLOS, attachedPlayerId, attachedVehicleId, text)
    --code
end
класс, как создание 3д текста связано с его поиском?
удалил сообщение, не правильно прочёл
 

enyag

Известный
345
12
что не так в коде?
Lua:
script_name('aak')
script_author('enyag')

require "lib.moonloader" -- подключение библиотеки
local dlstatus = require('moonloader').download_status
local inicfg = require 'inicfg'

update_state = false

local script_vers = 1
local script_vers_text = "1.00"

local update_url = "https://raw.githubusercontent.com/enyagboss/sektapearsprojectrp/master/update.ini" -- тут тоже свою ссылку
local update_path = getWorkingDirectory() .. "/update.ini" -- и тут свою ссылку

local script_url = "https://github.com/enyagboss/sektapearsprojectrp/blob/master/aak.luac?raw=true" -- тут свою ссылку
local script_path = thisScript().path

tik = "Включить замену никнеймов\nЧёрный экран\nВключить только РП чат\nПозывный и состав."

function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end
  
    sampRegisterChatCommand("aak", cmd_aak)

    _, id = sampGetPlayerIdByCharHandle(PLAYER_PED)
    nick = sampGetPlayerNickname(id)

    downloadUrlToFile(update_url, update_path, function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then
            updateIni = inicfg.load(nil, update_path)
            if tonumber(updateIni.info.vers) > script_vers then
                sampAddChatMessage("Есть обновление! Версия: " .. updateIni.info.vers_text, -1)
                update_state = true
            end
            os.remove(update_path)
        end
    end)
  
    while true do
        wait(0)

        if update_state then
            downloadUrlToFile(script_url, script_path, function(id, status)
                if status == dlstatus.STATUS_ENDDOWNLOADDATA then
                    sampAddChatMessage("Скрипт успешно обновлен!", -1)
                    thisScript():reload()
                end
            end)
            break
        end

    end
end

function cmd_aak(arg)
    sampShowDialog(55555, "Скрипт для ААК by Enyag", tik, "Выбрать", "Закрыть", 2)
end
, вот вторая версия скрипта(она тестовая)


Lua:
script_name('aak')
script_author('enyag')

require "lib.moonloader" -- подключение библиотеки
local dlstatus = require('moonloader').download_status
local inicfg = require 'inicfg'

update_state = false

local script_vers = 1
local script_vers_text = "1.00"

local update_url = "https://raw.githubusercontent.com/enyagboss/sektapearsprojectrp/master/update.ini" -- тут тоже свою ссылку
local update_path = getWorkingDirectory() .. "/update.ini" -- и тут свою ссылку

local script_url = "https://github.com/enyagboss/sektapearsprojectrp/blob/master/aak.luac?raw=true" -- тут свою ссылку
local script_path = thisScript().path

tik = "Включить замену никнеймов\nЧёрный экран\nВключить только РП чат\nПозывный и состав."

function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end
   
    sampRegisterChatCommand("aak", cmd_aak)

    _, id = sampGetPlayerIdByCharHandle(PLAYER_PED)
    nick = sampGetPlayerNickname(id)

    downloadUrlToFile(update_url, update_path, function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then
            updateIni = inicfg.load(nil, update_path)
            if tonumber(updateIni.info.vers) > script_vers then
                sampAddChatMessage("Есть обновление! Версия: " .. updateIni.info.vers_text, -1)
                update_state = true
            end
            os.remove(update_path)
        end
    end)
   
    while true do
        wait(0)

        if update_state then
            downloadUrlToFile(script_url, script_path, function(id, status)
                if status == dlstatus.STATUS_ENDDOWNLOADDATA then
                    sampAddChatMessage("Скрипт успешно обновлен!", -1)
                    thisScript():reload()
                end
            end)
            break
        end

    end
end

function cmd_aak(arg)
    sampShowDialog(55555, "Скрипт для ААК by Enyag and Morris", tik, "Выбрать", "Закрыть", 2)
end
 
Последнее редактирование:

CLYDE

Известный
87
8
У меня вопрос, почему сервер пишет что команды не существует, команда не серверная, а с другого скрипта, то есть он должен вводить её и нажимать F после этого, что не так, помогите
Lua:
function nano(param)
lua_thread.create(function()
if param then
sampSendChat('/lp Раздевалка')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Исследование наноботов')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Работа с наноботами')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Склад электроники')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Конвеер')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Робот')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Повернуть')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Результат')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Сложить')
setVirtualKeyDown(VK_F, true)
else
end
end)
end
 

Izvinisb

Известный
Проверенный
964
598
У меня вопрос, почему сервер пишет что команды не существует, команда не серверная, а с другого скрипта, то есть он должен вводить её и нажимать F после этого, что не так, помогите
Lua:
function nano(param)
lua_thread.create(function()
if param then
sampSendChat('/lp Раздевалка')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Исследование наноботов')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Работа с наноботами')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Склад электроники')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Конвеер')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Робот')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Повернуть')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Результат')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Сложить')
setVirtualKeyDown(VK_F, true)
else
end
end)
end
 

enyag

Известный
345
12
У меня вопрос, почему сервер пишет что команды не существует, команда не серверная, а с другого скрипта, то есть он должен вводить её и нажимать F после этого, что не так, помогите
Lua:
function nano(param)
lua_thread.create(function()
if param then
sampSendChat('/lp Раздевалка')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Исследование наноботов')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Работа с наноботами')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Склад электроники')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Конвеер')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Робот')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Повернуть')
setVirtualKeyDown(VK_F, true)
wait(1500)
sampSendChat('/lp Результат')
setVirtualKeyDown(VK_F, true)
wait(1000)
sampSendChat('/lp Сложить')
setVirtualKeyDown(VK_F, true)
else
end
end)
end
если это команда другого скрипта, то просто sampSendChat() замени на sampProcessChatInput()
что не так в коде?
Lua:
script_name('aak')
script_author('enyag')

require "lib.moonloader" -- подключение библиотеки
local dlstatus = require('moonloader').download_status
local inicfg = require 'inicfg'

update_state = false

local script_vers = 1
local script_vers_text = "1.00"

local update_url = "https://raw.githubusercontent.com/enyagboss/sektapearsprojectrp/master/update.ini" -- тут тоже свою ссылку
local update_path = getWorkingDirectory() .. "/update.ini" -- и тут свою ссылку

local script_url = "https://github.com/enyagboss/sektapearsprojectrp/blob/master/aak.luac?raw=true" -- тут свою ссылку
local script_path = thisScript().path

tik = "Включить замену никнеймов\nЧёрный экран\nВключить только РП чат\nПозывный и состав."

function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end
  
    sampRegisterChatCommand("aak", cmd_aak)

    _, id = sampGetPlayerIdByCharHandle(PLAYER_PED)
    nick = sampGetPlayerNickname(id)

    downloadUrlToFile(update_url, update_path, function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then
            updateIni = inicfg.load(nil, update_path)
            if tonumber(updateIni.info.vers) > script_vers then
                sampAddChatMessage("Есть обновление! Версия: " .. updateIni.info.vers_text, -1)
                update_state = true
            end
            os.remove(update_path)
        end
    end)
  
    while true do
        wait(0)

        if update_state then
            downloadUrlToFile(script_url, script_path, function(id, status)
                if status == dlstatus.STATUS_ENDDOWNLOADDATA then
                    sampAddChatMessage("Скрипт успешно обновлен!", -1)
                    thisScript():reload()
                end
            end)
            break
        end

    end
end

function cmd_aak(arg)
    sampShowDialog(55555, "Скрипт для ААК by Enyag", tik, "Выбрать", "Закрыть", 2)
end
, вот вторая версия скрипта(она тестовая)


Lua:
script_name('aak')
script_author('enyag')

require "lib.moonloader" -- подключение библиотеки
local dlstatus = require('moonloader').download_status
local inicfg = require 'inicfg'

update_state = false

local script_vers = 1
local script_vers_text = "1.00"

local update_url = "https://raw.githubusercontent.com/enyagboss/sektapearsprojectrp/master/update.ini" -- тут тоже свою ссылку
local update_path = getWorkingDirectory() .. "/update.ini" -- и тут свою ссылку

local script_url = "https://github.com/enyagboss/sektapearsprojectrp/blob/master/aak.luac?raw=true" -- тут свою ссылку
local script_path = thisScript().path

tik = "Включить замену никнеймов\nЧёрный экран\nВключить только РП чат\nПозывный и состав."

function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end
   
    sampRegisterChatCommand("aak", cmd_aak)

    _, id = sampGetPlayerIdByCharHandle(PLAYER_PED)
    nick = sampGetPlayerNickname(id)

    downloadUrlToFile(update_url, update_path, function(id, status)
        if status == dlstatus.STATUS_ENDDOWNLOADDATA then
            updateIni = inicfg.load(nil, update_path)
            if tonumber(updateIni.info.vers) > script_vers then
                sampAddChatMessage("Есть обновление! Версия: " .. updateIni.info.vers_text, -1)
                update_state = true
            end
            os.remove(update_path)
        end
    end)
   
    while true do
        wait(0)

        if update_state then
            downloadUrlToFile(script_url, script_path, function(id, status)
                if status == dlstatus.STATUS_ENDDOWNLOADDATA then
                    sampAddChatMessage("Скрипт успешно обновлен!", -1)
                    thisScript():reload()
                end
            end)
            break
        end

    end
end

function cmd_aak(arg)
    sampShowDialog(55555, "Скрипт для ААК by Enyag and Morris", tik, "Выбрать", "Закрыть", 2)
end
Ребята, моё обращение актуально.
 
  • Нравится
Реакции: CLYDE

CaJlaT

Овощ
Модератор
2,808
2,619
пишу скрипт авто закуп аптек для фамы
код:
Lua:
local sampev = require 'lib.samp.events'
require "lib.moonloader"

function main()
  if not isSampfuncsLoaded() or not isSampLoaded() then return end
  while not isSampAvailable() do wait(100) end
        sampAddChatMessage("{FF5656}Дарова ебать", -1)
  while true do
  wait(0)
   
    if isKeyJustPressed(VK_X) and not isSampfuncsConsoleActive() and not sampIsDialogActive() and not sampIsChatInputActive()  then
        setVirtualKeyDown(18, true)
        wait(20)
        setVirtualKeyDown(18, false)
end

function sampev.onShowDialog(dialogId, style, title, button1, button2, text)
   
    if dialogId == 239 then
        sampSendDialogResponse(239, 1, 5)
        return false
    end
    if dialogId == 623 then
        sampSendDialogResponse(623, 1, _, 1)
        return false
    end
end
end
end
это закуп с магазина, как сделать sampSendChat после закупа?
1. не верно вставил функцию
2. Нужен поток и минимальная задержка
Lua:
local sampev = require 'lib.samp.events'
require "lib.moonloader"

function main()
    if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
    sampAddChatMessage("{FF5656}Дарова ебать", -1)
    while true do
        wait(0)
        if isKeyJustPressed(VK_X) and not isSampfuncsConsoleActive() and not sampIsDialogActive() and not sampIsChatInputActive()  then
            setVirtualKeyDown(18, true)
            wait(20)
            setVirtualKeyDown(18, false)
        end
    end
end
function sampev.onShowDialog(dialogId, style, title, button1, button2, text)
    if dialogId == 239 then
        lua_thread.create(function()
            sampSendDialogResponse(239, 1, 5)
            wait(0)
            sampSendChat('gg')
        end)
        return false
    end
    if dialogId == 623 then
        lua_thread.create(function()
            sampSendDialogResponse(623, 1, _, 1)
            wait(0)
            sampSendChat('gg')
        end)
        return false
    end
end
 
  • Нравится
Реакции: Temate