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

moreveal

Известный
Проверенный
927
622
Lua:
local events = require "events"

function events.onServerMessage(color, text)
    if text:find("{66CC00}* {FFFFFF}Номер игрока {66CC00}.+%[%d+%]{FFFFFF}: {66CC00}%d+") then
        local playerNumber = text:match("{66CC00}* {FFFFFF}Номер игрока {66CC00}.+%[%d+%]{FFFFFF}: {66CC00}(%d+)")
        sampAddChatMessage("Полученный номер: " .. playerNumber)
    end
end

Как-то так, не проверял работает ли, проверь, если что напиши
можн не дублировать паттерн

Lua:
function events.onServerMessage(color, text)
    local playerNumber = text:match("{66CC00}* {FFFFFF}Номер игрока {66CC00}.+%[%d+%]{FFFFFF}: {66CC00}(%d+)")
    if playerNumber then sampAddChatMessage("Полученный номер: " .. playerNumber, -1) end
end
 
  • Нравится
Реакции: XRLM

Gorskin

{FFDEAD}
Проверенный
1,346
1,195
Есть массив:
Lua:
local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = ini.commands.openmenu},
}
В меню у меня так:
Lua:
for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        v.cfg = str(v.var)
        save()
    end
end
Вопрос почему значение конфига ini.commands.openmenu не сохраняется? По логике я сохраняю команду но она не меняется. Меняется только значение v.cfg но не ini.commands.openmenu
Что делать в такой ситуации?
 

kizn

q(≧▽≦q)
Всефорумный модератор
2,409
2,104
Есть массив:
Lua:
local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = ini.commands.openmenu},
}
В меню у меня так:
Lua:
for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        v.cfg = str(v.var)
        save()
    end
end
Вопрос почему значение конфига ini.commands.openmenu не сохраняется? По логике я сохраняю команду но она не меняется. Меняется только значение v.cfg но не ini.commands.openmenu
Что делать в такой ситуации?
Lua копирует ini.commands.openmenu в переменную cfg в объекте и уже после в твоем коде значение меняется непосредственно в новом объекте

Предлагаю следующее решение (если хуйня то можете предложить лучше) - храни строчку "ini.commands.openmenu" (
{var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"}
) и потом изменяй так: _G[v.cfg] = str(v.var)
 

chapo

чопа сребдс // @moujeek
Модератор
8,983
11,796
Есть массив:
Lua:
local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = ini.commands.openmenu},
}
В меню у меня так:
Lua:
for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        v.cfg = str(v.var)
        save()
    end
end
Вопрос почему значение конфига ini.commands.openmenu не сохраняется? По логике я сохраняю команду но она не меняется. Меняется только значение v.cfg но не ini.commands.openmenu
Что делать в такой ситуации?
imguiInputs[k].cfg = str(v.var)
 
  • Эм
Реакции: kizn

Gorskin

{FFDEAD}
Проверенный
1,346
1,195
Lua копирует ini.commands.openmenu в переменную cfg в объекте и уже после в твоем коде значение меняется непосредственно в новом объекте

Предлагаю следующее решение (если хуйня то можете предложить лучше) - храни строчку "ini.commands.openmenu" (
{var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"}
) и потом изменяй так: _G[v.cfg] = str(v.var)
imguiInputs[k].cfg = str(v.var)
Не помогло ничего из выше перечисленного
 

chapo

чопа сребдс // @moujeek
Модератор
8,983
11,796
Не помогло ничего из выше перечисленного
странно, все должно работать

1660157809524.png
 
  • Эм
Реакции: kizn

kizn

q(≧▽≦q)
Всефорумный модератор
2,409
2,104
Не помогло ничего из выше перечисленного
выяснил в чем дело

итак, для начала убери local у определения переменной cfg, чтобы иметь доступ к объекту через _G
затем изменяй переменную вот так:

Lua:
local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"},
}

-- изменение переменной в конфиге: (честно говоря, load выглядит не очень красиво, но к строке вида cfg.main.poop через _G можно добраться только так: _G["cfg"]["main"]["poop"] что имхо еще хуже)
load(v.cfg.."="..str(v.var))()
 

Gorskin

