Четверг, 16.05.2024, 00:36

Навигация
Главная страница Файлообменник Информация о сайте ! Гостевая книга Cyber Arena Онлайн PS Статьи Форум Поиск Радио Чат

Продвижение сайтов

TOP сайтов Регистрация доменов Реклама на сайте Создай себе баннер Автораскрутка сайта Генераторы CSS Compressor Сайт в поисковики

Онлайн кинотеатр

Онлайн фильмы Онлайн сериалы Онлайн трэйлеры Онлайн клипы

uCoz Система

Скрипты Шапки Шаблоны Иконки групп HTML таблица Кнопки для форума

Adobe PhotoShop

Кисти Иконки Стили Уроки Градиенты Шрифты Готовые PSD работы

Counter Strike 1.6

Cкачать Counter-Strike 1.6 Модели Игроков CS 1.6 Модели Оружия CS 1.6 Другие модели CS 1.6 Темы меню CS 1.6 Логотипы CS 1.6 Спрайты CS 1.6 Видео CS 1.6 Патчи CS 1.6 Боты CS 1.6

Сервер CS 1.6

Готовые сервера Программы Античиты Плагины Карты Моды

Counter-Strike Source

Скачать игру Модели Игроков Модели Оружия Темы меню Программы Логотипы Видео Карты Патчи Боты

Помощь по CS 1.6

Как создать сервер ? Как сд.серв на 2 протокола ? Как быть с динамическим IP ? Делаем плагин для AMXMods Установка плагинов Делаем демки HLTV
Партнёры #1
Партнёры #1:


Кинопремьеры
Наш опрос
Как вы нашли нас?

Результат опроса Результаты
Все опросы нашего сайта Архив опросов
Всего голосовало: 21

Главная » Статьи » Counter-Strike 1.6 » Другие настройки CS 1.6» Делаем плагин для AMXMods

Делаем плагин для AMXMods

Делаем плагин для AMXMods


Из этого мануала вы узнаете как нужно создавать плагины (plugins) для Counter-Strike сервера. Вы научитесь азам этого.
Этот плагин пишется под мод HL - Counter- Strike. Примите это к сведению.

Начнем написание вашего первого плагина.

Давайте начнем с простого: вывод сообщений на экран.

Придумаем команду, которая это будет делать:

amx_ helloworld,
amx_ hello
или даже hello



Надо что бы админ смог, когда захочет, вписать соответствующую команду и на экран выводилось соответствующая надпись:

hello world,
hello
или даже "hi all"



Прежде чем начать я хочу сказать несколько слов о том, что нужно для написания скриптов:
Вам нужен редактор текста. Блокнот (notepad2) – это хорошо, но worldpad лучше. Когда вы освоитесь можно переходить на более удобные редакторы.


У вас должен быть установлен AMXMod и соответственно должен быть сервер на котором он стоит.
Я не буду объяснять вам как устанавливать и настраивать AMXMod на сервере, так как это очень хорошо описано в документации к AMXMod'у.


Готовы? Ну тогда начнем!

Откройте блокнот и сохраните под названием, например, myplugin.sma. Заготовка уже есть, осталось наполнить её командами.
Начинаем с секции "комментарий", в самом начале файла myplugin. sma. Секция комментарий – часть кода, не являющаяся кодом. Это всего на всего комментарий. Обычно здесь указывают название плагина, его версию. Позже можно более детально описать работу вашего плагина, его установку и т.д. Но пока начнём с малого:

/*
Hello world, v0.1
By makeserver.ru
*/


Я всегда начинаю нумерацию версии плагина с 0.1. На самом деле не имеет значения с какой версии начать, но не начинайте с версии 1.0. Всегда нано начинать с меньшей версии. А когда вы пойметё, что ваш плагин уже готов к финалу, тогда вам и карты в руки. Так или иначе это всего на всего комментарий. Тут вы можете расписать весь ваш день, по минутам, как дневник. Это не будет критично, т.к. компилятор не будет читать эти строки. Но наличие названия плагина, версии и автора логично поместить здесь.


Любой плагин должен иметь функцию plugin_ init().
Всё то, что вставлено в эту данную функцию будет регистрироваться в AMX, что бы он мог использовать ваш плагин:

public plugin_init() {
register_plugin("Hello world","0.1","makeserver.ru")
}



Это команда регистрирует ваши переменные.
plugin_ init() берёт три параметра из плагина: это его название (Hello world), его версию (0.1) и автора (makeserver.ru).
Старайтесь не терять кавычек и скобок, иначе работать не будет.


