Spellpack Undying

>>Yeah, nvm.
It is not that I copy anyone else's idea. I am just following what DotA(Ice Frog) does.
 
nvm ahaha =/

i wanted to learn how to use structs from your map... but it seems u use ABC, which i dunno also... argh =/
 
**Bump** :p

>>i wanted to learn how to use structs from your map... but it seems u use ABC, which i dunno also... argh =/
They are just like handle vars.
In my situnation, my struct act like a large wrapper which wrap up every variable.

It is my routine to bump this now..
 
I think this should not be approved until you make raise dead as well
 
>>I think this should not be approved until you make raise dead as well
I didn't said I wanted to submit a DotA hero.
I just wanted to submit spell pack, why does it have matter to the Raise Dead?
 
Because it is natural for it to be there, and because you need to learn to finish what you started (education and stuff...)

EDIT:
JASS:
private function tAct takes nothing returns nothing
local timer t = GetExpiredTimer()
local Soul_Rip SR = GetTimerStructA(t)

    call ClearTimerStructA(t)
    call SR.destroy()
    
call DestroyTimer(t)
set t = null
endfunction


JASS:
private function tAct takes nothing returns nothing
local timer t = GetExpiredTimer()
local Soul_Rip SR = ClearTimerStructA(t) // <---- small trick

    call SR.destroy()
    
call DestroyTimer(t)
set t = null
endfunction


JASS:
    method onDestroy takes nothing returns nothing
    set .caster = null
    set .target = null
    call DestroyTrigger(.Infect)
    call DestroyTrigger(.Amplify)
    call DestroyGroup(.reg)
    set .Infect = null
    set .Amplify = null
    set .reg = null
    endmethod


JASS:
    method onDestroy takes nothing returns nothing
    //set .caster = null   // Don't null struct members they are not locals.
    //set .target = null
    call DestroyTrigger(.Infect)
    call DestroyTrigger(.Amplify)
    call DestroyGroup(.reg)
    //set .Infect = null
    //set .Amplify = null
    //set .reg = null
    endmethod


Disabled versions of some of your icons are not showing properly.
Do you know why is this?

EDIT:
You are also using constant functions for ability codes instead of constant globals.
functions in spells are just for stuff that have level as parameter, for example:
JASS:
function AOE takes integer level returns real
    return 100. + level*200.
endfunction
 
>>@Cohadar
I already finished what you said currently, but I won't update now. I am making Raise Dead.

>>You don't need to trigger Raise Dead, base it off Summon Lava Spawn and change units and art.
Hmm, right. I am currently base off that spell. But, how do you do about the Heal 50 hitpoints thing?
I don't see there is an option for it, or am I blinded?
 
I stopped playing dota before that hero was added,
but if you describe what that rise dead does,
I am sure I could give a couple hints...
 
Just detect when the unit type of summoned unit died, create a unit to use fan of knive, with negative damage (for the healing) and cast it targeting own player unit.
 
Ok here is the PUI part:
JASS:
struct ZombieData
    unit hero // owner of zombie
    unit zombie
    integer counter // for attack six times thing
    private static ZombieData array PUI
    
    static method create takes unit hero, unit zombie returns ZombieData
        local ZombieData ret = ZombieData.allocate()
        set ret.hero = hero
        set ret.zombie = zombie
        set ret.counter = 0
        set ZombieData.PUI[GetUnitIndex(zombie)] = ret // zombie -> ZombieData link
        return ret
    endmethod
    
    static method Get takes unit zombie returns ZombieData
        return ZombieData.PUI[GetUnitIndex(zombie)]
    endmethod
    
    method onDestroy takes nothing returns nothing
        set ZombieData.PUI[GetUnitIndex(.zombie)] = 0 // break the link
    endmethod
endstruct


You register on attack trigger and if attacking unit is zombie you increase it's counter. if counter gets to 6 you raise a new zombie.

How do you keep track of number of zombies?
Well I will leave that as a homework ;)

EDIT: fixed some typos in code.
 
>>You register on attack trigger and if attacking unit is zombie you increase it's counter. if counter gets to 6 you raise a new zombie.
Sorry bro.
In DotA, it is registered in EVENT_UNIT_DAMAGED. The "S" bug won't work with this spell. So... I think that in DotA, this spell was base on Lava Spawn. (IceFrog loves to use original spell of Blizzard, right? ;))

The problem was the healing 50 hp thingy...
 
>>Irrelevant, you steel need ZombieData.
-.-lll
There is a missle effect that moving towards the Hero when a zombie die.
The +50 hp effect will only happen when the missle reach the Hero.


And, in the other hand... I need 3 trigger for 1 spell again..?
1. Your PUI. (PUI is an insult in chinese you know?)
2. Your ZombieData (You said everything need 1 trigger right?)
3. Main Trigger.

>>Simple as that.
You think so?
 
ZombieData is a struct not a trigger ffs, just put it in spells trigger.
Heal effect is a dummy caster death-coil or something like that.
So when zombie dies use dummy caster to cast 50 heal on hero.

I said every scope should have it's own trigger.


EDIT:
I just looked at lava spawn spell.
You were right, that is how IceFrog did it, the only problem is that if you use lava spawn ability spell will not be MUI (it will be only multi-player instancable)

So you basically need to do this:

Forget about ZombieData

Base Raise dead on summon lava spawns

JASS:
globals
    unit array Dirges  // connects player <-> dirge