{FFDEAD}
Проверенный
1,346
1,195
выяснил в чем дело

итак, для начала убери local у определения переменной cfg, чтобы иметь доступ к объекту через _G
затем изменяй переменную вот так:

Lua:
local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"},
}

-- изменение переменной в конфиге: (честно говоря, load выглядит не очень красиво, но к строке вида cfg.main.poop через _G можно добраться только так: _G["cfg"]["main"]["poop"] что имхо еще хуже)
load(v.cfg.."="..str(v.var))()
Тоже не пашет
 

Gorskin

{FFDEAD}
Проверенный
1,346
1,195
ну покажи как делаешь
Lua:
local ini = inicfg.load(inicfg.load({
    commands = {
        openmenu = "/gmenu",
    },
}, directIni))
inicfg.save(ini, directIni)

local buffers = {
    cmd_openmenu = new.char[32](ini.commands.openmenu),
}

local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"},
}

for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        _G[v.cfg] = str(v.var)
        load(v.cfg.."="..str(v.var))
        save()
    end
end

--было так:
for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        v.cfg = str(v.var)
        save()
    end
end
 

kizn

q(≧▽≦q)
Всефорумный модератор
2,409
2,104
Lua:
local ini = inicfg.load(inicfg.load({
    commands = {
        openmenu = "/gmenu",
    },
}, directIni))
inicfg.save(ini, directIni)

local buffers = {
    cmd_openmenu = new.char[32](ini.commands.openmenu),
}

local imguiInputs = {
    [u8"Открыть меню скрипта"] = {var = buffers.cmd_openmenu, cfg = "ini.commands.openmenu"},
}

for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        _G[v.cfg] = str(v.var)
        load(v.cfg.."="..str(v.var))
        save()
    end
end

--было так:
for k, v in pairs(imguiInputs) do
    if imgui.InputText(k, v.var, sizeof(v.var)) then
        v.cfg = str(v.var)
        save()
    end
end
бля, я cfg написал кек

вместо local ini напиши просто ini
и эту строчку: _G[v.cfg] = str(v.var) удали

и почему у тебя конфиг грузится в загрузке конфига? че это такое
 

Gorskin

{FFDEAD}
Проверенный
1,346
1,195
бля, я cfg написал кек

вместо local ini напиши просто ini
и эту строчку: _G[v.cfg] = str(v.var) удали

и почему у тебя конфиг грузится в загрузке конфига? че это такое
Увы я уже и cfg = "ini.commands.openmenu" менял на cfg = ini.commands.openmenu
И _G[v.cfg] = str(v.var) удалял и
load(v.cfg.."="..str(v.var)) оставлял и наоборот и у переменной ini убирал local. Но ничего не помогает!
Работает только так:
ini.commands.openmenu = str(buffers.cmd_openmenu)
 

kizn

q(≧▽≦q)
Всефорумный модератор
2,409
2,104
Увы я уже и cfg = "ini.commands.openmenu" менял на cfg = ini.commands.openmenu
И _G[v.cfg] = str(v.var) удалял и
load(v.cfg.."="..str(v.var)) оставлял и наоборот и у переменной ini убирал local. Но ничего не помогает!
Работает только так:
ini.commands.openmenu = str(buffers.cmd_openmenu)
скинь скрипт в лс
 

shawtyglock.

Активный
188
63
Вообщем, написал мини-хелпер, после того, как я перешёл с .json на .ini возникла проблема, что изменения, внесённые пользователем (смена клавиш бинда, смена команды для активации скрипта) вступают в силу только после перезагрузки скрипта (Ctrl + R), а мне нужно, что бы они вступали в силу сразу после внесения самих изменений. Например, ставлю бинд: использование наркотиков на X, нажимаю X - ничего не происходит. Перезагружаю скрипт, нажимаю X и всё работает. Предоставляю вам мой говнокод:
Lua:
script_name('Shawty Helper')
script_author('shawtyglock')

require "lib.moonloader"
local imgui = require 'imgui'
local inicfg = require 'inicfg'
local sampev = require 'lib.samp.events'
local hook = require 'lib.samp.events'
local encoding = require 'encoding'
encoding.default = 'CP1251'
u8 = encoding.UTF8
local main_window_state = imgui.ImBool(false)
local rkeys = require 'rkeys'
imgui.HotKey = require('imgui_addons').HotKey

