[Core + Modes] Deathrun Mod

[Core + Modes] Deathrun Mod 1.1.4 (fix archive)

Нет прав для скачивания
Сообщения
594
Реакции
350
Предупреждения
1
Помог
9 раз(а)
Templar, ты темой и разделом ошибся) тебе в заказы)
 
Сообщения
584
Реакции
1,006
Помог
18 раз(а)
Said, сначала размеры задайте, потом уже drop_to_floor().
Еще не забудьте, что EngFunc_SetModel меняет размеры, если нужны кастомные, то размер надо менять после установки модели.
 
Последнее редактирование модератором:
Сообщения
175
Реакции
11
Mistrick, Спасибо. Проблему решил добавив pev(id, pev_origin, fOrigin);
Хотя до этого 5 часов старался пофиксить перетаскивая код по сотню раз с другого плагина :D
 
Сообщения
459
Реакции
272
Помог
9 раз(а)
wopox1337,
Код:
- TrieSetCell(g_tClasses, CLASSES, 0);
+ TrieSetCell(g_tClasses, CLASSES[i], 0);
Хорошая задумка, с вашего позволения, слеплю что нибудь с этого)
 
Последнее редактирование:
Сообщения
59
Реакции
28
Помог
1 раз(а)
Баг:
На некоторых картах оружие выдается, а не поднимается, соответственно, если будет режим, в котором кт запрещено оружие, все равно его можно будет получить.

Я пофиксил через Ham_Item_AddToPlayer
 
Сообщения
53
Реакции
13
Помог
2 раз(а)
Mistrick, в режиме рембо так и задумано что бы у кт были видны ножи и пистолеты?
 
Сообщения
43
Реакции
7
Mistrick, при выходе последнего терориста выбирается рандомный игрок место него , и у вас здесь возникает баг: цикл может выбрать рандомно индекс того же терориста который покидает игру, и соответственно в игре не остается терориста.
Код:
public client_disconnected(id)
{
    if(id != g_iTerrorist) {
        return;
    }
   
    new players[32], pnum;
    pnum = _get_players(players, true);
   
    if(pnum >= 2) {
        new Float:fOrigin[3]; pev(id, pev_origin, fOrigin);
        g_iTerrorist = players[random(pnum)];
        cs_set_user_team(g_iTerrorist, CS_TEAM_T);
        ExecuteHamB(Ham_CS_RoundRespawn, g_iTerrorist);
        engfunc(EngFunc_SetOrigin, g_iTerrorist, fOrigin);
       
        ExecuteForward(g_iForwards[NEW_TERRORIST], g_iReturn, g_iTerrorist);
       
        new name[32]; get_user_name(g_iTerrorist, name, charsmax(name));
        new leaver[32]; get_user_name(id, leaver, charsmax(leaver));
        client_print_color(0, print_team_red, "%s %L", PREFIX, LANG_PLAYER, "DRC_TERRORIST_LEFT", leaver, name);
    } else {
        set_num(RESTART, 5);
    }
}
может как то так ?
Код:
    while( ( g_iTerrorist = players[random(pnum)] ) == id )
 
