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

Emilsss4

Новичок
1
0
Здарова росомахи я ультра мега пупер дупер новичек на луа нечего не знаю и не понимаю пытаюсь говнокодить мне надо чтоб из переменной text удалялось чуть текста
delete:
function smpv.onSendChat(text)
    if text == 'wewewe' do delete(text, 1, 2) then
        sampAddChatMessage(text, clr)

    end
    
    

    
end
 

whyega52

Eblang головного мозга
Модератор
2,839
2,779
@imring Почему не хочет работать таймер? Ошибки никакой нет. Использую только SFLua и RakLua без cleo и sampfuncs

Код:
local RakLua = require 'RakLua'
RakLua.defineSampLuaCompatibility()

require "SFLua"
require "moonloader"
require "sampfuncs"

local sampev = require ("samp.events")

local time = 5

function sampev.onServerMessage(color, text)
        if text:find("Ты получил (%d+) материалов") or
            text:find("Ты взял со склада (%d+) пакетов.") then
            clock = os.clock()
            if not timer then
                lua_thread.create(function()
                    while os.clock() - clock < time do wait(0) timer = true end
                    timer = false
                    sampAddChatMessage("{FFFFFF}AutoMaterials{FFFFFF}: Откат прошел.", -1)
                end)
            end
        end
    end
а зачем подключать сампфункс и сфлуа одновременно? 🧐
 
  • Нравится
Реакции: qdIbp и Emilsss4

Basedbounty

Известный
198
103
Здрасте дорогие мои друзья, помогите пожалуйста с кодом:
Lua:
script_name('SETWEATH')
script_author('WEWORNY')


require "lib.moonloader"
local color_dialog = 0xDEB887
-- Для диалога с ID 14
local dialogTabArr = {"Нажмите сюда если хотите погоду:\t{FF8C00}Утро", "Нажмите сюда если хотите погоду:\t{FF8C00}Ночь"}
local dialogTabStr = ""

for _, str in ipairs(dialogTabArr) do
    dialogTabStr = dialogTabStr .. str .. "\n"
end



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

   sampRegisterChatCommand("setweath", cmd_dialog)
   sampRegisterChatCommand("sw", cmdSetWeather)
 
    while true do
        wait(0)
      
         if time then
      setTimeOfDay(time, 0)
    end

        local result, button, list, input = sampHasDialogRespond(14)

        if result then -- если диалог открыт
            if button == 1 then -- если нажата первая кнопка (Выбрать)
                if list == 0 then
                    sampAddChatMessage("Вы успешно выбрали погоду: {FF8C00}Утро", color_dialog)
                        sampSendChat("/sw 1")
        
                elseif list == 1 then
                    sampAddChatMessage("Вы успешно выбрали погоду: {FF8C00}Ночь", color_dialog) sampSendChat("/sw 4")
                end
           else
                sampAddChatMessage("Вы закрыли диалоговое окно c выбором погоды!", color_dialog)
                  
            end
        end

    end
end


function cmdSetWeather(param)
  local weather = tonumber(param)
  if weather ~= nil and weather >= 0 and weather <= 45 then
    forceWeatherNow(weather)
  end
end


function cmd_dialog(arg)
    if #arg == 0 then
        sampShowDialog(14, "Выберите погоду{DC143C} (By Weworny)", dialogTabStr, "Выбрать", "Закрыть", 4)

    end
    
end

прикол в том что при написании команды /setweath открывается диалоговое окно с выбором погоды, выбрав которую высвечивается текст и заменяется погода, но происходит все, кроме смены погоды, мне пишет что команды не существует, хотя я ее зарегестрировал.
 

qdIbp

Автор темы
Проверенный
1,451
1,190
@imring Почему не хочет работать таймер? Ошибки никакой нет. Использую только SFLua и RakLua без cleo и sampfuncs

Код:
local RakLua = require 'RakLua'
RakLua.defineSampLuaCompatibility()

require "SFLua"
require "moonloader"
require "sampfuncs"

local sampev = require ("samp.events")

local time = 5

function sampev.onServerMessage(color, text)
        if text:find("Ты получил (%d+) материалов") or
            text:find("Ты взял со склада (%d+) пакетов.") then
            clock = os.clock()
            if not timer then
                lua_thread.create(function()
                    while os.clock() - clock < time do wait(0) timer = true end
                    timer = false
                    sampAddChatMessage("{FFFFFF}AutoMaterials{FFFFFF}: Откат прошел.", -1)
                end)
            end
        end
    end
Закомменти require "SFLua" и с 90% уверен что код заработает

Здрасте дорогие мои друзья, помогите пожалуйста с кодом:
Lua:
script_name('SETWEATH')
script_author('WEWORNY')