Но этого не достаточно, для нашей цели. Должна быть команда которую админ сможет использовать и для этого мы должны её зарегистрировать в plugin_ init() функции. Команды, которые вводятся в консоле сервера или от клиента должны быть внутри plugin_ init() для того, что бы ей могли пользоваться. plugin_ init() важен по многим другим причинам, о которых вы узнаете из более поздних уроках. Функция plugin_ init() это как сообщение для AMXMod, что существует ваш плагин.


register_clcmd("amx_helloworld", "myfunction", ADMIN_VOTE, " : prints Hello world!!!")



Допишите данную строку в секцию функции

plugin_ init()



С помощью этой строки мы регистрируем команду, которую будем в последствии использовать. Первый параметр в ковычках - это команда, которую мы будет вбивать в консоле. Следующий параметр в кавычках – это функция в нашем плагине, когда команда будет введена будет выполнена данная функция. Эту функцию мы напишем позже. На самом деле назвать можно как угодно. Название не должно быть очень большим, тогда данное название не подходит ( ). Назвал её так для простоты и непринужденности прочтения текста. Следующий параметр – уровень доступа. Т.е. кто на сервере имеет права для выполнения данной команды. В данном случае админ ( ADMIN_VOTE ). Зачем простым игрокам разводить флуд . Но можно сделать доступ всем: надо указать 0 вместо ADMIN _ VOTE. Замете кавычек нет! Таким образом командой могут пользоваться админы с уровнем доступа к голосованию (vote). И последний параметр – это комментарий. Он будет отображен когда вы введёте amx_help. НЕ ТЕРЯЙТЕ КАВЫЧЕК!!!

Таким образом функция plugin_ init() выглядит так:

public plugin_init() {
register_plugin("Hello world", "0.1", "makeserver.ru")
register_clcmd("amx_helloworld", "myfunction", ADMIN _VOTE, " : says Hello world!!!")
}



Держите отступы, т.е. используйте " tab" или, к примеру, пробелы в написании функций. Откройте любой . sma файл, поставляемый вместе с AMX, и вы поймёте, о чем я говорю. Это упростит компиляцию и плагин будет откомпилирован более качественно. Так же это упростит изучение вашего плагина других разработчиков. Куда проще разбираться в структурированном коде, чем в бардаке . Есть ещё серьёзные основания, но сейчас я не буду в них вдаваться.


Добавьте данные строки. Они должны обязательно присутствовать в плагине:
#include
#include

Данные строки помещаются сразу после комментариев и перед plugin_ init() функцией. Таким образом мы добавляем модули CS.

Мы уже довольно много написали. Должно быть, похоже вот на это:

/*
Hello world, v0.1
By makeserver.ru
*/

#include
#include

public plugin_init() {
register_plugin("Hello world","0.1","makeserver.ru ")
register_clcmd("amx_helloworld","myfunction",ADMIN _VOTE," : says Hello world!!! to game screen")
}



Всегда сохраняйте написанное. Кто знает когда отключат электричество. Попробуйте откомпилировать данный плагин. Если есть ошибки, то их проще найти сейчас. Это значительно упрощает поиск ошибок. (Как откомпилировать плагин?)

Нам осталось написать последнюю функцию – вывод сообщения на экран. Мы зарегистрировали команду которая будет выполнятся в консоли, сообщение выводимое на экран тоже зарегистрировали. Теперь осталось создать функцию которая будет всё это делать:

public myfunction(id,level,cid) {
if (!cmd_access(id,level,cid,1)) {
return PLUGIN_HANDLED
}
}



Я не буду расписывать как работает функция cmd_access(). Скажу только, что она проверяет, может ли клиент использовать данную команду.

Хочу прокомментировать следующее – id.
Id – это уникальный номер каждого присутствующего на сервере. Оно будет ему присвоено при входе и отобрано при выходе. Это уникальный номер каждого играющего, одинаковых быть не может. Если сервер рассчитан на 32 игрока, то id будет от 1 до 32. Движок Half- Life более 32 игроков не держит. Если сервер рассчитан на 16, то от 1 до 16.


Id используется по разному. В cmd_ access() через id проверяется уровень доступа этого текучего пользователя, и никого другого. Надеюсь это понятно.

Следующая линия кода:

client_print(0,print_center,"Hello world!!!")