endglobals


When Dirge casts a summon spell you do:
JASS:
function RaiseDeadActions takes nothing returns nothing
    set Dirges[GetPlayerId(GetOwningPlayer(GetTriggerUnit()))] = GetTriggerUnit()
endfunction


And when spawn dies:
JASS:
function ZombieDiesActions takes nothing returns nothing
    local unit zombie = GetTriggerUnit
    local unit hero = Dirges[GetPlayerId(GetOwningPlayer(zombie))]
    local real x = GetUnitX(zombie)
    local real y = GetUnitY(zombie)

    // Cast some heal magic on hero from the position of dying unit
endfunction
 
not bad, a few things however

Soul Rip:

  • should use a timer stack, CSSafety is common for people
  • could use a global group, and remove the need of creating and destroying/nulling each time
  • no need to make comparisons, just add a not in front of it
  • the group can grab the target itself....
  • do not need to null lightning varaible on destroying the struct
  • damage/unit should be level dependant
  • rest is good
Hearstopper

  • could use a global group, and remove the need of creating and destroying/nulling each time
  • rest is good

Plague:

  • infect range and duration should be level dependant
  • timer stack needed
  • could again use global groups
  • dont need to null structs variables
  • rest looks good

anyhow, needs some updates IMO

good job though
 
Ah, forgot about the healing while dead, but just create a dummy, give it an expiration timer and order it to cast death coil on Undying.
 
I have gone to some sort of camp, sorry for late reply.. I just came back today.

>>@Cohadar
Hmm, I see.

>>should use a timer stack, CSSafety is common for people
I used it before, but ABC gives alot debug messages to me.
After I change from NewTimer to CreateTimer, this fixed the debug warning.

>>could use a global group, and remove the need of creating and destroying/nulling each time
I see.

>>no need to make comparisons, just add a not in front of it
Hmm? not?
Using not in where..?

>>the group can grab the target itself....
Argh, I have forgoten in DotA, it has no including the caster itself.

>>do not need to null lightning varaible on destroying the struct
I see.

>>damage/unit should be level dependant
I'll see what I can do about it.
Actually, what is dependant means? I see boolean option in ObjectEditor says something like Independance or something alike.

>> * infect range and duration should be level dependant
* timer stack needed
* could again use global groups
* dont need to null structs variables
* rest looks good

oK!

>>Ah, forgot about the healing while dead, but just create a dummy, give it an expiration timer and order it to cast death coil on Undying.
The problem is... You don't know who is the caster of the zombie when the zombie dies.
 
General chit-chat
Help Users
  • No one is chatting at the moment.
  • Varine Varine:
    +1
  • Varine Varine:
    I've been really into this
  • Varine Varine:
    It's a musical retelling of The Odyssey
  • Varine Varine:
    Also if you want mixed drinks without alcohol, there's a handful of non-alcoholic 'spirits'. Ritual Zero and Free Spirit are the two brands I've tried and they are alright. They don't have a TON of options, but they have some gin and whiskey alternatives that are fun to play with.
  • Varine Varine:
    I got a couple bottles to make some mixy drinks around holidays when I mostly want to drink, they aren't exact replacements but they are surprisingly close.
  • Varine Varine:
    I ended up with some hop water things that I really like instead for when I want to feel like I'm participating
  • Varine Varine:
    I just got moved to unsupervised probation, so I can get away with drinking a bit now. I technically am not supposed to, but I don't think I get checked anymore. I really want to smoke weed but it scares me
  • The Helper The Helper:
    Happy Wednesday! I am not feeling it today, my teeth are bothering me, or the fragments that were left behind are coming up and it is extra painful today. Don't ever let them tell you that getting full dental implants is easy. They have to pull all your teeth to do those and apparently they are not very good at getting all the teeth out all the time.
    +1
  • The Helper The Helper:
    That is true with Dentures too. I am taking the day off and working from home. The big difference is though, I am not drinking anymore so I have a nice tea and coffee regimen set up :)
  • Varine Varine:
    I wish i had a 3D scanner
  • Varine Varine:
    That would make what I'm doing SO much easier
  • Varine Varine:
    I guess I could just take a picture of it and then use that as a reference. I have a circuit board with some weird holes I can't get measured right
  • Varine Varine:
    Oh I got a Klipper mod for my big printer! It comes with a bunch of parts and I don't totally understand what it does but apparently it's way better than Marlin, which is I think what it currently runs
    +1
  • The Helper The Helper:
    Nice!
  • Varine Varine:
    You're people in Florida safe? The only couple I know are safe but I think they evacuated.
  • The Helper The Helper:
    They are without power but safe. Flood damage and stuff alot of tornados hit east Florida. No fatalities or injuries to any of my people that I know of
  • The Helper The Helper:
    They have been through all the Florida hurricanes they are like me I have been through every texas hurricane for the last 50 years.
  • The Helper The Helper:
    Never evacuated.
  • The Helper The Helper:
    Check out this bad ass Chicken Noodle soup recipe - https://www.thehelper.net/threads/crack-chicken-noodle-soup.196687/
  • The Helper The Helper:
    Happy Saturday!
    +1

      The Helper Discord

      Staff online

      Members online

      Affiliates

      Hive Workshop NUON Dome World Editor Tutorials

      Network Sponsors

      Apex Steel Pipe - Buys and sells Steel Pipe.
      Top