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

UBP

Известный
349
191
как совместить это
Lua:
imgui.Text(u8'Сказать "Привет" на ')
imgui.SameLine()
if imgui.HotKey("##img.HOTKEYS.privet", img.HOTKEYS.privet) then
    rkeys.changeHotKey(ID_PRIVET, img.HOTKEYS.privet.v)
    ini.HOTKEYS.privet = encodeJson(img.HOTKEYS.privet.v)
    inicfg.save(ini, filename_ini)
end
imgui.SameLine()
if imgui.ToggleButton(u8'##1', privet) then end
чтобы получилось это Посмотреть вложение 165376 ? или на много лучше чем это


ну это в пример такая хуйня, я хочу активацию на сокр команду, к примеру /usedrugs, сделать, и там нужен аргумент обязательно. тип если написал /us 6, то /usedrugs 6, можно по отдельности писать testCheat('us 1') testCheat('us 2') и тд., но я думаю что есть способы проще
Lua:
sampRegisterChatCommand("us", function(text) if Enable.v then sampSendChat("/usedrugs "..text) end end)
 

LazyK

Участник
41
47
Как можно имитировать краш игры? Если вдруг админ тепнет то что бы в логах было что именно крашнуло
 

LazyK

Участник
41
47
как обозначить длину imgui.InputText?
возможно то что вам нужно
 
  • Нравится
Реакции: XRLM

XRLM

Против ветра рождённый
Проверенный
1,507
1,069
возможно то что вам нужно
да, спасибо
 
  • Нравится
Реакции: LazyK

deveeh

Новичок
25
6
Короче проблема, если активен один чекбокс, то не могут работать в других чекбоксах подчекбоксики, подробнее в видео

вот код:
imgui.Begin('PR Manager | by deveeh', window, imgui.WindowFlags.NoResize)
            imgui.Checkbox(u8'Сообщения для VIP Чата (/vr)', settings.vr)
            if settings.vr.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSG', settings.vrmsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.vr2)
                if settings.vr2.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSG2', settings.vrmsg2)
                end
            end
            imgui.Checkbox(u8'Сообщения для FAMILY чата (/fam, /al)', settings.fam)
            if settings.fam.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSGFAM', settings.fammsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.al)
                if settings.al.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSGAL', settings.almsg)
                end
            end
            imgui.Checkbox(u8'Сообщения для объявлений (/ad)', settings.ad)
            if settings.ad.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSGAD', settings.admsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.ad2)
                if settings.ad2.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSGAD2', settings.admsg2)
                end
            end
            imgui.Text(u8'Задержка:')
            imgui.SameLine()
            imgui.PushItemWidth(83)
            imgui.InputInt('##delay', settings.delay)
            imgui.PopItemWidth()
            if imgui.IsItemHovered() then
                imgui.BeginTooltip()
                    imgui.Text(u8'Задержка между отправлением сообщений (секунды)')
                imgui.EndTooltip()
            end
        imgui.End()
 

Gorskin

♥ Love Lua ♥
Проверенный
1,331
1,161
Короче проблема, если активен один чекбокс, то не могут работать в других чекбоксах подчекбоксики, подробнее в видео

вот код:
imgui.Begin('PR Manager | by deveeh', window, imgui.WindowFlags.NoResize)
            imgui.Checkbox(u8'Сообщения для VIP Чата (/vr)', settings.vr)
            if settings.vr.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSG', settings.vrmsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.vr2)
                if settings.vr2.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSG2', settings.vrmsg2)
                end
            end
            imgui.Checkbox(u8'Сообщения для FAMILY чата (/fam, /al)', settings.fam)
            if settings.fam.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSGFAM', settings.fammsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.al)
                if settings.al.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSGAL', settings.almsg)
                end
            end
            imgui.Checkbox(u8'Сообщения для объявлений (/ad)', settings.ad)
            if settings.ad.v then
                imgui.Text(u8'    Сообщение:')
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.InputText('##MSGAD', settings.admsg)
                imgui.Text(u8'    ')
                imgui.SameLine()
                imgui.Checkbox(u8'Второе сообщение', settings.ad2)
                if settings.ad2.v then
                    imgui.Text(u8'        Сообщение:')
                    imgui.Text(u8'        ')
                    imgui.SameLine()
                    imgui.InputText('##MSGAD2', settings.admsg2)
                end
            end
            imgui.Text(u8'Задержка:')
            imgui.SameLine()
            imgui.PushItemWidth(83)
            imgui.InputInt('##delay', settings.delay)
            imgui.PopItemWidth()
            if imgui.IsItemHovered() then
                imgui.BeginTooltip()
                    imgui.Text(u8'Задержка между отправлением сообщений (секунды)')
                imgui.EndTooltip()
            end
        imgui.End()
