Admin Mapmenu 0.4.1

Статус
В этой теме нельзя размещать новые ответы.
Сообщения
61
Реакции
-8
Помог
1 раз(а)
Ошибка
не работают менюшки
ОС
Linux
Amx Mod X
1.9.0 5263
Билд
ReHLDS version: 3.7.0.695-dev
ReGamedll
ReGameDLL version: 5.15.0.458-dev
Версия Metamod
Metamod-r v1.3.0.128, API (5:13)
Список метамодулей
[ 1] Reunion        RUN   -    reunion_mm_i386.so          v0.1.0.133       ini  Start Never
[ 2] Revoice RUN - revoice_mm_i386.so v0.1.0.34 ini Start Never
[ 3] Rechecker RUN - rechecker_mm_i386.so v2.5 ini Chlvl ANY
[ 4] ReSRDetector RUN - resrdetector_mm_i386.so v0.1.0 ini Chlvl ANY
[ 5] ReSemiclip RUN - resemiclip_mm_i386.so v2.3.9 ini Chlvl ANY
[ 6] WHBlocker RUN - whblocker_mm_i386.so v1.5.696 ini Chlvl ANY
[ 7] AMX Mod X RUN - amxmodx_mm_i386.so v1.10.0.5392 ini Start ANY
[ 8] ReAPI RUN - reapi_amxx_i386.so v5.12.0.192-dev pl7 ANY Never
[ 9] MySQL RUN - mysql_amxx_i386.so v1.9.0.5263 pl7 ANY ANY
[10] ReAimDetector RUN - reaimdetector_amxx_i386.so v0.2.2 pl7 ANY Never
[11] FakeMeta RUN - fakemeta_amxx_i386.so v1.9.0.5263 pl7 ANY ANY
[12] Ham Sandwich RUN - hamsandwich_amxx_i386.so v1.9.0.5263 pl7 ANY ANY
[13] Fun RUN - fun_amxx_i386.so v1.9.0.5263 pl7 ANY ANY
[14] CStrike RUN - cstrike_amxx_i386.so v1.9.0.5263 pl7 ANY ANY
14 plugins, 14 running
Список плагинов
[  1] Admin Loader            3.5         neygomon          admin_loader.am  running  
[ 2] ReAimDetector API 0.2.2 ReHLDS Team reaimdetector.a running
[ 3] FreshBans 1.4.0b kanagava fresh_bans_1.4. running
[ 4] Gag & Mute System 1.0 unit pr_gm_system.am running
[ 5] Admin Commands 1.9.0.5263 AMXX Dev Team admincmd.amxx running
[ 6] Admin Votes 1.9.0.5263 AMXX Dev Team adminvote.amxx running
[ 7] Commands Menu 1.9.0.5263 AMXX Dev Team cmdmenu.amxx running
[ 8] Players Menu 1.9.0.5263 AMXX Dev Team plmenu.amxx running
[ 9] Plugin Menu 1.9.0.5263 AMXX Dev Team pluginmenu.amxx running
[ 10] Stats Configuration 1.9.0.5263 AMXX Dev Team statscfg.amxx running
[ 11] CSStatsX SQL 0.7.4+2 serfreeman1337 csstatsx_sql.am running
[ 12] AES: StatsX 0.6 Dev-CS serfreeman1337/s aes_statsx_cstr running
[ 13] Admin Menu 1.0 unit pr_admin_menu.a running
[ 14] Demo Recording 1.0 unit pr_demo.amxx running
[ 15] Adverts Messages 1.0 unit pr_adverts.amxx running
[ 16] AFK Kicker 1.1 unit pr_afk.amxx running
[ 17] Simple Damager 1.0.0 fl0wer simple_damager. running
[ 18] Killer Blink 1.2 unit pr_killer_blink running
[ 19] Reset Score 0.0.2f wopox1337 resetscore.amxx running
[ 20] [ReAPI] No Team Flash 0.0.3 Vaqtincha no_team_flash.a running
[ 21] Ping Checker 26.0.1 RC1 h1k3 ping_checker.am running
[ 22] Restrict Weapons 1.9.0.5263 AMXX Dev Team restmenu.amxx running
[ 23] ReParachute 1.4 PurposeLess reparachute.amx running
[ 24] VIP System 1.2 unit pr_vip_system.a running
[ 25] Chat Manager 1.1.2-16 Mistrick chatmanager.amx running
[ 26] Map Manager: Core 3.0.4 Mistrick map_manager_cor running
[ 27] Map Manager: Scheduler 0.1.2 Mistrick map_manager_sch running
[ 28] Admin Mapmenu 0.4.1 d3m37r4 admin_mapmenu.a running
[ 29] Map Manager: Rtv 0.1.0 Mistrick map_manager_rtv running
[ 30] Map Manager: Nominatio 0.1.0 Mistrick map_manager_nom running
[ 31] Map Manager: BlockList 0.0.3 Mistrick map_manager_blo running
[ 32] Map Manager: Online so 0.0.2 Mistrick map_manager_onl running
[ 33] Map Manager: Effects 0.0.8 Mistrick map_manager_eff running
[ 34] Map Manager: Informer 0.0.5 Mistrick map_manager_inf running
[ 35] Advanced Experience Sy 0.5.9 [REA serfreeman1337/s aes_main.amxx running
[ 36] AES: CStrike Addon 0.5.9 [REA serfreeman1337/s aes_exp_cstrike running
[ 37] AES: Informer 0.5.9 [REA serfreeman1337/s aes_informer.am running
37 plugins, 37 running
Автор плагина
Admin Mapmenu 0.4.1
Версия плагина
0.4.1
Исходный код
#include <amxmodx>
#include <map_manager>
#include <map_manager_scheduler>

new const ADMIN_MAPLIST[] = "maps.ini"; // Список карт для формирования меню (в строку указывается только название карты без учета онлайна)
const FLAG_ACCESS_CHANGEMAP = ADMIN_MAP; // Флаг для доступа к командам смены карты
const FLAG_ACCESS_VOTEMAP = ADMIN_VOTE; // Флаг для доступа к командам создания голосования за смену карты

const VOTE_BY_ADMIN_MENU = 4;
const MAX_ITEMS_MENU = 6;

enum {
MenuKeyConfirm = 6,
MenuKeyBack,
MenuKeyNext,
MenuKeyExit
};

enum {
ChangeMapMenu,
VoteMapMenu
};

enum InfoList {
MenuType,
MenuPos,
MenuId,
MenuUserId
};

enum StateType {
StateNone = -1,
StateSelect
};

new Array:g_MapList, Array:g_VoteList, Array:g_MainMapList;
new g_LoadedMaps, g_VoteItems;

new g_MenuInfo[InfoList];
new StateType:g_State = StateNone;
new g_EventNewRound;

new g_LastRound;
new g_NextMap[MAPNAME_LENGTH];
new g_Prefix[48];

#if AMXX_VERSION_NUM < 200
new MapName[MAPNAME_LENGTH];
#endif

public plugin_init() {
register_plugin("Admin Mapmenu", "0.4.1", "d3m37r4");

RegisterCmd();
RegisterBlockCmd();

register_menucmd(g_MenuInfo[MenuId] = register_menuid("MapMenu"), 1023, "HandleMapMenu");
disable_event(g_EventNewRound = register_event("HLTV", "EventNewRound", "a", "1=0", "2=0"));

#if AMXX_VERSION_NUM < 200
get_mapname(MapName, charsmax(MapName));
#endif
}

public plugin_cfg() {
g_MapList = ArrayCreate(MAPNAME_LENGTH);
g_VoteList = ArrayCreate(MAPNAME_LENGTH);

new filename[32];
copy(filename, charsmax(filename), ADMIN_MAPLIST);

if(!mapm_load_maplist_to_array(g_MapList, filename)) {
ArrayDestroy(g_MapList);
ArrayDestroy(g_VoteList);
set_fail_state("nothing loaded from '%s'", filename);
}

if(g_MapList) {
g_LoadedMaps = ArraySize(g_MapList);
}

bind_pcvar_num(get_cvar_pointer("mapm_last_round"), g_LastRound);
mapm_get_prefix(g_Prefix, charsmax(g_Prefix));
}

public CmdSay(const id) {
if(!is_vote_started() && !is_vote_finished() && !is_vote_will_in_next_round()) {
return PLUGIN_CONTINUE;
}

new text[MAPNAME_LENGTH]; read_args(text, charsmax(text));
remove_quotes(text); trim(text); strtolower(text);

if(is_string_with_space(text)) {
return PLUGIN_CONTINUE;
}

new bool:nomination = false;
new map_index = mapm_get_map_index(text);
if(map_index != INVALID_MAP_INDEX) {
nomination = true;
} else if(strlen(text) >= 4) {
map_index = __FindSimilarMapByString(text, g_MainMapList);
if(map_index != INVALID_MAP_INDEX ) {
nomination = true;
}
}

if(nomination) {
return PLUGIN_HANDLED;
}

return PLUGIN_CONTINUE;
}

public CmdBlock(const id) {
if(is_vote_started() || is_vote_finished() || is_vote_will_in_next_round()) {
return PLUGIN_HANDLED;
}

return PLUGIN_CONTINUE;
}

public CmdChangeMap(const id, const flags) {
if(!CmdEnabled(id, flags, true)) {
return PLUGIN_HANDLED;
}

if(read_argc() != 2) {
console_print(id, "* Неверный синтаксис команды!");
console_print(id, "* Пример использования: amx_changemap <map>");
return PLUGIN_HANDLED;
}

new map[MAPNAME_LENGTH];
read_argv(1, map, charsmax(map));

if(equali(map, MapName)) {
console_print(id, "* Нельзя сменить на текущую карту!");
return PLUGIN_HANDLED;
}

if(!MapInArray(map, g_MainMapList) && !MapInArray(map, g_MapList)) {
console_print(id, "* Карта '%s' отсутствует в маплисте!", map);
return PLUGIN_HANDLED;
}

ChangeMap(id, map);
return PLUGIN_HANDLED;
}

public CmdVoteMap(const id, const flags) {
if(!CmdEnabled(id, flags, true)) {
return PLUGIN_HANDLED;
}

new argc = read_argc();
new max_items = mapm_get_votelist_size();

if(argc < 2 || max_items + 1 < argc) {
console_print(id, "* Неверный синтаксис команды!");
console_print(id, "* Максимальное число карт в голосовании: %d", max_items);
console_print(id, "* Пример использования: amx_votemap <map1> <map2> ...");
return PLUGIN_HANDLED;
}

g_VoteItems = 0;
max_items = (argc - 1);

for(new i, map[MAPNAME_LENGTH]; i < max_items; i++) {
read_argv(i + 1, map, charsmax(map));
if(map[0] == EOS) {
continue;
}

if(equali(map, MapName)) {
//console_print(id, "* Нельзя сменить на текущую карту!");
continue;
}

if(!MapInArray(map, g_MainMapList) && !MapInArray(map, g_MapList)) {
//console_print(id, "* Карта '%s' отсутствует в маплисте!", map);
continue;
}

if(MapInArray(map, g_VoteList)) {
//console_print(id, "* Карта '%s' повторяется в списке голосования!", map);
continue;
}

ArrayPushString(g_VoteList, map);
g_VoteItems++;
}

if(g_VoteItems) {
StartVote(id);
} else {
console_print(id, "* Голосование не было запущено!");
}

return PLUGIN_HANDLED;
}

public CmdChangeMapMenu(const id, const flags) {
if(!CmdEnabled(id, flags)) {
return PLUGIN_HANDLED;
}

OpenMapMenu(id, ChangeMapMenu);
return PLUGIN_HANDLED;
}

public CmdVoteMapMenu(const id, const flags) {
if(!CmdEnabled(id, flags)) {
return PLUGIN_HANDLED;
}

OpenMapMenu(id, VoteMapMenu);
return PLUGIN_HANDLED;
}

OpenMapMenu(const id, const menuid) {
if(g_State == StateNone) {
g_MenuInfo[MenuPos] = 0;
g_MenuInfo[MenuType] = menuid;
g_MenuInfo[MenuUserId] = id;
g_State = StateSelect;
ShowMapMenu(id);
}

if(g_State == StateSelect) {
new bool:menu_open, menu_index, dummy;
for(new player = 1; player <= MaxClients; player++) {
if(!is_user_connected(player)) {
continue;
}

player_menu_info(player, menu_index, dummy);
if(g_MenuInfo[MenuId] != menu_index) {
continue;
}

menu_open = true;
break;
}

if(!menu_open) {
ClearData();
}
}
}

ShowMapMenu(const id, const page = 0) {
new start, end;
new current = GetMenuPage(page, g_LoadedMaps, MAX_ITEMS_MENU, start, end);
new pages = GetMenuPagesNum(g_LoadedMaps, MAX_ITEMS_MENU);
new max_items = g_MenuInfo[MenuType] == VoteMapMenu ? mapm_get_votelist_size() : 1;

new menu[MAX_MENU_LENGTH];
new len = formatex(menu, charsmax(menu), g_MenuInfo[MenuType] == VoteMapMenu ?
"\y[\rVoteMap Menu\y] \wСписок карт" : "\y[\rChangeMap Menu\y] \wСписок карт");

len += formatex(menu[len], charsmax(menu) - len, " \y%d/%d^n", current + 1, pages + 1);
len += formatex(menu[len], charsmax(menu) - len, "\wВыбрано карт: \y%d/%d^n^n", g_VoteItems, max_items);

new keys = MENU_KEY_0;
for(new i = start, item, map_name[MAPNAME_LENGTH]; i < end; i++) {
ArrayGetString(g_MapList, i, map_name, charsmax(map_name));

keys |= (1 << item);
len += formatex(menu[len], charsmax(menu) - len, MapInArray(map_name, g_VoteList) ?
"\d%d. %s \y[\r*\y]^n" : "\r%d. \w%s^n", ++item, map_name);
}

new tmp[15];
setc(tmp, MAX_ITEMS_MENU - (end - start) + 1, '^n');
len += copy(menu[len], charsmax(menu) - len, tmp);

if(g_VoteItems) {
keys |= MENU_KEY_7;
len += formatex(menu[len], charsmax(menu) - len, g_MenuInfo[MenuType] == VoteMapMenu ?
"\r7. \wСоздать голосование^n" : "\r7. \wПодтвердить выбор^n");
} else {
len += formatex(menu[len], charsmax(menu) - len, g_MenuInfo[MenuType] == VoteMapMenu ?
"\d7. Создать голосование^n" : "\d7. Подтвердить выбор^n");
}

if(g_MenuInfo[MenuPos] != 0) {
keys |= MENU_KEY_8;
len += formatex(menu[len], charsmax(menu) - len, "^n\r8. \wНазад");
} else {
len += formatex(menu[len], charsmax(menu) - len, "^n\d8. Назад");
}

if(end < g_LoadedMaps) {
keys |= MENU_KEY_9;
len += formatex(menu[len], charsmax(menu) - len, "^n\r9. \wДалее");
} else {
len += formatex(menu[len], charsmax(menu) - len, "^n\d9. Далее");
}

formatex(menu[len], charsmax(menu) - len, "^n\r0. \wВыход");
show_menu(id, keys, menu, -1, "MapMenu");
}

public HandleMapMenu(const id, const key) {
new max_items = g_MenuInfo[MenuType] == VoteMapMenu ? mapm_get_votelist_size() : 1;
switch(key) {
case MenuKeyConfirm: {
if(g_MenuInfo[MenuType] == VoteMapMenu) {
StartVote(id);
} else {
ArrayGetString(g_VoteList, 0, g_NextMap, charsmax(g_NextMap));
ChangeMap(id, g_NextMap);
}
}
case MenuKeyBack: {
ShowMapMenu(id, --g_MenuInfo[MenuPos]);
}
case MenuKeyNext: {
ShowMapMenu(id, ++g_MenuInfo[MenuPos]);
}
case MenuKeyExit: {
ClearData();
}
default: {
new map_name[MAPNAME_LENGTH];
ArrayGetString(g_MapList, g_MenuInfo[MenuPos] * MAX_ITEMS_MENU + key, map_name, charsmax(map_name));

new map_index = ArrayFindString(g_VoteList, map_name);
if(map_index == INVALID_MAP_INDEX) {
if(g_VoteItems != max_items) {
ArrayPushString(g_VoteList, map_name);
g_VoteItems++;
}
} else {
ArrayDeleteItem(g_VoteList, map_index);
g_VoteItems--;
}

ShowMapMenu(id, g_MenuInfo[MenuPos]);
}
}
}

public EventNewRound() {
client_print_color(0, print_team_default, "%s ^1Следующая карта: ^4%s^1.", g_Prefix, g_NextMap);
intermission();
}

public mapm_maplist_loaded(Array:maplist) {
g_MainMapList = ArrayClone(maplist);
}

public mapm_prepare_votelist(type) {
if(type != VOTE_BY_ADMIN_MENU) {
return;
}

for(new i, map_name[MAPNAME_LENGTH]; i < g_VoteItems; i++) {
ArrayGetString(g_VoteList, i, map_name, charsmax(map_name));
mapm_push_map_to_votelist(map_name, PUSH_BY_NATIVE, CHECK_IGNORE_MAP_ALLOWED);
}

mapm_set_votelist_max_items(g_VoteItems);
}

bool:CmdEnabled(const index, const flags, bool:console = false) {
if(~get_user_flags(index) & flags) {
console_print(index, "* Недостаточно прав для использования команды!");
return false;
}

static message[190];
if(is_vote_started()) {
formatex(message, charsmax(message), "^1Команда недоступна! Голосование уже запущено!");
console ? __ConsolePrintEx(index, "* %s", message) : client_print_color(index, print_team_default, "%s %s", g_Prefix, message);
return false;
}

if(is_vote_will_in_next_round()) {
formatex(message, charsmax(message), "^1Команда недоступна! В следующем раунде начнется голосование за смену карты!");
console ? __ConsolePrintEx(index, "* %s", message) : client_print_color(index, print_team_default, "%s %s", g_Prefix, message);
return false;
}

if(is_last_round()) {
get_cvar_string("amx_nextmap", g_NextMap, charsmax(g_NextMap));
formatex(message, charsmax(message), "^1Команда недоступна! Cледующая карта уже определена: ^4%s^1.", g_NextMap);
console ? __ConsolePrintEx(index, "* %s", message) : client_print_color(index, print_team_default, "%s %s", g_Prefix, message);
return false;
}

if(g_State == StateSelect && g_MenuInfo[MenuUserId] != index) {
new name[MAX_NAME_LENGTH];
get_user_name(g_MenuInfo[MenuUserId], name, charsmax(name));

formatex(message, charsmax(message), "^1Команда недоступна! ^4%s^1 уже выбирает %s!",
g_MenuInfo[MenuUserId] ? name : "Server", g_MenuInfo[MenuType] == VoteMapMenu ? "карты" : "карту");

console ? __ConsolePrintEx(index, "* %s", message) : client_print_color(index, print_team_default, "%s %s", g_Prefix, message);
return false;
}

return true;
}

ChangeMap(const index, map[]) {
new name[MAX_NAME_LENGTH];
get_user_name(index, name, charsmax(name));

copy(g_NextMap, charsmax(g_NextMap), map);
set_cvar_string("amx_nextmap", g_NextMap);

client_print_color(0, print_team_default, "%s ^4%s ^1сменил текущую карту на ^4%s^1.", g_Prefix, index ? name : "Server", g_NextMap);
if(g_LastRound) {
enable_event(g_EventNewRound);
client_print_color(0, print_team_default, "%s ^1Смена карты произойдет в начале следующего раунда.", g_Prefix);
} else {
intermission();
}
}

StartVote(const index) {
new name[MAX_NAME_LENGTH];
get_user_name(index, name, charsmax(name));

client_print_color(0, print_team_default, "%s ^4%s ^1создал голосование за смену карты.", g_Prefix, index ? name : "Server");
map_scheduler_start_vote(VOTE_BY_ADMIN_MENU);
}

RegisterCmd() {
register_concmd("amx_changemap", "CmdChangeMap", FLAG_ACCESS_CHANGEMAP);
register_clcmd("amx_changemap_menu", "CmdChangeMapMenu", FLAG_ACCESS_CHANGEMAP);

register_concmd("amx_votemap", "CmdVoteMap", FLAG_ACCESS_VOTEMAP);
register_clcmd("amx_votemap_menu", "CmdVoteMapMenu", FLAG_ACCESS_VOTEMAP);
}

RegisterBlockCmd() {
register_clcmd("say", "CmdSay");
register_clcmd("say_team", "CmdSay");

register_clcmd("say rtv", "CmdBlock");
register_clcmd("say /rtv", "CmdBlock");
register_clcmd("say maps", "CmdBlock");
register_clcmd("say /maps", "CmdBlock");
}

GetMenuPage(cur_page, elements_num, per_page, &start, &end) {
new max = min(cur_page * per_page, elements_num);
start = max - (max % MAX_ITEMS_MENU);
end = min(start + per_page, elements_num);
return start / per_page;
}

GetMenuPagesNum(elements_num, per_page) {
return (elements_num - 1) / per_page;
}

ClearData() {
g_State = StateNone;
g_VoteItems = 0;
g_NextMap[0] = EOS;
g_MenuInfo[MenuUserId] = 0;
ArrayClear(g_VoteList);
}

__FindSimilarMapByString(string[MAPNAME_LENGTH], Array:maplist) {
if(maplist == Invalid_Array) {
return INVALID_MAP_INDEX;
}

new map_info[MapStruct], end = ArraySize(maplist);
for(new i; i < end; i++) {
ArrayGetArray(maplist, i, map_info);
if(containi(map_info[Map], string) != -1) {
return i;
}
}

return INVALID_MAP_INDEX;
}

bool:MapInArray(map[], Array:arr) {
return bool:(ArrayFindString(arr, map) != INVALID_MAP_INDEX);
}

stock __ConsolePrintEx(const index, const message[], any:...) {
static _string[126];
vformat(_string, charsmax(_string), message, 3);

static const color_tags[][] = { "^1", "^3", "^4" };
for(new i; i < sizeof color_tags; i++) {
replace_string(_string, charsmax(_string), color_tags[i], "", false);
}

console_print(index, _string);
}
не работают менюшки
 
В этой теме было размещено решение! Перейти к решению.
Сообщения
75
Реакции
66
Помог
1 раз(а)
Каким образом пытаетесь открыть меню карт?
Через консольные комманды?
 
Сообщения
75
Реакции
66
Помог
1 раз(а)
Polis, amx_votemap_menu
Не пропустили нижний прочерк?
Внимательно посмотрите комманды
 
Последнее редактирование:

d3m37r4

111111
Сообщения
1,454
Реакции
1,194
Помог
10 раз(а)
amx_votemapmenu

amx_mapmenu
Посмотри пункт КОМАНДЫ
amx_changemap_menu - консольная команда, которая открывает меню для смены карты.
amx_votemap_menu - консольная команда, которая открывает меню для создания голосования за смену карты.
 
Статус
В этой теме нельзя размещать новые ответы.

Пользователи, просматривающие эту тему

Сейчас на форуме нет ни одного пользователя.
Сверху Снизу