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

Dashok.

Участник
228
9
Как сделать сохранение? не получается чтото
Код:
require "lib.moonloader"
local tag = "{A9F213}[AL by Dadayaaa]: {CCCCCC}"
local vkeys    = require "lib.vkeys"
local inicfg = require 'inicfg'


local mainIni = inicfg.load({
  settings =
  {
    password = ""
  }
}) -- загрузим основной конфиг. путь к файлу не указан, а значит будет загружен файл по пути ./moonloader/config/example.lua.in

function main()
 if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
    
     _, player_id = sampGetPlayerIdByCharHandle(playerPed)
     player_nick = sampGetPlayerNickname(player_id)
    
    
     sampRegisterChatCommand('alog', function(passwd)
    mainIni.settings.password = passwd
    inicfg.save(mainIni,
    end)
    
     sampAddChatMessage(tag .. '”спешно загружен.')
     sampAddChatMessage(tag .. 'Что-бы установить пароль для входа введите команду /alog')
     while true do
    
    --if isKeyJustPressed(VK_R) and not isGamePaused() then
    --sampSendChat("/usedrugs 2")
    --end
        wait(0)
        end
end

function onReceiveRpc(id,bitStream)
    if id == 61 then
        dialogId = raknetBitStreamReadInt16(bitStream)
        style = raknetBitStreamReadInt8(bitStream)
        str = raknetBitStreamReadInt8(bitStream)
        title = raknetBitStreamReadString(bitStream, str)
        if title:find("јвторизаци¤") then
        sampSendDialogResponse(dialogId,1,0,""..password)
        end
    end
end
 

ollydbg

Известный
163
115
Как сделать сохранение? не получается чтото
Код:
require "lib.moonloader"
local tag = "{A9F213}[AL by Dadayaaa]: {CCCCCC}"
local vkeys    = require "lib.vkeys"
local inicfg = require 'inicfg'


local mainIni = inicfg.load({
  settings =
  {
    password = ""
  }
}) -- загрузим основной конфиг. путь к файлу не указан, а значит будет загружен файл по пути ./moonloader/config/example.lua.in

function main()
if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
   
     _, player_id = sampGetPlayerIdByCharHandle(playerPed)
     player_nick = sampGetPlayerNickname(player_id)
   
   
     sampRegisterChatCommand('alog', function(passwd)
    mainIni.settings.password = passwd
    inicfg.save(mainIni,
    end)
   
     sampAddChatMessage(tag .. '”спешно загружен.')
     sampAddChatMessage(tag .. 'Что-бы установить пароль для входа введите команду /alog')
     while true do
   
    --if isKeyJustPressed(VK_R) and not isGamePaused() then
    --sampSendChat("/usedrugs 2")
    --end
        wait(0)
        end
end

function onReceiveRpc(id,bitStream)
    if id == 61 then
        dialogId = raknetBitStreamReadInt16(bitStream)
        style = raknetBitStreamReadInt8(bitStream)
        str = raknetBitStreamReadInt8(bitStream)
        title = raknetBitStreamReadString(bitStream, str)
        if title:find("јвторизаци¤") then
        sampSendDialogResponse(dialogId,1,0,""..password)
        end
    end
end
Lua:
local inicfg = require 'inicfg'
local mainIni = inicfg.load({
    settings = {
         password = ""
    }
},'file')
inicfg.save(mainIni, 'file')
 

bottom_text

Известный
673
320
Как сделать сохранение? не получается чтото
Код:
require "lib.moonloader"
local tag = "{A9F213}[AL by Dadayaaa]: {CCCCCC}"
local vkeys    = require "lib.vkeys"
local inicfg = require 'inicfg'


local mainIni = inicfg.load({
  settings =
  {
    password = ""
  }
}) -- загрузим основной конфиг. путь к файлу не указан, а значит будет загружен файл по пути ./moonloader/config/example.lua.in

function main()
if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
  
     _, player_id = sampGetPlayerIdByCharHandle(playerPed)
     player_nick = sampGetPlayerNickname(player_id)
  
  
     sampRegisterChatCommand('alog', function(passwd)
    mainIni.settings.password = passwd
    inicfg.save(mainIni,
    end)
  
     sampAddChatMessage(tag .. '”спешно загружен.')
     sampAddChatMessage(tag .. 'Что-бы установить пароль для входа введите команду /alog')
     while true do
  
    --if isKeyJustPressed(VK_R) and not isGamePaused() then
    --sampSendChat("/usedrugs 2")
    --end
        wait(0)
        end
end

function onReceiveRpc(id,bitStream)
    if id == 61 then
        dialogId = raknetBitStreamReadInt16(bitStream)
        style = raknetBitStreamReadInt8(bitStream)
        str = raknetBitStreamReadInt8(bitStream)
        title = raknetBitStreamReadString(bitStream, str)
        if title:find("јвторизаци¤") then
        sampSendDialogResponse(dialogId,1,0,""..password)
        end
    end
end
Lua:
require "lib.moonloader"
local tag = "{A9F213}[AL by Dadayaaa]: {CCCCCC}"
local vkeys    = require "lib.vkeys"
local inicfg = require 'inicfg'

local mainIni = inicfg.load({
  settings =
  {
    password = ""
  }
}) -- загрузим основной конфиг. путь к файлу не указан, а значит будет загружен файл по пути ./moonloader/config/example.lua.in
local ini = 'moonloader\\zalupa.ini' -- ты забыла написать директорию и вместо неё поставила end
function main()
if not isSampfuncsLoaded() or not isSampLoaded() then return end
    while not isSampAvailable() do wait(100) end
   
     _, player_id = sampGetPlayerIdByCharHandle(playerPed)
     player_nick = sampGetPlayerNickname(player_id)
   
   
     sampRegisterChatCommand('alog', function(passwd)
    mainIni.settings.password = passwd
    inicfg.save(mainIni,
     ini ) -- тут ошибка была
        end)
   
     sampAddChatMessage(tag .. '”спешно загружен.', -1)
     sampAddChatMessage(tag .. 'Что-бы установить пароль для входа введите команду /alog', -1 ) -- цвет поставил, иначе timestamp чёрный
     while true do
   
    --if isKeyJustPressed(VK_R) and not isGamePaused() then
    --sampSendChat("/usedrugs 2")
    --end
        wait(0)
        end
end
function onReceiveRpc(id,bitStream)
    if id == 61 then
        dialogId = raknetBitStreamReadInt16(bitStream)
        style = raknetBitStreamReadInt8(bitStream)
        str = raknetBitStreamReadInt8(bitStream)
        title = raknetBitStreamReadString(bitStream, str)
        if title:find("јвторизаци¤") then
        sampSendDialogResponse(dialogId,1,0,""..password)
        end
    end
end
 

chapo

чопа сребдс // @moujeek
Модератор
8,935
11,704
Как сделать только четные числа в sliderInt? (imgui)
 

kiborgg

Новичок
14
0
Как выбрать пункт вперед из диалога и нажать энтер?
54566.png
 

Vintik

Через тернии к звёздам
Проверенный
1,556
1,027
Не вариант кнопки только выгнать и закрыть а продолжить нету
Вариант. "Нажать ентер" это тоже самое, что кликнуть левую кнопку (в твоём случае "Выгнать"). Не веришь? Проверяй сам.
 

BRaze

Участник
84
0
В чём может быть проблема? Просит ещё какие-то end'ы.
Как только убираю строки "return false" - скрипт начинает прекрасно работать
Разве return false требует end'a?

Lua:
  function Sampev.onShowDialog(ID, Style, Title, Button1, Button2, Text)
    if ID == 3412 and Title:find('Отправка сообщения без модерации') then
      sampSendDialogResponse(ID, 1, 65535)
      return false
    end
    if ID == 45 and Text:find('Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.') then
      sampSendDialogResponse(ID, 1, 65535)
      return false
      if AutoADMessage then
        sampAddChatMessage('{F9DF73}Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.', -1)
      end
    end
  end
 

bottom_text

Известный
673
320
В чём может быть проблема? Просит ещё какие-то end'ы.
Как только убираю строки "return false" - скрипт начинает прекрасно работать
Разве return false требует end'a?

Lua:
  function Sampev.onShowDialog(ID, Style, Title, Button1, Button2, Text)
    if ID == 3412 and Title:find('Отправка сообщения без модерации') then
      sampSendDialogResponse(ID, 1, 65535)
      return false
    end
    if ID == 45 and Text:find('Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.') then
      sampSendDialogResponse(ID, 1, 65535)
      return false
      if AutoADMessage then
        sampAddChatMessage('{F9DF73}Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.', -1)
      end
    end
  end

Lua:
function Sampev.onShowDialog(ID, Style, Title, Button1, Button2, Text)
    if ID == 3412 and Title:find('Отправка сообщения без модерации') then
      sampSendDialogResponse(ID, 1, 65535)
      return false
    end
      if AutoADMessage then
        sampAddChatMessage('{F9DF73}Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.', -1)
      end
      if ID == 45 and Text:find('Ваше объявление было автоматически отправлено в очередь публикации, так как вы репортер.') then
        sampSendDialogResponse(ID, 1, 65535)
        return false
      end 
  end
Попробуй вот так
 

Rybkabob

Участник
65
9
1:
if wasKeyPressed(43) and not sampIsChatInputActive() then
            setAudioStreamState(AudioStream, sound_state.STOP)

Как дополнить еще клавиши?
 

Setkh

Участник
74
6
смотря для какого сервера, если на сервере команда /re то можно сделать так
Lua:
local samp = require("samp.events")

function samp.onSendCommand(cmd)
   local result, playerid = sampGetPlayerIdByCharHandle(PLAYER_PED)
   if result and tonumber(cmd:match("^/re%s+(%d+)%s*")) == playerid then
      sampAddChatMessage("нельзя следить за собой", -1)
      return false
   end
end
Я не это имел в виду)
Я про функцию, при активации которой админ не видит тебя при реконе, вместо этого ему транслируется пляж
Хз что это, в ракботе мб такая функция есть, мб в собейте каком-то. Хотелось бы узнать как работает