require "lib.moonloader"
local color_dialog = 0xDEB887
-- Для диалога с ID 14
local dialogTabArr = {"Нажмите сюда если хотите погоду:\t{FF8C00}Утро", "Нажмите сюда если хотите погоду:\t{FF8C00}Ночь"}
local dialogTabStr = ""

for _, str in ipairs(dialogTabArr) do
    dialogTabStr = dialogTabStr .. str .. "\n"
end



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

   sampRegisterChatCommand("setweath", cmd_dialog)
   sampRegisterChatCommand("sw", cmdSetWeather)
 
    while true do
        wait(0)
    
         if time then
      setTimeOfDay(time, 0)
    end

        local result, button, list, input = sampHasDialogRespond(14)

        if result then -- если диалог открыт
            if button == 1 then -- если нажата первая кнопка (Выбрать)
                if list == 0 then
                    sampAddChatMessage("Вы успешно выбрали погоду: {FF8C00}Утро", color_dialog)
                        sampSendChat("/sw 1")
      
                elseif list == 1 then
                    sampAddChatMessage("Вы успешно выбрали погоду: {FF8C00}Ночь", color_dialog) sampSendChat("/sw 4")
                end
           else
                sampAddChatMessage("Вы закрыли диалоговое окно c выбором погоды!", color_dialog)
                
            end
        end

    end
end


function cmdSetWeather(param)
  local weather = tonumber(param)
  if weather ~= nil and weather >= 0 and weather <= 45 then
    forceWeatherNow(weather)
  end
end


function cmd_dialog(arg)
    if #arg == 0 then
        sampShowDialog(14, "Выберите погоду{DC143C} (By Weworny)", dialogTabStr, "Выбрать", "Закрыть", 4)

    end
  
end

прикол в том что при написании команды /setweath открывается диалоговое окно с выбором погоды, выбрав которую высвечивается текст и заменяется погода, но происходит все, кроме смены погоды, мне пишет что команды не существует, хотя я ее зарегестрировал.
Ты хочешь использ локальные команды в sampSendChat, но я тебя растрою это так не работает

Lua:
script_name('SETWEATH')
script_author('WEWORNY')

require("lib.moonloader")

local color_dialog = 0xDEB887
-- Для диалога с ID 14
local dialogTabArr = {"Нажмите сюда если хотите погоду:\t{FF8C00}Утро", "Нажмите сюда если хотите погоду:\t{FF8C00}Ночь"}
local dialogTabStr = ""
local times = true
for _, str in ipairs(dialogTabArr) do
    dialogTabStr = dialogTabStr..''..str.."\n"
end

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

    sampRegisterChatCommand("setweath", function()sampShowDialog(14, "Выберите погоду{DC143C} (By Weworny)", dialogTabStr, "Выбрать", "Закрыть", 4) end)
    sampRegisterChatCommand("sw", cmdSetWeather)
 
    while true do wait(0)
   
        setTimeOfDay(times and 12 or 23,0)
        local result, button, list, input = sampHasDialogRespond(14)
        if result then
            if button == 1 then
                sampAddChatMessage("Вы успешно выбрали погоду: "..(list == 0 and '{FF8C00}Утро' or '{FF8C00}Ночь'), color_dialog)
                cmdSetWeather(list == 0 and 1 or 4)
                times = (list == 0 or false)
            else
                sampAddChatMessage("Вы закрыли диалоговое окно c выбором погоды!", color_dialog)
            end
        end

    end
end

function cmdSetWeather(param)
    if tonumber(param) then
        local weather = tonumber(param)
        if weather >= 0 and weather <= 45 then
            forceWeatherNow(weather)
        end
    end
end
 
Последнее редактирование:
  • Нравится
Реакции: Basedbounty

RoAB

Потрачен
102
37
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
актуально

как проверить текстдрав по позиции? тип есть текстдрав и надо проверять, если ли еще один под ним.
Lua:
function sampev.onShowTextDraw(id, data)
    if math.floor(data.position.x) == "корда x" and math.floor(data.position.y) == "корда y" and math.floor(data.position.z) == "корда z" then
       -- code
    end
end
 

ChаtGPT

Активный
403
97
imgui.SetCursorPos(imgui.ImVec2(15 + 100 + 15, 35))
imgui.SetCursorPos(imgui.ImVec2(15 + 200 + 15, 50 + 15 + 50 + 5 + 165 + 30))
Объясните нахуя столько не понятных цифр ставить? почему не сделать просто X и Y Нахуя столько этого дрочить? Объясните, не понимаю..
 

chapo

