Библиотека, которая позволяет добавлять общее событие "юнит получает урон":
cJass
library UnitDamaged initializer InitRect {
    #include "cj_types_priv.j"

    private group   allUnits;
    private region  mapArea;
    private trigger Trigger[];
    private int     TrigsNum = 0;

    private void unitDamagedEvent() {
        TriggerRegisterUnitEvent(Trigger[TrigsNum], GetEnumUnit(), EVENT_UNIT_DAMAGED);
    }

    void AnyUnitDamagedEvent(trigger toTrigger) {
        Trigger[TrigsNum] = toTrigger;
        ForGroup(allUnits, function unitDamagedEvent);
        TrigsNum++;
    }

    private void onUnitSpawn() {
        for (int i = 0; i < TrigsNum; i++) {
            TriggerRegisterUnitEvent(Trigger[i], GetEnteringUnit(), EVENT_UNIT_DAMAGED);
        }
        GroupAddUnit(allUnits, GetEnteringUnit());
    }

    private void onUnitDecay() {
        GroupRemoveUnit(allUnits, GetDecayingUnit());
    }

    private void InitRect() {
        trigger onSpawn = CreateTrigger();
        trigger onDecay = CreateTrigger();
        allUnits = CreateGroup();
        mapArea = CreateRegion();
        GroupEnumUnitsInRect(allUnits, GetWorldBounds(), null);
        RegionAddRect(mapArea, GetWorldBounds());
        TriggerRegisterEnterRegion(onSpawn, mapArea, null);
        for (int i = 0; i < bj_MAX_PLAYER_SLOTS; i++) {
            TriggerRegisterPlayerUnitEvent(onDecay, Player(i), EVENT_PLAYER_UNIT_DECAY, null);
        }
        TriggerAddAction(onSpawn, function onUnitSpawn);
        TriggerAddAction(onDecay, function onUnitDecay);
    }
}
vJass
library UnitDamaged initializer initRect
    globals
        private group   allUnits
        private region  mapArea
        private trigger Trigger[]
        private integer TrigsNum = 0
    endglobals

    private function unitDamagedEvent takes nothing returns nothing
        call TriggerRegisterUnitEvent(Trigger[TrigsNum], GetEnumUnit(), EVENT_UNIT_DAMAGED)
    endfunction

    function AnyUnitDamagedEvent takes trigger toTrigger returns nothing
        set Trigger[TrigsNum] = toTrigger
        call ForGroup(allUnits, function unitDamagedEvent)
        set TrigsNum = TrigsNum + 1
    endfunction

    private function onUnitSpawn takes nothing returns nothing
        local integer i = 0
        loop
            exitwhen (i == TrigsNum)
            call TriggerRegisterUnitEvent(Trigger[i], GetEnteringUnit(), EVENT_UNIT_DAMAGED)
            set i = i + 1
        endloop
        call GroupAddUnit(allUnits, GetEnteringUnit())
    endfunction

    private function onUnitDecay takes nothing returns nothing
        call GroupRemoveUnit(allUnits, GetDecayingUnit())
    endfunction

    private function initRect takes nothing returns nothing
        local integer i = 0
        local trigger onSpawn = CreateTrigger()
        local trigger onDecay = CreateTrigger()
        set allUnits = CreateGroup()
        set mapArea = CreateRegion()
        call GroupEnumUnitsInRect(allUnits, GetWorldBounds(), null)
        call RegionAddRect(mapArea, GetWorldBounds())
        call TriggerRegisterEnterRegion(onSpawn, mapArea, null)
        loop
            exitwhen (i == bj_MAX_PLAYER_SLOTS)
            call TriggerRegisterPlayerUnitEvent(onDecay, Player(i), EVENT_PLAYER_UNIT_DECAY, null)
            set i = i + 1
        endloop
        call TriggerAddAction(onSpawn, function onUnitSpawn)
        call TriggerAddAction(onDecay, function onUnitDecay)
    endfunction
endlibrary

Добавление события:
    call AnyUnitDamagedEvent(subscribingTrigger)

Источник урона (атаковавший юнит):
GetEventDamageSource()
Цель урона (атакованный юнит):
GetTriggerUnit() 
Величина нанесённого урона:
GetEventDamage()

Установка: скопировать в Нестандартный Код Карты, дальнейших действий не требуется.

Ограничения:
  • Нельзя использовать с динамичными триггерами
  • Нельзя использовать более, чем с JASS_MAX_ARRAY_SIZE триггеров