Сообщения
43
Реакции
7
Mistrick, разобрался, пардон
Код:
stock _get_players(players[32], bool:alive = false)
{
    new CsTeams:team, count;
    for(new i = 1; i <= g_iMaxPlayers; i++) {
        if(i == g_iTerrorist || !is_user_connected(i) || alive && !is_user_alive(i)) {
            continue;
        }
 
Сообщения
35
Реакции
12
Помог
1 раз(а)
Обратите внимание, если вы хотите заключить сделку с этим пользователем, он заблокирован
На последней версии с гитхаба.


Код:
L 12/23/2020 - 16:22:15: String formatted incorrectly - parameter 9 (total 8)
L 12/23/2020 - 16:22:15: [AMXX] Displaying debug trace (plugin "deathrun_modes.amxx", version "1.1.0")
L 12/23/2020 - 16:22:15: [AMXX] Run time error 25: parameter error
L 12/23/2020 - 16:22:15: [AMXX]    [0] deathrun_modes.sma::modes_menu__handler (line 447)

Код:
#include <amxmodx>
#include <cstrike>
#include <fakemeta_util>
#include <hamsandwich>
#include <deathrun_modes>
#include <fun>

#if AMXX_VERSION_NUM < 183
#include <colorchat>
#define client_disconnected client_disconnect
#endif

#define PLUGIN "Deathrun: Modes"
#define VERSION "1.1.0"
#define AUTHOR "Mistrick"

#pragma semicolon 1

// TODO: move to cvars
#define DEFAULT_BHOP 1
#define DEFAULT_USP 1
#define TIMER 15

#define IsPlayer(%1) (%1 && %1 <= g_iMaxPlayers)
#define CHECK_FLAGS(%1) (g_eCurModeInfo[m_Flags] & %1)

enum (+=100) {
    TASK_SHOWMENU = 100
};

#define NONE_MODE -1

new const PREFIX[] = "^4[DRM]";

new Array:g_aModes, g_iModesNum;

new g_eCurModeInfo[ModeData];
new g_iCurMode = NONE_MODE;
new g_iMaxPlayers;

new g_iPage[33], g_iTimer[33], bool:g_bBhop[33];

enum Forwards {
    SELECTED_MODE,
    CHANGED_BHOP
};

new g_hForwards[Forwards], g_fwReturn;

new g_hMenuDisableItem;

public plugin_init()
{
    register_plugin(PLUGIN, VERSION, AUTHOR);
    
    register_cvar("deathrun_modes_version", VERSION, FCVAR_SERVER | FCVAR_SPONLY);
    
    register_clcmd("say /bhop", "Command_Bhop");
    
    RegisterHam(Ham_Spawn, "player", "ham_player_spawn_post", 1);
    RegisterHam(Ham_Touch, "weaponbox", "ham_touch_items_pre", 0);
    RegisterHam(Ham_Touch, "armoury_entity", "ham_touch_items_pre", 0);
    RegisterHam(Ham_Touch, "weapon_shield", "ham_touch_items_pre", 0);
    RegisterHam(Ham_Use, "func_button", "ham_use_buttons_pre", 0);
    RegisterHam(Ham_Player_Jump, "player", "ham_player_jump_pre", 0);
    
    register_event("HLTV", "event__new_round", "a", "1=0", "2=0");
    register_event("TextMsg", "event__restart", "a", "2=#Game_Commencing", "2=#Game_will_restart_in");
    
    register_menucmd(register_menuid("ModesMenu"), 1023, "modes_menu__handler");
    
    g_hForwards[SELECTED_MODE] = CreateMultiForward("dr_selected_mode", ET_IGNORE, FP_CELL, FP_CELL);
    g_hForwards[CHANGED_BHOP] = CreateMultiForward("dr_changed_bhop", ET_IGNORE, FP_CELL, FP_CELL);

    g_hMenuDisableItem = menu_makecallback("menu_disable_item");
    g_iMaxPlayers = get_maxplayers();
    
    g_eCurModeInfo[m_Name] = "DRM_MODE_NONE";
    g_eCurModeInfo[m_Flags] = (ModeFlags:DEFAULT_BHOP * DRM_ALLOW_BHOP) | (ModeFlags:DEFAULT_USP * DRM_GIVE_USP);
}
public plugin_cfg()
{
    register_dictionary("deathrun_modes.txt");
}
public plugin_natives()
{
    g_aModes = ArrayCreate(ModeData);
    
    register_library("deathrun_modes");
    register_native("dr_register_mode", "native_register_mode");
    register_native("dr_set_mode", "native_set_mode");
    register_native("dr_get_mode", "native_get_mode");
    register_native("dr_get_mode_by_mark", "native_get_mode_by_mark");
    register_native("dr_get_mode_info", "native_get_mode_info");
    register_native("dr_set_mode_bhop", "native_set_mode_bhop");
    register_native("dr_get_mode_bhop", "native_get_mode_bhop");
    register_native("dr_set_user_bhop", "native_set_user_bhop");
    register_native("dr_get_user_bhop", "native_get_user_bhop");
}
public native_register_mode(plugin, params)
{
    enum {
        arg_name = 1,
        arg_mark,
        arg_round_delay,
        arg_flags
    };
    
    new mode_info[ModeData];
    
    get_string(arg_name, mode_info[m_Name], charsmax(mode_info[m_Name]));
    get_string(arg_mark, mode_info[m_Mark], charsmax(mode_info[m_Mark]));
    mode_info[m_RoundDelay] = get_param(arg_round_delay);
    mode_info[m_Flags] = ModeFlags:get_param(arg_flags);
    
    ArrayPushArray(g_aModes, mode_info);
    g_iModesNum++;
    
    return g_iModesNum;
}
public native_set_mode(plugin, params)
{
    enum {
        arg_mode_index = 1,
        arg_forward,
        arg_player_id
    };
    
    new mode_index = get_param(arg_mode_index) - 1;
    
    if(mode_index < 0 || mode_index >= g_iModesNum) {
        log_error(AMX_ERR_NATIVE, "[DRM] Set mode: wrong mode index! index %d", mode_index + 1);
        return 0;
    }
    
    g_iCurMode = mode_index;
    ArrayGetArray(g_aModes, mode_index, g_eCurModeInfo);
    
    if(g_eCurModeInfo[m_RoundDelay]) {
        g_eCurModeInfo[m_CurDelay] = g_eCurModeInfo[m_RoundDelay] + 1;
        ArraySetArray(g_aModes, mode_index, g_eCurModeInfo);
    }
    
    if(get_param(arg_forward)) {
        ExecuteForward(g_hForwards[SELECTED_MODE], g_fwReturn, get_param(arg_player_id), mode_index + 1);
    }
    
    return 1;
}
public native_get_mode(plugin, params)
{
    enum {
        arg_name = 1,
        arg_size
    };
    
    new size = get_param(arg_size);
    
    if(size > 0) {
        set_string(arg_name, g_eCurModeInfo[m_Name], size);
    }
    
    return g_iCurMode + 1;
}
public native_get_mode_by_mark(plugin, params)
{
    enum { arg_mark = 1 };
    
    new mark[16];
    get_string(arg_mark, mark, charsmax(mark));
    
    for(new mode_index, mode_info[ModeData]; mode_index < g_iModesNum; mode_index++) {
        ArrayGetArray(g_aModes, mode_index, mode_info);
        if(equali(mark, mode_info[m_Mark])) {
            return mode_index + 1;
        }
    }
    
    return 0;
}
public native_get_mode_info(plugin, params)
{
    enum {
        arg_mode_index = 1,
        arg_info
    };
    
    new mode_index = get_param(arg_mode_index) - 1;
    
    if(mode_index < 0 || mode_index >= g_iModesNum) {
        log_error(AMX_ERR_NATIVE, "[DRM] Get mode info: wrong mode index! index %d", mode_index + 1);
        return 0;
    }
    
    new mode_info[ModeData]; ArrayGetArray(g_aModes, mode_index, mode_info);
    set_array(arg_info, mode_info, ModeData);
    
    return 1;
}
public native_set_mode_bhop(plugin, params)
{
    enum { arg_mode_bhop = 1 };
    
    if(get_param(arg_mode_bhop)) {
        g_eCurModeInfo[m_Flags] |= DRM_ALLOW_BHOP;
    } else {
        g_eCurModeInfo[m_Flags] &= ~DRM_ALLOW_BHOP;
    }
}
public native_get_mode_bhop(plugin, params)
{
    return _:CHECK_FLAGS(DRM_ALLOW_BHOP);
}
public native_set_user_bhop(plugin, params)
{
    enum {
        arg_player_id = 1,
        arg_bhop
    };
    
    new player = get_param(arg_player_id);
    
    if(player < 1 || player > g_iMaxPlayers) {
        log_error(AMX_ERR_NATIVE, "[DRM] Set user bhop: wrong player index! index %d", player);
        return 0;
    }
    
    g_bBhop[player] = get_param(arg_bhop) ? true : false;

    ExecuteForward(g_hForwards[CHANGED_BHOP], g_fwReturn, player, g_bBhop[player]);
    
    return 1;
}
public bool:native_get_user_bhop(id)
{
    enum { arg_player_id = 1 };
    
    new player = get_param(arg_player_id);
    
    if(player < 1 || player > g_iMaxPlayers) {
        log_error(AMX_ERR_NATIVE, "[DRM] Get user bhop: wrong player index! index %d", player);
        return false;
    }
    
    return CHECK_FLAGS(DRM_ALLOW_BHOP) && g_bBhop[player];
}
public client_putinserver(id)
{
    g_bBhop[id] = true;
}
public client_disconnected(id)
{
    remove_task(id + TASK_SHOWMENU);
}
public Command_Bhop(id)
{
    if(!CHECK_FLAGS(DRM_ALLOW_BHOP)) return PLUGIN_CONTINUE;
    
    g_bBhop[id] = !g_bBhop[id];
    client_print_color(id, print_team_default, "%s^1 %L", PREFIX, id, "DRM_BHOP_MSG", id, g_bBhop[id] ? "DRM_ENABLED" : "DRM_DISABLED");

    ExecuteForward(g_hForwards[CHANGED_BHOP], g_fwReturn, id, g_bBhop[id]);
    
    return PLUGIN_CONTINUE;
}
//***** Events *****//
public event__new_round()
{
    g_iCurMode = NONE_MODE;
    g_eCurModeInfo[m_Name] = "DRM_MODE_NONE";
    g_eCurModeInfo[m_Flags] = (ModeFlags:DEFAULT_BHOP * DRM_ALLOW_BHOP) | (ModeFlags:DEFAULT_USP * DRM_GIVE_USP);

    new mode_info[ModeData];
    for(new i = 0; i < g_iModesNum; i++) {
        ArrayGetArray(g_aModes, i, mode_info);
        if(mode_info[m_CurDelay]) {
            mode_info[m_CurDelay]--;
            ArraySetArray(g_aModes, i, mode_info);
        }
    }

    ExecuteForward(g_hForwards[SELECTED_MODE], g_fwReturn, 0, g_iCurMode + 1);

    for(new id = 1; id <= g_iMaxPlayers; id++) {
        remove_task(id + TASK_SHOWMENU);
    }
}
public event__restart()
{
    new mode_info[ModeData];
    for(new i = 0; i < g_iModesNum; i++) {
        ArrayGetArray(g_aModes, i, mode_info);
        mode_info[m_CurDelay] = 0;
        ArraySetArray(g_aModes, i, mode_info);
    }
}
//***** Ham *****//
public ham_player_jump_pre(id)
{
    if(!CHECK_FLAGS(DRM_ALLOW_BHOP) || !g_bBhop[id]) {
        return HAM_IGNORED;
    }

    new flags = pev(id, pev_flags);
    
    if(flags & FL_WATERJUMP || pev(id, pev_waterlevel) >= 2 || !(flags & FL_ONGROUND)) {
        return HAM_IGNORED;
    }

    new Float:velocity[3];
    
    pev(id, pev_velocity, velocity);
    
    velocity[2] = 250.0;
    
    set_pev(id, pev_velocity, velocity);
    set_pev(id, pev_gaitsequence, 6);
    set_pev(id, pev_fuser2, 0.0);
    
    return HAM_IGNORED;
}
public ham_use_buttons_pre(ent, caller, activator, use_type)
{
    if(!IsPlayer(activator)) {
        return HAM_IGNORED;
    }
    
    new CsTeams:team = cs_get_user_team(activator);
    
    if(team == CS_TEAM_T && CHECK_FLAGS(DRM_BLOCK_T_BUTTONS)
        || team == CS_TEAM_CT && CHECK_FLAGS(DRM_BLOCK_CT_BUTTONS)) {
        return HAM_SUPERCEDE;
    }
    
    return HAM_IGNORED;
}
public ham_touch_items_pre(ent, id)
{
    if(!IsPlayer(id) || g_iCurMode == NONE_MODE) {
        return HAM_IGNORED;
    }
    
    new CsTeams:team = cs_get_user_team(id);
    
    if(team == CS_TEAM_T && CHECK_FLAGS(DRM_BLOCK_T_WEAPON)
        || team == CS_TEAM_CT && CHECK_FLAGS(DRM_BLOCK_CT_WEAPON)) {
        return HAM_SUPERCEDE;
    }
    
    return HAM_IGNORED;
}
public ham_player_spawn_post(id)
{
    if(!is_user_alive(id)) {
        return HAM_IGNORED;
    }
    
    set_user_rendering(id);
    
    new CsTeams:team = cs_get_user_team(id);
    
    if(CHECK_FLAGS(DRM_GIVE_USP) && team == CS_TEAM_CT) {
        give_item(id, "weapon_usp");
        cs_set_user_bpammo(id, CSW_USP, 100);
    }
    
    if(g_iCurMode != NONE_MODE || team != CS_TEAM_T) {
        return HAM_IGNORED;
    }

    g_iTimer[id] = TIMER + 1;
    g_iPage[id] = 0;
    task__menu_timer(id + TASK_SHOWMENU);
    
    return HAM_IGNORED;
}
public show__modes_menu(id)
{
    new text[80];
    formatex(text, charsmax(text), "%L^n^n%L ", id, "DRM_MENU_SELECT_MODE", id, "DRM_MENU_TIMELEFT", g_iTimer[id]);
    new menu = menu_create(text, "modes_menu__handler");
    
    new mode_info[ModeData];
    for(new i, item[2], len; i < g_iModesNum; i++) {
        ArrayGetArray(g_aModes, i, mode_info);
        
        if(mode_info[m_Flags] & DRM_HIDE) {
            continue;
        }
        
        if(GetLangTransKey(mode_info[m_Name]) != TransKey_Bad) {
            len = formatex(text, charsmax(text), "%L", id, mode_info[m_Name]);
        } else {
            len = formatex(text, charsmax(text), "%s", mode_info[m_Name]);
        }
        
        if(mode_info[m_CurDelay] > 0) {
            formatex(text[len], charsmax(text) - len, "[\r%d\d]", mode_info[m_CurDelay]);
        }
        
        item[0] = i;
        
        menu_additem(menu, text, item, 0, mode_info[m_CurDelay] ? g_hMenuDisableItem : -1);
    }
    
    formatex(text, charsmax(text), "%L", id, "DRM_MENU_BACK");
    menu_setprop(menu, MPROP_BACKNAME, text);
    formatex(text, charsmax(text), "%L", id, "DRM_MENU_NEXT");
    menu_setprop(menu, MPROP_NEXTNAME, text);
    
    menu_setprop(menu, MPROP_EXIT, MEXIT_NEVER);
    
    new _menu, _newmenu, _menupage;
    player_menu_info(id, _menu, _newmenu, _menupage);
    
    new page = (_newmenu != -1 && menu_items(menu) == menu_items(_newmenu)) ? _menupage : 0;
    menu_display(id, menu, page);
    
    return PLUGIN_HANDLED;
}
public modes_menu__handler(id, menu, item)
{
    if(item == MENU_EXIT || g_iCurMode != NONE_MODE || cs_get_user_team(id) != CS_TEAM_T) {
        menu_destroy(menu);
        return PLUGIN_HANDLED;
    }
    
    new info[2], stuff;
    menu_item_getinfo(menu, item, stuff, info, charsmax(info), _, _, stuff);
    
    new mode = info[0];
    g_iCurMode = mode;
    
    ArrayGetArray(g_aModes, mode, g_eCurModeInfo);
    
    if(g_eCurModeInfo[m_RoundDelay]) {
        g_eCurModeInfo[m_CurDelay] = g_eCurModeInfo[m_RoundDelay] + 1;
        ArraySetArray(g_aModes, mode, g_eCurModeInfo);
    }
    
    check_usp();
    
    remove_task(id + TASK_SHOWMENU);
    ExecuteForward(g_hForwards[SELECTED_MODE], g_fwReturn, id, mode + 1);

    if(GetLangTransKey(g_eCurModeInfo[m_Name]) != TransKey_Bad) {
        client_print_color(0, print_team_red, "%s %L^4 %L^1.", PREFIX, LANG_PLAYER, "DRM_SELECTED_MODE", LANG_PLAYER, g_eCurModeInfo[m_Name]);
    } else {
        client_print_color(0, print_team_red, "%s %L^4 %s^1.", PREFIX, LANG_PLAYER, "DRM_SELECTED_MODE", g_eCurModeInfo[m_Name]);
    }
    
    menu_destroy(menu);
    return PLUGIN_HANDLED;
}
public menu_disable_item(id, menu, item)
{
    return ITEM_DISABLED;
}
public task__menu_timer(id)
{
    id -= TASK_SHOWMENU;
    
    if(g_iCurMode != NONE_MODE || !is_user_alive(id) || cs_get_user_team(id) != CS_TEAM_T) {
        show_menu(id, 0, "^n");
        return;
    }
    if(--g_iTimer[id] <= 0) {
        show_menu(id, 0, "^n");
        
        new mode;
        
        if(!is_all_modes_blocked()) {
            do {
                mode = random(g_iModesNum);
                ArrayGetArray(g_aModes, mode, g_eCurModeInfo);
            } while(g_eCurModeInfo[m_CurDelay] || CHECK_FLAGS(DRM_HIDE));
        } else {
            do {
                mode = random(g_iModesNum);
                ArrayGetArray(g_aModes, mode, g_eCurModeInfo);
            } while(CHECK_FLAGS(DRM_HIDE));
        }
        
        g_iCurMode = mode;
        
        if(g_eCurModeInfo[m_RoundDelay]) {
            g_eCurModeInfo[m_CurDelay] = g_eCurModeInfo[m_RoundDelay] + 1;
            ArraySetArray(g_aModes, mode, g_eCurModeInfo);
        }
        
        check_usp();
        
        ExecuteForward(g_hForwards[SELECTED_MODE], g_fwReturn, id, mode + 1);
        
        if(GetLangTransKey(g_eCurModeInfo[m_Name]) != TransKey_Bad) {
            client_print_color(0, print_team_red, "%s %L^4 %L^1.", PREFIX, LANG_PLAYER, "DRM_RANDOM_MODE", LANG_PLAYER, g_eCurModeInfo[m_Name]);
        } else {
            client_print_color(0, print_team_red, "%s %L^4 %s^1.", PREFIX, LANG_PLAYER, "DRM_RANDOM_MODE", g_eCurModeInfo[m_Name]);
        }
    } else {
        show__modes_menu(id);
        set_task(1.0, "task__menu_timer", id + TASK_SHOWMENU);
    }
}
check_usp()
{
    #if DEFAULT_USP < 1
    if(CHECK_FLAGS(DRM_GIVE_USP)) {
        new player, players[32], pnum;
        get_players(players, pnum, "ae", "CT");
        for(new i = 0; i < pnum; i++) {
            player = players[i];
            give_item(player, "weapon_usp");
            cs_set_user_bpammo(player, CSW_USP, 100);
        }
    }
    #else
    if(!CHECK_FLAGS(DRM_GIVE_USP)) {
        new player, players[32], pnum;
        get_players(players, pnum, "ae", "CT");
        for(new i = 0; i < pnum; i++) {
            player = players[i];
            fm_strip_user_gun(player, CSW_USP);
        }
    }
    #endif
}

bool:is_all_modes_blocked()
{
    new mode_info[ModeData];
    for(new i; i < g_iModesNum; i++) {
        ArrayGetArray(g_aModes, i, mode_info);
        if(!mode_info[m_CurDelay] && !(mode_info[m_Flags] & DRM_HIDE)) return false;
    }
    return true;
}
 
Последнее редактирование:
Сообщения
35
Реакции
12
Помог
1 раз(а)
Обратите внимание, если вы хотите заключить сделку с этим пользователем, он заблокирован
Mistrick, там вроде все с архива перезалил. Извиняюсь, сейчас перепроверю,
 
Сообщения
68
Реакции
8
Помог
2 раз(а)
Обратите внимание, если вы хотите заключить сделку с этим пользователем, он заблокирован
Можно пожалуйста описание режима mode_skillmaster
 
Сообщения
584
Реакции
1,006
Помог
18 раз(а)
TrapManiak, у тера 3 абилки на кнопках перезарядки, фонарика и дропа оружия. Одна останавливает всех КТ, вторая поджигает нанося урон, третья делает слап(тычок со смешением направления движения). Должны мешать проходить карту. Балансом не занимался, особо имбовым режимом для тера не считаю.
 

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

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