tg/inst: @moujeek
Модератор
9,073
12,037
imgui.SetCursorPos(imgui.ImVec2(15 + 100 + 15, 35))
imgui.SetCursorPos(imgui.ImVec2(15 + 200 + 15, 50 + 15 + 50 + 5 + 165 + 30))
Объясните нахуя столько не понятных цифр ставить? почему не сделать просто X и Y Нахуя столько этого дрочить? Объясните, не понимаю..
так это и есть x и у, просто автору проще написать 15+200+15 вместо 230. Я делаю так же, но я делаю это потому что у меня практически все отступы сделаны «вручную», так что будет проще изменить 15 на 10, а не 230 на 225 (выглядит как бред шизика, но лично мне так проще)
 
  • Нравится
Реакции: ChаtGPT

ChаtGPT

Активный
403
97
актуально

как проверить текстдрав по позиции? тип есть текстдрав и надо проверять, если ли еще один под ним.
можно проверять текстдрав по иду, так проще думаю будет

Код:
function sampev.onShowTextDraw(id, data)
    if id == *id* then
    
    end
end
 
  • Нравится
Реакции: RoAB

Smeruxa

smeruxa.ru
Проверенный
1,412
757
imgui.SetCursorPos(imgui.ImVec2(15 + 100 + 15, 35))
imgui.SetCursorPos(imgui.ImVec2(15 + 200 + 15, 50 + 15 + 50 + 5 + 165 + 30))
Объясните нахуя столько не понятных цифр ставить? почему не сделать просто X и Y Нахуя столько этого дрочить? Объясните, не понимаю..
Удобнее ведь
1667793424432.png


не понятных цифр
Для тебя они могут являться непонятными, но для разработчика каждое слагаемое будет означать длину чего-то
 
Последнее редактирование:

imring

Ride the Lightning
Всефорумный модератор
2,366
2,556
@imring Почему не хочет работать таймер? Ошибки никакой нет. Использую только SFLua и RakLua без cleo и sampfuncs

Код:
local RakLua = require 'RakLua'
RakLua.defineSampLuaCompatibility()

require "SFLua"
require "moonloader"
require "sampfuncs"

local sampev = require ("samp.events")

local time = 5

function sampev.onServerMessage(color, text)
        if text:find("Ты получил (%d+) материалов") or
            text:find("Ты взял со склада (%d+) пакетов.") then
            clock = os.clock()
            if not timer then
                lua_thread.create(function()
                    while os.clock() - clock < time do wait(0) timer = true end
                    timer = false
                    sampAddChatMessage("{FFFFFF}AutoMaterials{FFFFFF}: Откат прошел.", -1)
                end)
            end
        end
    end
пытался через print найти какая часть кода не обрабатывается?

а зачем подключать сампфункс и сфлуа одновременно? 🧐
в sampfuncs.lua только объявление глобальных переменных (ид рпс/пакетов, тип диалогов и т.д.), поэтому вряд ли помешает сфлуа

Закомменти require "SFLua" и с 90% уверен что код заработает
точно?
 
  • Эм
Реакции: qdIbp

whyega52

Eblang головного мозга
Модератор
2,839
2,779
в sampfuncs.lua только объявление глобальных переменных (ид рпс/пакетов, тип диалогов и т.д.), поэтому вряд ли помешает сфлуа
не, я как раз не понимаю зачем надо подключать спамфункс.луа, если есть сфлуа (хз, заменяет-ли сфлуа и сампфункс.луа)
 
D

deleted-user-139653

Гость
пытался через print найти какая часть кода не обрабатывается?


в sampfuncs.lua только объявление глобальных переменных (ид рпс/пакетов, тип диалогов и т.д.), поэтому вряд ли помешает сфлуа


точно?
именно таймер не срабатывает почему-то
в этом скрипте есть еще вкл/выкл на команду, который я делаю, и там выводится в чат что скрипт вкл/выкл, так что дело не в этом

пытался через print найти какая часть кода не обрабатывается?


в sampfuncs.lua только объявление глобальных переменных (ид рпс/пакетов, тип диалогов и т.д.), поэтому вряд ли помешает сфлуа


точно?
Я конечно в шоке, я не знаю как это работает, но чисто решил проверить, и получилось, все заработало

Код:
Было так:
local RakLua = require 'RakLua'
RakLua.defineSampLuaCompatibility()
require "SFLua"

А надо было так записать:
require "SFLua"

local RakLua = require 'RakLua'
RakLua.defineSampLuaCompatibility()
 
Последнее редактирование модератором:
  • Вау
Реакции: qdIbp

artie

Участник
70
21
Как можно хукнуть краш игры? Чтобы, к примеру, когда игра крашит отправлялось уведомление в ТГ через этот исходник? Если, конечно, это возможно "успеть" сделать🧐
 

XRLM

Против ветра рождённый
Модератор
1,570
1,154
Как можно хукнуть краш игры? Чтобы, к примеру, когда игра крашит отправлялось уведомление в ТГ через этот исходник? Если, конечно, это возможно "успеть" сделать🧐
прогу писать ток мб, не на луа конечно.
 
  • Клоун
  • Нравится
Реакции: Air_Official и artie