local fa = require 'faIcons'
local fonts = renderCreateFont("Arial", 9, 5)

local themes = import "resource/imgui_themes.lua"

local directIni = 'Shawty Helper.ini'
local mainIni = inicfg.load(inicfg.load({
    config = {
            CommandAct = 'sh',
            SizeFont = 9,
            FlagFont = 5,
            famzone = false,
            fastrep = false,
            probiv = false
    },
        HotKey = {
            armour = encodeJson({nil}),
            mask = encodeJson({nil}),
            drugs = encodeJson({nil}),
            cure = encodeJson({nil}),
            lock = encodeJson({nil})
        }
}, directIni))

inicfg.save(mainIni, directIni)

local tLastKeys = {}

local ActiveArmour = {
    v = decodeJson(mainIni.HotKey.armour)
}

local ActiveMask = {
    v = decodeJson(mainIni.HotKey.mask)
}

local ActiveLock = {
    v = decodeJson(mainIni.HotKey.lock)
}

local ActiveDrugs = {
    v = decodeJson(mainIni.HotKey.drugs)
}

local ActiveCure = {
    v = decodeJson(mainIni.HotKey.cure)
}

local font = renderCreateFont("Arial", mainIni.config.SizeFont, mainIni.config.FlagFont)

--ImGui
-- local checkkill = imgui.ImBool(config.Kill)
-- local checkstats = imgui.ImBool(config.Stats)
-- local checkhphud = imgui.ImBool(config.HPHud)
-- local checkbell = imgui.ImBool(config.Bell)
local commandact = imgui.ImBuffer(mainIni.config.CommandAct,256)
local sizefont = imgui.ImInt(mainIni.config.SizeFont)
local flagfont = imgui.ImInt(mainIni.config.FlagFont)

-- Checkbox
-- local choose_Kill = imgui.ImBool(false)
-- local choose_Stats = imgui.ImBool(false)
-- local choose_HPHud = imgui.ImBool(false)
-- local choose_Bell = imgui.ImBool(false)

local famzone = imgui.ImBool(mainIni.config.famzone)
local fastrep = imgui.ImBool(mainIni.config.fastrep)
local probiv = imgui.ImBool(mainIni.config.probiv)

