if ability is ultimate?

XeNiM666

I lurk for pizza
Reaction score
138
well simple question...
how would i know/set if an ability is an ultimate? :)
 

Ayanami

칼리
Reaction score
288
Hmm, how about storing the ability in a variable array, and looping through the variables to check if it's an ultimate :p Could be inefficient though.

Or maybe, you could store a boolean in a hashtable with the parent key set as the ability raw code.
 

Weep

Godspeed to the sound of the pounding
Reaction score
400
If it is a hero spell and its minimum required level is higher than 1, WC3 considers it an "ultimate", with a few exceptions (eg. Phoenix Fire).
 

KaerfNomekop

Swim, fishies. Swim through the veil of steel.
Reaction score
613
If it is a hero spell and its minimum required level is higher than 1, WC3 considers it an "ultimate", with a few exceptions (eg. Phoenix Fire).

Is Phoenix Fire an ultimate? It's not even a hero ability.
 

Weep

Godspeed to the sound of the pounding
Reaction score
400
Is Phoenix Fire an ultimate? It's not even a hero ability.
No. What I mean is that even if you edit its settings to fit the profile of an "ultimate", it still won't target spell immune units even if the gameplay constants are set to allow ultimates to do so.
 

luorax

Invasion in Duskwood
Reaction score
67
Well, with a simple JASS function and a custom script we can do it:

1, You'll have to add some simple letters to your ulti's end: " (U)" (e.g. "Avatar" >> "Avatar (U)")
2, Copy my function to your map's header
3, To test whether an ability is ulti or not, just call that function.

Function:
JASS:
function IsAbilityUltimate takes integer id returns boolean
    local string s = GetObjectName(id)
    return SubString(s, StringLength(s)-4, StringLength(s)) == " (U)"
endfunction


Usage:

JASS:
if IsAbilityUltimate('A006') then
        call BJDebugMsg("ULTI")
    else
        call BJDebugMsg("NOT ULTI")
    endif


Hope I helped you :D

Note that you have to rename the function not the tooltip. The name is invisible for the players, so we can do with it whatever we would like to.
 

DioD

New Member
Reaction score
57
not really smart way to change name of every skill, when you simply can make database with skills you need.
 

luorax

Invasion in Duskwood
Reaction score
67
Yes, but takes about 2 mins to edit them, and will work faster in-game.
 

meOme

New Member
Reaction score
31
I would do it like this:
JASS:
function IsAbilityUltimate takes integer id returns boolean
    return ( id == 'A001' or id == 'A002' or id == 'A003' or id == 'A004' or id == 'A005' )
endfunction

(A001, A002, A003, A004 and A005 are ultimates)

You're just comparing some integers (as many as there are heroes), I don't think you will get any performance problems from that.

/edit: Of course, you can't put this function in the map header, but I don't think that's that much of a problem.
 

luorax

Invasion in Duskwood
Reaction score
67
I haven't said that substrings are faster than comparing two integers...
Please read the whole topic if you would like to comment...
 

Sevion

The DIY Ninja
Reaction score
413
Hmm?

Use a struct...

JASS:
keyword ultimateList

globals
    ultimateList spells
endglobals

struct ultimateList extends array
    private boolean isUltimateX

    // Not explicitly required, but if you wish to do something upon setting the boolean...
    public method operator isUltimate= takes integer i, boolean flag returns nothing
        set spells<i>.isUltimateX = flag
    endmethod

    public method operator isUltimate takes integer i returns boolean
        debug if spells<i>.isUltimateX = null then
            debug DisplayTextToPlayer(GetLocalPlayer(), 0, 0, &quot;Warning (isUltimate): Null boolean!&quot;)
            debug // Do something else? I.E. return false ?
        debug endif
        return spells<i>.isUltimateX
    endmethod
    
    private static method onInit takes nothing returns nothing
        set spells = thistype.allocate()
        set spells[A000].isUltimateX = true
        set spells[A001].isUltimateX = true
    endmethod
endstruct

//usage

scope myTest initializer init
    private function init takes nothing returns nothing
        if ( ultimates[A000].isUltimate ) then
            // Do Something
        else
            // Do Something Else
        endif
    endfunction
endscope
</i></i></i>


There's a little work in initialization.

A little less efficient than the if ... or ... or ... or ... then method, but prettier and the efficiency impact is moot.

You can also use this as an interface to add additional features.

It has been a while since I vJASSed, so my scripting may be a bit rusty.

You could also wrap the struct into a library and privatize the entire struct to stop users from making duplicate structs. Just make the "spells" variable public.
 

DioD

New Member
Reaction score
57
A000 is large integer and will not fit 8190 limit for arrays.

you must use ID - A000 or other way to fit ID into 8190 bounds.
 
General chit-chat
Help Users
  • No one is chatting at the moment.

      The Helper Discord

      Members online

      Affiliates

      Hive Workshop NUON Dome World Editor Tutorials

      Network Sponsors

      Apex Steel Pipe - Buys and sells Steel Pipe.
      Top