Multi-Rendering System

Multi-Rendering System 0.3

Нет прав для скачивания
Сообщения
258
Реакции
262
Помог
5 раз(а)
Пользователь Subb98 разместил новый ресурс:

Multi-Rendering System - AMXX плагин для разрешения конфликтов при использовании *_rendering функций

Данный плагин призван исключить "конфликты" при работе с функциями типа set_user_rendering / set_rendering. Такие "конфликты" могут иметь место быть, когда два и более плагинов используют эти функции для одного игрока.


Принцип работы:
Функция add_user_rendering устанавливает модели указанного игрока режим визуализации, добавляет переданные аргументы в динамический (array) массив, присваивает установленному режиму уникальный индекс и возвращает его...
Узнать больше об этом ресурсе...
 
Сообщения
3,569
Реакции
1,560
Помог
133 раз(а)
Отличный плагин!

Выкладываю версию для ReAPI, если кто-то хочет использовать без Engine.

Код:
/* Multi-Rendering System 0.3 [06.05.2017]
 * thanks: PRoSToTeM@ for consultations
 * Edited for ReAPI by Nordic Warrior 04.04.2019 */

#pragma semicolon 1

#include <amxmodx>
#include <reapi>
#include <multirendering>

enum _:RENDERING_DATA {
    rd_r_index,
    rd_fx,
    rd_r,
    rd_g,
    rd_b,
    rd_render,
    rd_amount
}

new Array:g_data[MAX_PLAYERS + 1];

new g_maxplayers;

public plugin_natives() {
    register_native("add_user_rendering", "native_add_user_rendering");
    register_native("remove_user_rendering", "native_remove_user_rendering");
}

public plugin_init() {
    register_plugin("Multi-Rendering System", "[ReAPI] 0.3", "Subb98/Nordic Warrior");

    g_maxplayers = get_maxplayers();

    for(new i = 1; i <= g_maxplayers; i++) {
        g_data[i] = ArrayCreate(RENDERING_DATA);
    }
}

public client_putinserver(id) {
    if(!is_user_hltv(id)) {
        ArrayClear(g_data[id]);
    }
}

public plugin_end() {
    for(new i = 1; i <= g_maxplayers; i++) {
        ArrayDestroy(g_data[i]);
    }
}

public native_add_user_rendering() {
    new id = get_param(1);
    new r_index = get_param_byref(2);
    new data[RENDERING_DATA];

    if(r_index) {
        check_rendering(id, r_index, ArraySize(g_data[id]), data);
    }

    static unique_r_index;

    data[rd_fx] = get_param(3);
    data[rd_r] = get_param(4);
    data[rd_g] = get_param(5);
    data[rd_b] = get_param(6);
    data[rd_render] = get_param(7);
    data[rd_amount] = get_param(8);

    rg_set_rendering(id, data[rd_fx], data[rd_r], data[rd_g], data[rd_b], data[rd_render], data[rd_amount]);

    data[rd_r_index] = ++unique_r_index; // unique index number, autoincrement

    ArrayPushArray(g_data[id], data);
    set_param_byref(2, data[rd_r_index]);

    return data[rd_r_index];
}

public native_remove_user_rendering() {
    new id = get_param(1);
    new r_index = get_param_byref(2);
    new size = ArraySize(g_data[id]);
    new data[RENDERING_DATA];

    if(!check_rendering(id, r_index, size, data)) {
        return INVALID_HANDLE;
    }

    if(--size) {
        ArrayGetArray(g_data[id], size - 1, data);
        rg_set_rendering(id, data[rd_fx], data[rd_r], data[rd_g], data[rd_b], data[rd_render], data[rd_amount]);
    } else {
        rg_set_rendering(id);
    }

    set_param_byref(2, R_INDEX_NULL);

    return R_INDEX_NULL;
}

stock rg_set_rendering(const index, fx=kRenderFxNone, r=255, g=255, b=255, render=kRenderNormal, amount=16)
{
    set_entvar(index, var_renderfx, fx);

    new Float:RenderColor[3];
    RenderColor[0] = float(r);
    RenderColor[1] = float(g);
    RenderColor[2] = float(b);

    set_entvar(index, var_rendercolor, RenderColor);
    set_entvar(index, var_rendermode, render);
    set_entvar(index, var_renderamt, float(amount));

    return 1;
}

bool:check_rendering(const id, const r_index, const size, data[]) {
    for(new i; i < size; i++) {
        ArrayGetArray(g_data[id], i, data);

        if(data[rd_r_index] == r_index) {
            ArrayDeleteItem(g_data[id], i);
            return true;
        }
    }

    return false;
}
 

Вложения

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

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