function CherryTheme()
  imgui.SwitchContext()
  local style = imgui.GetStyle()
  local colors = style.Colors
  local clr = imgui.Col
  local ImVec4 = imgui.ImVec4
  local ImVec2 = imgui.ImVec2


  style.WindowPadding = ImVec2(8, 8)
  style.WindowRounding = 6.0
  style.FramePadding = ImVec2(5, 3)
  style.FrameRounding = 3.0
    style.ItemSpacing = imgui.ImVec2(5, 4)
    style.ItemInnerSpacing = imgui.ImVec2(4, 4)
    style.IndentSpacing = 21
    style.ScrollbarSize = 10.0
    style.ScrollbarRounding = 13
    style.GrabMinSize = 8
    style.GrabRounding = 1
    style.WindowTitleAlign = imgui.ImVec2(0.5, 0.5)
    style.ButtonTextAlign = imgui.ImVec2(0.5, 0.5)

  style.WindowTitleAlign = ImVec2(0.5, 0.5)

  colors[clr.Text] = ImVec4(0.860, 0.930, 0.890, 0.78)
  colors[clr.TextDisabled] = ImVec4(0.860, 0.930, 0.890, 0.28)
  colors[clr.WindowBg] = ImVec4(0.13, 0.14, 0.17, 1.00)
  colors[clr.ChildWindowBg] = ImVec4(0.200, 0.220, 0.270, 0.58)
  colors[clr.PopupBg] = ImVec4(0.200, 0.220, 0.270, 0.9)
  colors[clr.Border] = ImVec4(0.31, 0.31, 1.00, 0.00)
  colors[clr.BorderShadow] = ImVec4(0.00, 0.00, 0.00, 0.00)
  colors[clr.FrameBg] = ImVec4(0.200, 0.220, 0.270, 1.00)
  colors[clr.FrameBgHovered] = ImVec4(0.455, 0.198, 0.301, 0.78)
  colors[clr.FrameBgActive] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.TitleBg] = ImVec4(0.232, 0.201, 0.271, 1.00)
  colors[clr.TitleBgActive] = ImVec4(0.502, 0.075, 0.256, 1.00)
  colors[clr.TitleBgCollapsed] = ImVec4(0.200, 0.220, 0.270, 0.75)
  colors[clr.MenuBarBg] = ImVec4(0.200, 0.220, 0.270, 0.47)
  colors[clr.ScrollbarBg] = ImVec4(0.200, 0.220, 0.270, 1.00)
  colors[clr.ScrollbarGrab] = ImVec4(0.09, 0.15, 0.1, 1.00)
  colors[clr.ScrollbarGrabHovered] = ImVec4(0.455, 0.198, 0.301, 0.78)
  colors[clr.ScrollbarGrabActive] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.CheckMark] = ImVec4(0.71, 0.22, 0.27, 1.00)
  colors[clr.SliderGrab] = ImVec4(0.47, 0.77, 0.83, 0.14)
  colors[clr.SliderGrabActive] = ImVec4(0.71, 0.22, 0.27, 1.00)
  colors[clr.Button] = ImVec4(0.47, 0.77, 0.83, 0.14)
  colors[clr.ButtonHovered] = ImVec4(0.455, 0.198, 0.301, 0.86)
  colors[clr.ButtonActive] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.Header] = ImVec4(0.455, 0.198, 0.301, 0.76)
  colors[clr.HeaderHovered] = ImVec4(0.455, 0.198, 0.301, 0.86)
  colors[clr.HeaderActive] = ImVec4(0.502, 0.075, 0.256, 1.00)
  colors[clr.ResizeGrip] = ImVec4(0.47, 0.77, 0.83, 0.04)
  colors[clr.ResizeGripHovered] = ImVec4(0.455, 0.198, 0.301, 0.78)
  colors[clr.ResizeGripActive] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.PlotLines] = ImVec4(0.860, 0.930, 0.890, 0.63)
  colors[clr.PlotLinesHovered] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.PlotHistogram] = ImVec4(0.860, 0.930, 0.890, 0.63)
  colors[clr.PlotHistogramHovered] = ImVec4(0.455, 0.198, 0.301, 1.00)
  colors[clr.TextSelectedBg] = ImVec4(0.455, 0.198, 0.301, 0.43)
  colors[clr.ModalWindowDarkening] = ImVec4(0.200, 0.220, 0.270, 0.73)
end
CherryTheme()

local menu = 1
local fa_font = nil
local sizefont = nil

-- KillStatus
-- local kills = 0
-- local deaths = 0
-- local ratio = 0
-- local dead_players = {}
-- local current = 0
-- local total = 0

function imgui.TextQuestion(text)
    imgui.SameLine()
    imgui.TextDisabled("(?)")
    if imgui.IsItemHovered() then
        imgui.BeginTooltip()
        imgui.TextUnformatted(u8(text))
        imgui.EndTooltip()
    end
end