`
ОЖИДАНИЕ РЕКЛАМЫ...

Показан только небольшой набор комментариев вокруг указанного. Перейти к актуальным.
24
А зачем вообще TriggerResgister ? сделайте класс, наследуйтесь от него и передавайте системе
Затем что у нас тут СОП, а не ООП.
Clamp:
Хотя в целом не лучше и не хуже.
Лол. Объясняю для особо одаренных, почему твой код - уг.
Берем из твоей либы:
AnyUnitDamagedEvent(trigger trg)
И регистрируем 100, опустим тот факт, что нефига не зарегистрируется, если на карте много юнитов, ну а далее, мы уничтожаем 99 триггеров(ты же не думал что они будут все статичными, лол).
И смотрим сюда:
private void Adder()
    {
        int i = 0
        loop
        {
            TriggerRegisterUnitEvent(Trigger[i],GetEnteringUnit(),EVENT_UNIT_DAMAGED)
            exitwhen i==TrigsNum
            i++
        }
        GroupAddUnit(Group,GetEnteringUnit())
    }
Лол. Конечно же моя система ничем не лучше :D
Для самых одаренных из одаренных поясняю, в твоей системе еще нужно писать метод для удаления твоей костыльной регистрации ._.
30
  1. события нельзя удалять
  2. каждое событие существует в единственном экземпляре и имеет ряд ссылок на завязанные на нём триггеры.
  3. количество ссылок на удалённые триггеры никаким образом не влияет на производительность карты и затрачиваемый ею объем оперативной памяти.
Вывод: нет никакой необходимости эти ссылки чистить.
Заметка: аргумент про перманентность событий для каждого динамичного триггера появился только что, а сообщил ты о нём так, как будто уже три дня только об этом и говоришь.
Дополнение: твоя регистрация не менее костыльная ввиду того, что у тебя тоже нельзя её удалить.
P.S.: дискуссия с тобой неприятна ввиду твоей речевой стилистики, низкой грамотности, открытого неуважения к оппоненту и того, что ты не скрываешь, что это неуважение вызвано самим фактом того, что он является твоим оппонентом. Также твоё общение выглядит так, будто ты страдаешь нарциссизмом, однако при этом готов вылизывать обувь людям, от которых зависишь, что является типичным признаком низкой самооценки и вызывает следствие в виде попыток самоутвердиться на тех, кто заведомо слабее тебя в теме дискуссии, и даже при этом ты умудряешься опускаться до переходов на личности и повторов отбитых аргументационных суждений.
P.P.S.: дальнейшие твои сообщения с речевыми конструкциями вида "твоё ... - убогое" или "моё ... лучше по факту того, что оно лучше" будут просто игнорироваться, а в случаях, где будет отсутствовать иное содержание - удаляться.

и да, на все динамичные спелы типа "юнит получит х2 от полученного урона" нормальные люди используют один единственный триггер.

я предупреждал, а за офтоп так ещё и пункты полагаются.
2 комментария удалено
24
private void Adder()
    {
        int i = 0
        loop
        {
            TriggerRegisterUnitEvent(Trigger[i],GetEnteringUnit(),EVENT_UNIT_DAMAGED)
            exitwhen i==TrigsNum
            i++
        }
        GroupAddUnit(Group,GetEnteringUnit())
    }
Это фейл! и не оффтоп. лол.
24
Легко.
Пусть TrigsNum = 100500 (или как минимум > JASS_MAX). Дальше ясно, или нужна помощь кэпа?
for(int i = 0; i < 50; i++)
{
   AnyUnitDamagedEvent(CreateTrigger())
}
При условии что на карте овер 1к юнитов.
Дальше ясно, или нужна помощь кэпа?
30
Если Вы умудрились создать over9000 триггеров с событием на получение урона, то проблемы с переполнением массива будут интересовать Вас в последнюю очередь. Кроме того, vJass эмулирует увеличенный размер массива, в результате чего для переполнения придётся создать больше 64 миллионов триггеров. В дополнение к этому замечу, что я не могу даже представить ситуацию, при которой понадобится одновременно создавать 50 триггеров, использующих одно и тоже событие.
24
Кроме того, vJass эмулирует увеличенный размер массива
Что то я не вижу тут эмуляции :|
больше 64 миллионов триггеров.
409550 триггеров. fxd*
Если Вы умудрились создать over9000 триггеров с событием на получение урона...
for(int i = 0; i < 9000; ;i++)
{
  trigger t = CreateTrigger()
  AnyUnitDamagedEvent(t)
  DestroyTrigger(t)
  t = null;
}
то проблемы с переполнением массива будут интересовать Вас в последнюю очередь.
Только в случае использование Вашей наработки.
30
for(int i = 0; i < 9000; ;i++)
{
  trigger t = CreateTrigger()
  AnyUnitDamagedEvent(t)
  DestroyTrigger(t)
  t = null;
}
Под "умудрились создать" имеется в виду "создать триггеров для реализации каких-либо полезных действий", разумеется.
Показан только небольшой набор комментариев вокруг указанного. Перейти к актуальным.
Чтобы оставить комментарий, пожалуйста, войдите на сайт.