У тебя чекбоксы с словом "Второе сообщение" имеют одинаковые названия, называй каждый такой чекбокс добавляя ##1, ##2 и т.д в меню не будет видно ## и всё что идёт за ними.
Пример:
Lua:
imgui.Checkbox(u8'Второе сообщение##1', settings.vr2)
imgui.Checkbox(u8'Второе сообщение##2', settings.vr2)
 

deveeh

Новичок
25
6
У тебя чекбоксы с словом "Второе сообщение" имеют одинаковые названия, называй каждый такой чекбокс добавляя ##1, ##2 и т.д в меню не будет видно ## и всё что идёт за ними.
Пример:
Lua:
imgui.Checkbox(u8'Второе сообщение##1', settings.vr2)
imgui.Checkbox(u8'Второе сообщение##2', settings.vr2)
понял, не заметил, спасибо
 
Последнее редактирование:

NoName_001

Участник
152
21

из-за чего ошибка и как фиксить?
Код:
[ML] (error) Imgui Addons Hotkey: ... gta\REBUILT BLIN GTA\moonloader\imgui_lesson_18 (1).lua:18: attempt to index local 'mainIni' (a nil value)
stack traceback:
    ... gta\REBUILT BLIN GTA\moonloader\imgui_lesson_18 (1).lua:18: in main chunk
[ML] (error) Imgui Addons Hotkey: Script died due to an error. (186ABFF4)
скорее всего обращаешься к переменной, которой нет(проверяй рЕгИсТрЫ)
можешь еще приложить файл/код, исправим твою ошибку
 

liptonxgod

Активный
367
89
Пожалуйста мог бы ктото сделать или скинуть сюда заготовку чтобы ракбот тепался на определенные корды и жал там бесконечно альт
 
  • Bug
  • Эм
Реакции: Gorskin и NoName_001

UBP

Известный
349
191
Как направить вектор скорости в сторону в которую смотрит пед?
data.movespeed

взял скрипт формуса с его группы с 18 урока, чтобы на его примере уже писать свое
код:
Lua:
script_name('Imgui Addons Hotkey') -- название скрипта
script_author('FORMYS') -- автор скрипта
script_description('Imgui Addons Hotkey Review') -- описание скрипта

require "lib.moonloader" -- подключение библиотеки
local keys = require "vkeys"
local imgui = require 'imgui'
local inicfg = require 'inicfg'
local encoding = require 'encoding'
encoding.default = 'CP1251'
u8 = encoding.UTF8

local themes = import "resource/imgui_themes.lua"
local directIni = "moonloader\\settings.ini"

local mainIni = inicfg.load(nil, directIni)

if mainIni.hotkey == nil then -- если отсутствует секция hotkey в ини файле
    mainIni.hotkey = {
        bindClock = "[18,82]", -- alt + r
        bindPass = "[18,83]" -- alt + s
    }
end

local rkeys = require 'rkeys'
imgui.HotKey = require('imgui_addons').HotKey

local tLastKeys = {} -- тут будут храниться предыдущие хоткеи при переактивации

local ActiveClockMenu = {
    v = decodeJson(mainIni.hotkey.bindClock)
}

local ActivePassMenu = {
    v = decodeJson(mainIni.hotkey.bindPass)
}

main_window_state = imgui.ImBool(false)

function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end

    sampRegisterChatCommand("hotkey", cmd_hotkey)

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

    imgui.Process = false

    imgui.SwitchContext()
    themes.SwitchColorTheme()

    bindClock = rkeys.registerHotKey(ActiveClockMenu.v, true, clockFunc) -- создаем объект хоткея и регистрируем коллбэк функцию
    bindPass = rkeys.registerHotKey(ActivePassMenu.v, true, passFunc)

    while true do
        wait(0)

        -- Блок выполняющийся бесконечно (пока самп активен)

    end
end

function cmd_hotkey(arg)
    main_window_state.v = not main_window_state.v
    imgui.Process = main_window_state.v
end

function clockFunc()
    sampSendChat("/c 60")
end

function passFunc()
    sampSendChat("/pass " .. id)
end