function imgui.CenterTextColoredRGB(text)
    local width = imgui.GetWindowWidth()
    local style = imgui.GetStyle()
    local colors = style.Colors
    local ImVec4 = imgui.ImVec4

    local explode_argb = function(argb)
        local a = bit.band(bit.rshift(argb, 24), 0xFF)
        local r = bit.band(bit.rshift(argb, 16), 0xFF)
        local g = bit.band(bit.rshift(argb, 8), 0xFF)
        local b = bit.band(argb, 0xFF)
        return a, r, g, b
    end

    local getcolor = function(color)
        if color:sub(1, 6):upper() == 'SSSSSS' then
            local r, g, b = colors[1].x, colors[1].y, colors[1].z
            local a = tonumber(color:sub(7, 8), 16) or colors[1].w * 255
            return ImVec4(r, g, b, a / 255)
        end
        local color = type(color) == 'string' and tonumber(color, 16) or color
        if type(color) ~= 'number' then return end
        local r, g, b, a = explode_argb(color)
        return imgui.ImColor(r, g, b, a):GetVec4()
    end

    local render_text = function(text_)
        for w in text_:gmatch('[^\r\n]+') do
            local textsize = w:gsub('{.-}', '')
            local text_width = imgui.CalcTextSize(u8(textsize))
            imgui.SetCursorPosX( width / 2 - text_width .x / 2 )
            local text, colors_, m = {}, {}, 1
            w = w:gsub('{(......)}', '{%1FF}')
            while w:find('{........}') do
                local n, k = w:find('{........}')
                local color = getcolor(w:sub(n + 1, k - 1))
                if color then
                    text[#text], text[#text + 1] = w:sub(m, n - 1), w:sub(k + 1, #w)
                    colors_[#colors_ + 1] = color
                    m = n
                end
                w = w:sub(1, n - 1) .. w:sub(k + 1, #w)
            end
            if text[0] then
                for i = 0, #text do
                    imgui.TextColored(colors_[i] or colors[1], u8(text[i]))
                    imgui.SameLine(nil, 0)
                end
                imgui.NewLine()
            else
                imgui.Text(u8(w))
            end
        end
    end
    render_text(text)
end

function hook.onShowDialog(dialogId, dialogStyle, dialogTitle, okButtonText, cancelButtonText, dialogText)
    if fastrep.v then
        if dialogId == 32 then
            return false
        end
    end
end


function fastreport(text)
    if fastrep.v then
        if #text == 0 then
            sampAddChatMessage('{ff6347}[Shawty Helper]:{ffffff} Введите ваш репорт', 0xff6347)
        else
            sampSendChat('/rep')
            sampSendDialogResponse(32, 1, 0, text)
        end
    else
        sampSendChat('/rep')
    end
end

function findfamzone()
    if famzone.v then
        lua_thread.create(function()
            sampSendChat("/fammenu")
            wait(150)
            sampSendClickTextdraw(2077)
            wait(150)
            sampSendDialogResponse(15208, 1, 1, nil)
            wait(150)
            sampSendDialogResponse(15226, 1, 0, nil)
            wait(150)
            sampSendDialogResponse(15227, 1, 0, nil)
            wait(50)
            setVirtualKeyDown(27, true)
          end)
    end
end





function main()
    if not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
    sampAddChatMessage('{de3163}[Shawty Helper] {ffffff}Успешно загружен! Открыть меню:{de3163} /'..mainIni.config.CommandAct, -1)
    sampRegisterChatCommand("sh", function()
 main_window_state.v = not main_window_state.v end)
    sampRegisterChatCommand(mainIni.config.CommandAct, function()
 main_window_state.v = not main_window_state.v end)
 sampRegisterChatCommand('rep', fastreport)
 sampRegisterChatCommand('probiv', cmd_probiv)
 sampRegisterChatCommand('famzone', findfamzone)

        bind = rkeys.registerHotKey(ActiveArmour.v, true, function()
            if not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
                sampSendChat("/armour")
            end
    end)

        bind = rkeys.registerHotKey(ActiveMask.v, true, function()
            if not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
        sampSendChat("/mask")
            end
    end)

        bind = rkeys.registerHotKey(ActiveLock.v, true, function()
            if not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
        sampSendChat("/lock")
            end
    end)

        bind = rkeys.registerHotKey(ActiveDrugs.v, true, function()
            hp = getCharHealth(PLAYER_PED)
            if hp < 120 and not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
                    sampSendChat('/usedrugs 3')
            elseif hp >= 120 and hp < 140 and not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
                    sampSendChat('/usedrugs 2')
            elseif hp >= 140 and not sampIsChatInputActive() and not sampIsDialogActive() and not sampIsScoreboardOpen() and not isSampfuncsConsoleActive() then
                    sampSendChat('/usedrugs 1')
            end
    end)

        bind = rkeys.registerHotKey(ActiveCure.v, true, function()
            local veh, ped = storeClosestEntities(PLAYER_PED)
            local _, id = sampGetPlayerIdByCharHandle(ped)
            if id then
                            if id == -1 then sampAddChatMessage('{de3163}[Shawty Helper]{FFFFFF} Ошибка, рядом никого нет!', -1) else
                                sampSendChat('/cure '..id)
                        end
            end
        end)



    while true do
        wait(0)
        imgui.Process = main_window_state.v
    end
end

function cmd_probiv(id)
    if probiv.v then
        lua_thread.create(function()
        _, id = sampGetPlayerIdByCharHandle(PLAYER_PED)
        wait(500)
        sampAddChatMessage('{de3163}[Shawty Helper] {ffffff}Авто-Пробив начат.', -1)
        wait(2000)
        sampSendChat("/time")
        wait(500)
        sampSendChat("/id "..id.."")
        sampSendChat("/id "..id.."")
        sampSendChat("/id "..id.."")
        wait(1000)
        setVirtualKeyDown(VK_TAB, false)
        wait(1000)
        setVirtualKeyDown(VK_TAB, false)
        wait(500)
        setVirtualKeyDown(116, true)
        wait(3100)
        setVirtualKeyDown(116, false)
        wait(600)
        sampSendChat("/skill")
        wait(600)
        sampSendChat("/stats")
        wait(600)
        sampSendChat("/donate")
        wait(600)
        setVirtualKeyDown(27, true)
        wait(500)
        sampSendChat("/invent")
        wait(1500)
        sampSendClickTextdraw(2078)
        wait(2000)
        setVirtualKeyDown(27, true)
        wait(500)
        sampAddChatMessage('{de3163}[Shawty Helper] {ffffff}Авто-Пробив завершён.', -1)
      end)
    end
end

local fa_glyph_ranges = imgui.ImGlyphRanges({ fa.min_range, fa.max_range })
function imgui.BeforeDrawFrame()
    if fa_font == nil then
        local font_config = imgui.ImFontConfig()
        font_config.MergeMode = true
        fa_font = imgui.GetIO().Fonts:AddFontFromFileTTF('moonloader/resource/fonts/fontawesome-webfont.ttf', 14.0, font_config, fa_glyph_ranges)
    end
end

function imgui.OnDrawFrame()
    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(750, 400), imgui.Cond.FirstUseEver)
        imgui.Begin(u8"Shawty Helper", main_window_state, imgui.WindowFlags.NoCollapse + imgui.WindowFlags.NoResize + imgui.WindowFlags.NoScrollbar + imgui.WindowFlags.NoScrollWithMouse +
              imgui.WindowFlags.NoTitleBar)
                imgui.BeginChild('##up1',
                imgui.ImVec2(200, 50), true, imgui.WindowFlags.NoScrollbar + imgui.WindowFlags.NoScrollWithMouse)
                imgui.Spacing()
                imgui.Spacing()
                imgui.Spacing()
                imgui.CenterTextColoredRGB('Shawty Helper v0.1.1')
                imgui.EndChild()
                imgui.SameLine()
                imgui.BeginChild('##up2',
                imgui.ImVec2(528, 50), true, imgui.WindowFlags.NoScrollbar + imgui.WindowFlags.NoScrollWithMouse)
                imgui.Spacing()
                imgui.Spacing()
                imgui.Spacing()
                imgui.CenterTextColoredRGB('Информация')
                imgui.EndChild()
                imgui.BeginChild('##left',
                imgui.ImVec2(200, 328), true, imgui.WindowFlags.NoScrollbar + imgui.WindowFlags.NoScrollWithMouse)
             if imgui.Button(u8('Информация'), imgui.ImVec2(-1, 75)) then
                     menu = 1
             end
             if imgui.Button(u8('Функции'), imgui.ImVec2(-1, 75)) then
                     menu = 2
             end
             if imgui.Button(u8('Биндер'), imgui.ImVec2(-1, 75)) then
                     menu = 3
             end
             if imgui.Button(u8('Настройки'), imgui.ImVec2(-1, 75)) then
                     menu = 4
             end
             imgui.EndChild()
             imgui.SameLine()
             imgui.BeginChild('##right', imgui.ImVec2(528, 328), true, imgui.WindowFlags.NoScrollbar + imgui.WindowFlags.NoScrollWithMouse)
             if menu == 1 then
                 imgui.CenterTextColoredRGB('Автор данного скрипта - shawtyglock\nЕсли желаете добавить в скрипт что-то для его доработки\nили нашли ошибки в скрипте, пишите мне в Discord: FluffyBeast#8186')
             end
             if menu == 2 then
                 if imgui.Checkbox(u8"Быстрый репорт", fastrep) then
                     mainIni.config.fastrep = fastrep.v
                     inicfg.save(mainIni, 'Shawty Helper.ini')
                 end
                 imgui.SameLine()
               imgui.TextQuestion("Быстрый репорт в формате:\n/rep *текст репорта*")



                 if imgui.Checkbox(u8"Авто-Пробив", probiv) then
                     mainIni.config.probiv = probiv.v
                     inicfg.save(mainIni, 'Shawty Helper.ini')
                 end
                 imgui.SameLine()
                 imgui.TextQuestion("Автоматически пробивает ваш айди, тайм, таб, \nдонат, скиллы, обвесы, F5. Активация: /probiv")

                 if imgui.Checkbox(u8"Нахождение территории", famzone) then
                     mainIni.config.famzone = famzone.v
                     inicfg.save(mainIni, 'Shawty Helper.ini')
                 end
                 imgui.SameLine()
                 imgui.TextQuestion("Автоматически находит территорию ближайшего семейного капта.\nНе включать, если используете пункт *WAR FOR TERRITORY*. Активация: /famzone")
             end


             if menu == 3 then

                 if imgui.HotKey("##1", ActiveLock, tLastKeys, 50) then
                         rkeys.changeHotKey(bindLock, ActiveLock.v)
                         mainIni.HotKey.lock = encodeJson(ActiveLock.v)
                         inicfg.save(mainIni, 'Shawty Helper.ini')
                 end
                 imgui.SameLine()
                 imgui.Text(u8"Открытие машины")
                 imgui.TextQuestion("Открывает машину на указанную вами клавишу/комбинацию клавиш")

                 if imgui.HotKey("##2", ActiveArmour, tLastKeys, 50) then
                         rkeys.changeHotKey(bindArmour, ActiveArmour.v)
                         mainIni.HotKey.armour = encodeJson(ActiveArmour.v)
                         inicfg.save(mainIni, 'Shawty Helper.ini')
                 end

                 imgui.SameLine()
                 imgui.Text(u8"Использование армора")
                 imgui.TextQuestion("Использует армор на указанную вами клавишу/комбинацию клавиш")

                 if imgui.HotKey("##3", ActiveMask, tLastKeys, 50) then
                         rkeys.changeHotKey(bindMask, ActiveMask.v)
                         mainIni.HotKey.mask = encodeJson(ActiveMask.v)
                         inicfg.save(mainIni, 'Shawty Helper.ini')
                 end

                 imgui.SameLine()
                 imgui.Text(u8"Использование маски")
                 imgui.TextQuestion("Использует маску на указанную вами клавишу/комбинацию клавиш")

                 if imgui.HotKey("##4", ActiveCure, tLastKeys, 50) then
                         rkeys.changeHotKey(bindCure, ActiveCure.v)
                         mainIni.HotKey.cure = encodeJson(ActiveCure.v)
                         inicfg.save(mainIni, 'Shawty Helper.ini')
                 end

                 imgui.SameLine()
                 imgui.Text(u8"Поднятие ближайшего игрока")
                 imgui.TextQuestion("Поднимает ближайшего игрока в стадии смерти уколом\nадреналина на указанную вами клавишу/комбинацию клавиш")

                 if imgui.HotKey("##5", ActiveDrugs, tLastKeys, 50) then
                         rkeys.changeHotKey(bindDrugs, ActiveDrugs.v)
                         mainIni.HotKey.drugs = encodeJson(ActiveDrugs.v)
                         inicfg.save(mainIni, 'Shawty Helper.ini')
                 end

                 imgui.SameLine()
                 imgui.Text(u8"Использование наркотиков")
                 imgui.TextQuestion("Использует наркотики в зависимости от количества вашего\nздоровья на указанную вами клавишу/комбинацию клавиш")
             end
             if menu == 4 then
                 imgui.Text(u8'Команда активации')
                 imgui.SameLine()
                 if imgui.InputText('', commandact) then
                         mainIni.config.CommandAct = commandact.v
                         inicfg.save(mainIni,'Shawty Helper.ini')
                 end
             end
             imgui.EndChild()
             imgui.End()
    end
end