Это та строчка кода, которая отвечает за печатание сообщения у клиента. сlient_ print является названием функции, которая берёт три параметра (может требоваться больше, но об этом в других уроках). Первый параметр (0) отвечает за то кому будет выведена данная команда. Если поставить id номер игрока, то сообщение будет выведено ему и вам. В данном случае выведено будет для всех присутствующих на сервере (живым или мертвым). Т.е. когда вам надо сделать со всеми что-то или сообщить всем что-то надо использовать 0. Второй параметр указывает где следует выводить сообщение. Можно поместить сообщение в районе чата - print_ chat или print_ notify – отображает только в консоле. И третий параметр – само сообщение. То, что в пределах кавычек то и есть сообщение, которое будет печататься на экран. Не теряйте кавычек.


Мы почти написали наш первый плагин. Осталось только дописать следующую строчку в функцию

myfunction():return PLUGIN_HANDLED



Поэтому всегда заканчивайте функцию return PLUGIN_HANDLED.

Полностью наш плагин выглядит так:

/*
Hello world, v0.1
By makeserver.ru
*/

#include
#include

public myfunction(id,level,cid) {
if (!cmd_access(id,level,cid,1)) {
return PLUGIN_HANDLED
}

client_print(0,print_center,"Hello world!!!")

return PLUGIN_HANDLED
}

public plugin_init() {
register_plugin("Hello world","0.1","makeserver.ru")
register_clcmd("amx_helloworld","myfunction",ADMIN _VOTE," : prints Hello world!!! to everyone")

}



Всё, плагин готов. Откомпилируйте его и убедитесь, что нет ошибок во время компиляции.
Если при компиляции вы получаете сообщение

warning 217: loose indentation,



перейдите на указанную строчку и проследите что бы углубление (" tab" – помните…) было одинаково везде в вашем плагине.

Теперь можете поместить файл myplugin.amx в папку plugins и прописать плагин в config/plugins.ini. Не забудьте перезагрузить ваш сервер.

Теперь заходите в игру и пропишите amx_helloworld и убедитесь что всё отображается как надо.
Удостоверьтесь, что при вводе команды amx_help описание соответствует тому, что использовали мы.
Если плагин не работает, в консоле сервера введите amx plugins и убедитесь, что плагин загружен.
Возможно вы забыли прописать себя админом.
Категория: Другие настройки CS 1.6 | Просмотров: 1224 | Добавил: c1nOpT1k | Рейтинг: 0.0/0 |

Теги:

HTML
BB-Code
Ссылка
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]
Мини-чат
SunshineFM Radio - первое солнечное и яркое
онлайн радио. Закажите свою любимую песню,
передайте приветы и поздравления,
признание в любви. Мы делаем этот мир ярче!

Слушать в своем плеере
Наша Кнопка

Наши баннеры


Мы [b][K]онтакте
Counter-Strike 1.6
Навигация 2
Для Windows Cиcтемные Рабочий стол Мультимедиа Графические Для раскрутки сайтов Антивирусные программы Утилиты для компьютера DataLife Engine ( DLE ) Интернет программы Прочие программы

Игры для PC

Action ( Экшен ) Logic ( Логические ) Adventure ( Путешествия ) Online ( Онлайн ) Simulation ( Симуляторы ) Arcade ( Аркады ) Racing ( Гонки ) Sports ( Спортивные ) Board Game ( Офисные ) RPG ( Ролевые )
Друзья сайта


Статистика
Онлайн:
Онлайн всего: 1
Гостей: 1
Пользователей: 0
Гости сайта Пользователи
Зарег. на сайте:
Всего: 377
Новых за месяц: 0
Новых за неделю: 0
Новых вчера: 0
Новых сегодня: 0
Из них:
Обычных: 376
Г.Администраторов: 1
Администраторов: 0
Г.Модераторов: 0
Модераторов: 0
Дизайнеров: 0
Журналистов: 0
Файловиков: 0
Друзья: 0
Проверенных: 0
Забаненых: 0
Из них:
Парней: 337
Девушек: 40
Счетчик материалов:
Новостей: 139
Статей: 6
Файлов: 1022
Форум: 119/126
Видео: 9
Сайтов: 1
Фильмов: 16
Серверов: 4
Картинок: 31
Комментариев: 7
Счетчики:
Тиц и pr сайта







PR-CY.ru
Сегодня нас посетили:


HiT-HarD.3dn.Ru © Все права защищены Бесплатный хостинг uCoz Сайт оптимизирован под разрешение экрана 1280х1024 и браузеры Mozila Firefox
Дизайн данного сайта полностью принадлежит администратору сайта.