function imgui.OnDrawFrame()

    if not main_window_state.v then
        imgui.Process = false
    end

    if main_window_state.v then
        local sw, sh = getScreenResolution()

        imgui.SetNextWindowPos(imgui.ImVec2(sw / 2, sh / 2), imgui.Cond.FirstUseEver, imgui.ImVec2(0.5, 0.5))
        imgui.SetNextWindowSize(imgui.ImVec2(300, 200), imgui.Cond.FirstUseEver)

        imgui.Begin('Imgui Hotkey Review', main_window_state, imgui.WindowFlags.NoCollapse)

        imgui.Text(u8"Посмотреть время")
        imgui.SameLine()
        if imgui.HotKey("##1", ActiveClockMenu, tLastKeys, 100) then
            rkeys.changeHotKey(bindClock, ActiveClockMenu.v)
            sampAddChatMessage("Успешно! Старое значение: {F4A460}" .. table.concat(rkeys.getKeysName(tLastKeys.v), " + ") .. "{ffffff} | Новое: {F4A460}" .. table.concat(rkeys.getKeysName(ActiveClockMenu.v), " + "), -1)
            sampAddChatMessage("Строчное значение: {F4A460}" .. encodeJson(ActiveClockMenu.v), -1)

            mainIni.hotkey.bindClock = encodeJson(ActiveClockMenu.v)
            inicfg.save(mainIni, directIni)
        end

        imgui.Text(u8"Посмотреть паспорт")
        imgui.SameLine()
        if imgui.HotKey("##2", ActivePassMenu, tLastKeys, 100) then
            rkeys.changeHotKey(bindPass, ActivePassMenu.v)
            sampAddChatMessage("Успешно! Старое значение: {F4A460}" .. table.concat(rkeys.getKeysName(tLastKeys.v), " + ") .. "{ffffff} | Новое: {F4A460}" .. table.concat(rkeys.getKeysName(ActivePassMenu.v), " + "), -1)
            sampAddChatMessage("Строчное значение: {F4A460}" .. encodeJson(ActivePassMenu.v), -1)

            mainIni.hotkey.bindPass = encodeJson(ActivePassMenu.v)
            inicfg.save(mainIni, directIni)
        end

        imgui.End()
    end
end[/CODE=lua]
попробуй удалить ини файл, и создать сзаного пустой
 
Последнее редактирование:

UBP

Известный
349
191
Как направить вектор скорости в сторону в которую смотрит пед?
data.movespeed
Актуально
 

melody.

Участник
36
3
Вылезает ошибка в moonloader.log
pokemon fist gta\moonloader\casinoYesNo.lua:7: attempt to call global 'require' (a string value)
stack traceback:
random:
script_name("CasinoHelper")
script_author('melody')
script_description('CH Loaded')

require = 'lib.moonloader'
local tag = '[CHelper]: '
local keys = require 'vkeys'
local inicfg = require 'inicfg'
local imgui = require 'imgui'
local sampev = require 'lib.samp.events'

local str_rand = {tag .. 'Играй', 'Не играй', 'Подумай сам', 'Думаю стоит перезайти'}


function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end

    sampRegisterChatCommand('chelp', test_chelp)

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

  sampAddChatMesssage(tag ..'Helper Loaded.', 0x00FFFF)

    while true do
        wait(0)

        if isKeyJustPressed(VK_F3) then
            sampAddChatMessage(tag ..'F3 Pressed', 0x00FFFF)
        end


    end
end

function test_help(arg)
    math.randomseed(os.time())
    rand = math.random(1, #str_rand)
    sampAddChatMessage(str_rand[1], 0x00FFFF)
end
 

UBP

Известный
349
191
Вылезает ошибка в moonloader.log
pokemon fist gta\moonloader\casinoYesNo.lua:7: attempt to call global 'require' (a string value)
stack traceback:
random:
script_name("CasinoHelper")
script_author('melody')
script_description('CH Loaded')

require = 'lib.moonloader'
local tag = '[CHelper]: '
local keys = require 'vkeys'
local inicfg = require 'inicfg'
local imgui = require 'imgui'
local sampev = require 'lib.samp.events'

local str_rand = {tag .. 'Играй', 'Не играй', 'Подумай сам', 'Думаю стоит перезайти'}


function main()
    if not isSampLoaded() or not isSampfuncsLoaded() then return end
    while not isSampAvailable() do wait(100) end

    sampRegisterChatCommand('chelp', test_chelp)

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

  sampAddChatMesssage(tag ..'Helper Loaded.', 0x00FFFF)

    while true do
        wait(0)

        if isKeyJustPressed(VK_F3) then
            sampAddChatMessage(tag ..'F3 Pressed', 0x00FFFF)
        end


    end
end

function test_help(arg)
    math.randomseed(os.time())
    rand = math.random(1, #str_rand)
    sampAddChatMessage(str_rand[1], 0x00FFFF)
end
local keys = require 'vkeys'
local inicfg = require 'inicfg'
local imgui = require 'imgui'
local sampev = require 'lib.samp.events'
Установи эти либы