Roll20 uses cookies to improve your experience on our site. Cookies enable you to enjoy certain features, social sharing functionality, and tailor message and display ads to your interests on our site and others. They also help us understand how our site is being used. By continuing to use our site, you consent to our use of cookies. Update your cookie preferences .
×
Create a free account

Scritpcard API Working and Sharing.

July 24 (3 years ago)

Edited July 24 (3 years ago)
Kurt J.
Pro
API Scripter

5E Action Menu Script

This ScriptCards script will display (to the person executing the script) a menu containing buttons for actions (NPCs), attacks (PCs) and spells (Both). These buttons can be clicked to execute the action, which will be displayed as an output card to everyone.

While not technically required, there are some features that won't work on ScriptCards below 1.3.9.

  • With any character token selected, executing the macro will present the caller with a list of actions and spells available to that character as a set of buttons.
  • Items in the Character's "Attacks & Spellcasting" section will only be displayed as actions if the AREN'T a spell (they will be displayed under the appropriate spell level instead).
  • The reentrant functions attempt to analyze the attack or spell and construct an appropriate output card. This should work for most 5e spells and attacks.
  • You can define a "spell mule" (see the beginning of the script). If you do, the script will check for Ability names on the spell mule character that match the names of the spells it is creating buttons for. If it finds on (CASE SENSITIVE) it will create a sheet button to that ability instead of a reentrant button. This allows odd-ball spells to fire their own custom scripts from the same card interface (I've got a character named "Spell_Mule" in my game, with an ability "Fireball" that contains the fireball macro. When the card is displayed and fireball is clicked it will run the full fireball script instead of trying to come up with something on its own).
  • If you wish to suppress the output of ACs from public view, change the "showGmInfo" value near the top of the script from 0 to 1.
  • If you don't upgrade to 1.3.9, the formatting will look a little weird and the spell mule stuff won't work, but otherwise the script should function.


The script is hosted on a GIST, and is available here. It is likely to be updated and revised as bugs are discovered, etc. I do intend to add support for global modifiers, but I haven't gotten there yet.

Here is a sample video using the script for a couple of PCs and NPCs, as well as how to use the "Spell_Mule" to substitute custom scripts for spells. In this case, I fire the Lightning Bolt spell without the Spell_Mule setup and then set up the mule and fire it again to see the custom script.



July 28 (3 years ago)

Edited July 28 (3 years ago)
David M.
Pro
API Scripter

Scriptcard for Random Terrain

My players are journeying into a cursed forest region, so I just picked up Gabriel Pickard's Excellent Critical Trails: Blighted Forest asset pack. Faced with the prospect of manually assembling a bunch of maps for random encounters, I wondered how hard it would be to make a random terrain generator using Scriptcards & SpawnDefaultToken. Turns out, not that hard! A bit of a kluge, but might give some folks ideas :)

Dependencies: Scriptcards, SpawnDefaultToken, SelectManager

Setup:

  1. I bulk downloaded the relevant art assets and dropped them into my personal art library (required for the api to be able to access them)
  2. Created Rollable table tokens for each class of art (Trees, Mushrooms, Blight patches, and Blight Pools for this example)
  3. Wrote a scriptcard querying for number of trees and some size and offset ranges. Due to wanting to properly layer the features (e.g. mushrooms below patches below pools below trees), I set it up as individual loops for each class in the proper layering order. I also used roll variables to create the desired ratios of Trees to more infrequent features (e.g. Blight Patches roughly 1/5th and Blight Pools roughly 1/8th of the tree frequency)
  4. I created a "default" blank map with my blight forest background and a perimeter of trees, and placed an origin token on the GM layer in the center. The objects are placed randomly within the given offset ranges relative to the selected origin token. Random side and rotation is handled by standard Spawn syntax.  

Note: 

Here's a gif of it in action:

The code:

!script {{
  --#hideCard|1

  --=Qty|?{How many Trees?|20}
  --=XRange|?{Plus/minus how many squares (X)?|14}
  --=YRange|?{Plus/minus how many squares (Y)?|11}
  --=MinSize|?{Minimum Size?|2}
  --=MaxSize|?{Maximum Size?|6}

  --=i|0
  --:Loop1|
      --=i|[$i]+1
      --:MUSHROOMS|
      -->RandomizeSize|1;3
      -->RandomizeOffset|
      -->Spawn|Temp
      --?[$i] -lt [$Qty]|Loop1

  --=i|0
  --:Loop2|   
      --=i|[$i]+1   
      --:BLIGHT PATCHES|
      --=AddPatch|1d5
      -->RandomizeSize|[$MinSize.Raw]; [$MaxSize.Raw]
      -->RandomizeOffset|
      --?[$AddPatch] -eq 1|>Spawn;Blight Patch
      --?[$i] -lt [$Qty]|Loop2

  --=i|0
  --:Loop3|
      --=i|[$i]+1
      --:BLIGHT POOLS|
      --=AddPool|1d8
      -->RandomizeSize|[$MinSize.Raw]; [$MaxSize.Raw]
      -->RandomizeOffset|
      --?[$AddPool] -eq 1|>Spawn;Blight Pool      
      --?[$i] -lt [$Qty]|Loop3

  --=i|0
  --:Loop4|
      --=i|[$i]+1
      --:TREES|
      -->RandomizeSize|[$MinSize.Raw]; [$MaxSize.Raw]
      -->RandomizeOffset|
      -->Spawn|Blight Trees
      --?[$i] -lt [$Qty]|Loop4

  --X|

  --:Spawn| accepts Rollable Table Token Name as parameter
      --@forselected|Spawn _name|[%1%] _offset|[$XOffset.Raw],[$YOffset.Raw] _layer|map _side|rand _size|[$ThisSize.Raw] _rotation|rand
  --<|

  --:RandomizeSize| accepts MinSize, MaxSize as parameters
      --=SizeRange|[%2%] - [%1%] + 1
      --=ThisSize|[%1%] + 1d[$SizeRange]
  --<|

  --:RandomizeOffset|
      -->PlusMinus|
      --=XOffset|[$PlusMinus]*1d[$XRange]
      -->PlusMinus|
      --=YOffset|[$PlusMinus]*1d[$YRange]
  --<|

  --:PlusMinus|
      --=temp|1d2-1
      --=PlusMinus|[$temp]*2-1
  --<|
}}

Index Entry

  • Random Terrain Generation - link


 

July 29 (3 years ago)

Edited July 29 (3 years ago)

Scriptcard for 5e Shove Action

The following script can be used to execute a D&D 5e Shove attack.

This new script requires version 1.3.9a of scriptcards, specifically the new math "Angle" function.  


!script {{  
  --#title|Shove
  --#reentrant|Shove
  --#emoteText|attempts to shove
  --#bodyFontSize|11px 

--+|[b][c]Shoving a Creature[/c][/b]
--+|Using the Attack action, you can make a special melee attack to shove a creature, either to knock it prone or push it away from you. If you're able to make multiple attacks with the Attack action, this attack replaces one of them.
--+|The target must be no more than one size larger than you and must be within your reach. Instead of making an attack roll, you make a Strength (Athletics) check contested by the target's Strength (Athletics) or Dexterity (Acrobatics) check (the target chooses the ability to use). You succeed automatically if the target is incapacitated. 
--+|If you succeed, you either knock the target prone or push it 5 feet away from you.

  --#sourceToken|@{selected|token_id}
  --#targetToken|@{target|token_id}
  --#debug|1

  --&STid|@{selected|token_id}
  --&TTid|@{target|token_id}

  --#leftsub|[*[&STid]:t-name]
  --#rightsub|[*[&TTid]:t-name]

  -->GET_SKILL_BONUS|[&STid];athletics
  --&SBonus|[&Bonus]

  -->GET_SKILL_BONUS|[&TTid];athletics
  --&TAthBonus|[&Bonus]

  -->GET_SKILL_BONUS|[&TTid];acrobatics
  --&TAcrBonus|[&Bonus]

  --&tStyle|style = "width:100%;padding:1px;border-spacing:0px;border-collapse:collapse;text-shadow: 0px 0px 0px black;border:0px dashed black;"
  --&trStyle1|style="border-top:0px dashed black;"
  --&tdStyle1|style="width:100%;text-align:center;background-color:#FFFFFF;font-size:80%"


--:STEP1| Setup the Shove Attack, ask if attacker is using advantage

  --+|Select the Roll Type for the attacker([*[&STid]:t-name]) using [b]athletics[/b]:
  --+|[t [&tStyle]]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Normal::STEP2;N[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Advantage::STEP2;A[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Disadvantage::STEP2;D[/rbutton][/td][/tr]
      [/t]
  --X|

--:STEP2| Process result from step 1 and Get defender info
  --#emotetext|
  --#emoteState|1
  --#hideTitleCard|1

  --&SRT|1d20
  --?[&reentryval] -eq A|&SRT;2d20kh1
  --?[&reentryval] -eq D|&SRT;2d20kl1

  --+|Defender ([*[&TTid]:t-name]) preferred skill for countering shove?
  --+|[t [&tStyle]]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Athletics/Str([&TAthBonus])::STEP3;athletics[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Acrobatics/Dex([&TAcrBonus])::STEP3;acrobatics[/rbutton][/td][/tr]
      [/t]
  --X|

--:STEP3| Process result from step 2 and Get defender roll type
  --&TSkill|athletics
  --&TBonus|[&TAthBonus]
  --?[&reentryval] -eq athletics|STEP3_ASK
    --&TSkill|acrobatics
    --&TBonus|[&TAcrBonus]

  --:STEP3_ASK|  

  --+|Select the Roll Type for the defender([*[&TTid]:t-name]) using [b][&TSkill][/b]:
  --+|[t [&tStyle]]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Normal::STEP4;N[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Advantage::STEP4;A[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Disadvantage::STEP4;D[/rbutton][/td][/tr]
      [/t]
  --X|

--:STEP4| Process result from step 3 and execute the roll
  --&TRT|1d20
  --?[&reentryval] -eq A|&TRT;2d20kh1
  --?[&reentryval] -eq D|&TRT;2d20kl1

  --=SResult|[&SRT] + [&SBonus] 
  --=TResult|[&TRT] + [&TBonus]
  
  --?[$SResult.Raw] -ge [$TResult.Raw]|WON|LOST

  --:WON|

  --+|Attacker [b]won[/b] ([$SResult] vs. [$TResult])the contest, select the desired effect:
  --+|[t [&tStyle]]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Knock it Prone::STEP5;PRONE[/rbutton][/td][/tr]
      [tr [&trStyle1]][td [&tdStyle1]][rbutton]Push it away 5'::STEP5;PUSH[/rbutton][/td][/tr]
      [/t]

  --x|
  --:LOST|
  --+|Defender [b]won[/b] ([$SResult] vs. [$TResult]) the contest, better luck next time!
--x|

--:STEP5| If attacker won the contest, decide on prone or shoved back 5 feet
  --?[&reentryval] -eq PUSH|PUSH|PRONE

  --:PUSH|

    -->MOVE_TOKEN|[&STid];[&TTid];1
    --+|[*[&STid]:t-name] has pushed [*[&TTid]:t-name] back five feet!

  --X|
  --:PRONE|

    --@token-mod|_set statusmarkers|Prone _ids [&TTid] _ignore-selected
    --+|[*[&TTid]:t-name] is now [b]prone[/b]!
    --+|A [b][i]prone[/b][/i] creature’s only movement option is to crawl, unless it stands up and thereby ends the condition.
    --+|The creature has **Disadvantage** on attack rolls.
    --+|An attack roll against the creature has **Advantage** if the attacker is within 5 feet of the creature. Otherwise, the attack roll has **Disadvantage**.

--X|

--:GET_SKILL_BONUS|TokenID, skill
  --&Tid|[%1%]
  --&Skill|[%2%]
  --&SB|[&Skill]_bonus

  --/|*Token|[*[&Tid]:t-name]
  --/|*Skill|[&Skill]
  --/|*SB|[&SB]: [*[&Tid]:[&SB]]
  --/|*NPC|[*[&Tid]:npc]

  --?"[*[&Tid]:npc]" -eq 1|NPC|CHAR
  --:NPC|
    --&NSF|npc_[&Skill]_flag
    --&NSB|npc_[&Skill]
    --/|*NSF|[&NSF]: [*[&Tid]:[&NSF]] 
    --/|*NSB|[&NSB]: [*[&Tid]:[&NSB]]: [*[&Tid]:[&NSB]]
    --?[*[&Tid]:[&NSF]] -eq 1|&Bonus;[*[&Tid]:[&NSB]]|&Bonus;[*[&Tid]:[&SB]]
        --/|*Bonus|[&Bonus]
    --<|Return
  --:CHAR|
    --&Bonus|[*[&Tid]:[&SB]]
    --/|*Bonus|[&Bonus]   
    --<|Return
  --x|

--:MOVE_TOKEN|STokenid, TTokenId, Units
  --&TId1|[%1%]
  --&TId2|[%2%]
  --&Units|[%3%]

  --/| Angle function returns a string variable (&) with lots of decimal points.
  --~A|math;angle;[&TId1];[&TId2]

  --/| I've found that TokenMod chokes on a movement angle with lots of decimal points, so rounding is needed
  --/|$Ar will now contain a rounded integer version of &A
  --~Ar|math;round;[&A]


  --/|&Angle will end up being one of the common directions which may work better for grids
  --?[$Ar] -gt 337.5 -or [$Ar] -le 22.5|&Angle;0
  --?[$Ar] -gt 22.5 -and [$Ar] -le 67.5|&Angle;45
  --?[$Ar] -gt 67.5 -and [$Ar] -le 112.5|&Angle;90
  --?[$Ar] -gt 112.5 -and [$Ar] -le 157.5|&Angle;135
  --?[$Ar] -gt 157.5 -and [$Ar] -le 202.5|&Angle;180
  --?[$Ar] -gt 202.5 -and [$Ar] -le 247.5|&Angle;225
  --?[$Ar] -gt 247.5 -and [$Ar] -le 292.5|&Angle;270
  --?[$Ar] -gt 292.5 -and [$Ar] -le 337.5|&Angle;315

  --/| Added for dealing with a SC 1.39a bug (returns negative angles beteen 270 and 360)
  --?[$Ar] -gt -90 -and [$Ar] -le -67.5|&Angle;270
  --?[$Ar] -gt -67.5 -and [$Ar] -le -22.5|&Angle;315
  --?[$Ar] -gt -22.5 -and [$Ar] -le 0|&Angle;0

  --&UnitsFactor|1
  --?[&Angle] -eq 45|&UnitsFactor;1.4142
  --?[&Angle] -eq 135|&UnitsFactor;1.4142
  --?[&Angle] -eq 225|&UnitsFactor;1.4142
  --?[&Angle] -eq 315|&UnitsFactor;1.4142

  --=U|[&Units] * [&UnitsFactor] 

  --*Angles|[&Angle] ([&A]) ([$Ar]) 
  --/| Time to call the magic TokenMod function to make the target token move across the screen
  --@token-mod|_move =[&Angle]|[$U.Raw]g _ids [&TId2] _ignore-selected

--<|Return

}}

Index Entry

  • 5e Shove Attack action - Link
July 29 (3 years ago)

Edited July 29 (3 years ago)

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  


!script {{
  --#title|Spell: Gust of Wind
  --#reentrant|GustOfWind
  --#debug|1
  --#sourcetoken|@{selected|token_id}
  --#targettoken|@{target|token_id}

  --&TTokenId|@{target|token_id}
  --=SpellSaveDC|[*S:spell_save_dc]
  --=Result|1d20 + [*T:strength_save_bonus]

  --?[$Result.Base] -eq 1|TARGET_FAILED
  --?[$Result.Base] -eq 20|TARGET_PASSED
  --?[$Result.Raw] -lt [$SpellSaveDC]|TARGET_FAILED
  
  --:TARGET_PASSED|
    --+|Target [b]succeeded[/b] on their strength saving throw with a [$Result] vs. Spellsave DC of [$SpellSaveDC]
    --x|

  --:TARGET_FAILED|
    --+|Target [b]failed[/b] on their strength saving throw with a [$Result] vs. Spellsave DC of [$SpellSaveDC]

    --&tStyle|style = "width:100%;padding:1px;border-spacing:0px;border-collapse:collapse;text-shadow: 0px 0px 0px black;border:0px dashed black;"
    --&trStyle1|style="border-top:0px dashed black;"
    --&tdStyle1|style="width:33%;text-align:center;background-color:#FFFFFF;font-size:80%"
    
    --/| Angle function returns a string variable (&) with lots of decimal points.
    --~A|math;angle;@{selected|token_id};@{target|token_id}

    --/| I've found that TokenMod chokes on a movement angle with lots of decimal points, so rounding is needed
    --/|$Ar will now contain a rounded integer version of &A
    --~Ar|math;round;[&A]

    --/|&Angle will end up being one of the common directions which may work better for grids
    --?[$Ar] -gt 337.5 -or [$Ar] -le 22.5|&Angle;0
    --?[$Ar] -gt 22.5 -and [$Ar] -le 67.5|&Angle;45
    --?[$Ar] -gt 67.5 -and [$Ar] -le 112.5|&Angle;90
    --?[$Ar] -gt 112.5 -and [$Ar] -le 157.5|&Angle;135
    --?[$Ar] -gt 157.5 -and [$Ar] -le 202.5|&Angle;180
    --?[$Ar] -gt 202.5 -and [$Ar] -le 247.5|&Angle;225
    --?[$Ar] -gt 247.5 -and [$Ar] -le 292.5|&Angle;270
    --?[$Ar] -gt 292.5 -and [$Ar] -le 337.5|&Angle;315

    --/| Added for dealing with a SC 1.39a bug (returns negative angles beteen 270 and 360)
    --?[$Ar] -gt -90 -and [$Ar] -le -67.5|&Angle;270
    --?[$Ar] -gt -67.5 -and [$Ar] -le -22.5|&Angle;315
    --?[$Ar] -gt -22.5 -and [$Ar] -le 0|&Angle;0

    --&UnitsFactor|1
    --?[&Angle] -eq 45|&UnitsFactor;1.4142
    --?[&Angle] -eq 135|&UnitsFactor;1.4142
    --?[&Angle] -eq 225|&UnitsFactor;1.4142
    --?[&Angle] -eq 315|&UnitsFactor;1.4142

    --=U|3 * [&UnitsFactor] 

    --/|*Angles|[&Angle] ([&A]) ([$Ar]) 
    --/| Time to call the magic TokenMod function to make the target token move across the screen
    --@token-mod|_move =[&Angle]|[$U.Raw]g _ids @{target|token_id} _ignore-selected

  --X|
}}

Index Entry

  • 5e Gust of Wind spell - Link


July 29 (3 years ago)


Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  

Very Sweet! Thank you

July 29 (3 years ago)


David M. said:

Scriptcard for Random Terrain

My players are journeying into a cursed forest region, so I just picked up Gabriel Pickard's Excellent Critical Trails: Blighted Forest asset pack. Faced with the prospect of manually assembling a bunch of maps for random encounters, I wondered how hard it would be to make a random terrain generator using Scriptcards & SpawnDefaultToken. Turns out, not that hard! A bit of a kluge, but might give some folks ideas :)

Dependencies: Scriptcards, SpawnDefaultToken, SelectManager


Beautiful thank you for sharing

July 30 (3 years ago)
Snow
Pro


Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  


Very nice, I used this and modified it for my Minotaur player for his Hammering Horn attack.



August 02 (3 years ago)

Edited August 02 (3 years ago)

Scriptcard for Away From Keyboard (AFK) toggle

Here's a simple script to toggle an AFK status marker (make sure you have one loaded in your campaign) when someone steps away and then back.  Place this in your campaign macros area or on a Macro Mule and give all your players access to it. 

When they click it for the first time it will:

  • Places your assigned AFK marker on their token
  • Sends the GM a message that the player is AFK

When they get back and click it:

  • Clears the AFK marker from their token
  • Sends the GM a message that the player is Back

If you don't have a marker called AFK, you could always designate one you do have and change the name in the code below to your desired marker name.  

Requires: TokenMod API

!script {{

  --/|Script Name : Away From Keyboard (AFK)
  --/|Version     : 0.1
  --/|Requires SC : 1.3.7+, TokenMod
  --/|Author      : Will M.

  --/|Description : Quick AFK Toggle.  Assumes you have an AFK Status Marker
  --/|

  --:TOP|
  --#sourceToken|@{selected|token_id}
  --#leftsub|@{selected|character_name}
  --#hidecard|0
  --#oddRowBackground|#FFFFFF
  --#evenRowBackground|#FFFFFF
  --#whisper|gm
  --#titleCardBackground|[&SendingPlayerColor]
  --#debug|1

  --/| Name of Status Marker for indicating AFK
  --&AFK|AFK

  --/|Loop through all of the status markers on the targetted token 
  --~|array;statusmarkers;aryToken_SM;@{selected|token_id}
  --~SMItem|array;getfirst;aryToken_SM

    --:LOOPTOP|
    --?[&SMItem] -eq ArrayError|ENDLOOP

      --&SMItem_Name|[&SMItem]
      --/| The rbutton syntax doesn't like '::' in the name- messes with the parser
      --~SMItem|string;replace;::;^^;[&SMItem]
      --~SMItem_Name|string;before;::;[&SMItem_Name]
      --?[&AFK] -eq [&SMItem_Name]|AFK_ON
      --~SMItem|array;getnext;aryToken_SM
    --^LOOPTOP|
    --:ENDLOOP| Not AFK
      --#title|AFK
      --@token-mod|_set statusmarkers|[&AFK] _ids @{selected|token_id} _ignore-selected
      --/|+|[c]@{selected|character_name} is now [b]"Away From Keyboard"[/b][/c]
      --X|
    --:AFK_ON|
      --#title|Back
      --@token-mod|_set statusmarkers|-[&AFK] _ids @{selected|token_id} _ignore-selected
      --/|+|[c]@{selected|character_name} is [b]back[/b][/c]      
  --X|

}}

Index Entry

  • Away from Keyboard (AFK) Toggle - Link
August 02 (3 years ago)

FYI - I've started maintaining all my Scriptcards and Macros on my personal GitHub: MadCar-Dev/Default: My Default Repository (github.com).  I'll continue to post here from time to time, but having written about 40 Scriptcards now, it will be easier for me to maintain my growing library on GitHub.   

August 06 (3 years ago)
Per request here is my (beginner) Scorching Ray using Kurt's MM as a template, along with Will's (? There are so many excellent contributors it is hard for an old man like me to keep them straight!) color template and other borrowings.  

!scriptcards {{ 
  --#title|Scorching Ray
  --#sourceToken|@{selected|token_id}
  --#emoteText|@{selected|character_name} Casts Scorching Rays!
  --&TFColor|#FFFFFF
  --&STFColor|#000000
  --&FColor1|#000000
  --&FColor2|#000000
  --&EBColor|#7DEDFF
  --&BColor1|#7C83FD
  --&BColor2|#96BAFF
  --#titlecardbackground|[&BColor1]
  --#titlecardbackgroundimage|linear-gradient(to bottom, #96BAFF, #7C83FD)
  --#titleFontColor|[&TFColor]
  --#subtitleFontColor|[&STFColor]
  --#emoteBackground|[&EBColor]
  --#titlefontsize|2.0em
  --#titlefontlineheight|1.2em
  --#titlefontface|Times New Roman
  --#norollhighlight|0
  --#hideTitleCard|0
  --#bodyfontsize|12px
  --#bodyfontface|Algerian
  --#oddrowbackground|[&BColor1]
  --#oddrowfontcolor|[&FColor2]
  --#evenrowbackground|[&BColor2]
  --#evenrowfontcolor|[&FColor1]
  --#leftsub|Level 2 | Evocation | Action
  --#rightsub| 120' | V S M

  --#debug|1

  --:Setup|
     -->GetAndCheckSlotInformation|
     --&DamageType|fire

    --=MissileCount|[$SlotLevel] + 1
    -->BuildAndAskTargets|[$MissileCount.Total]
    --=DisplayCount|1
    --=MissileDamage|2d6
    --+|[c]Spell Save DC: [*S:spell_save_dc]   Damage: [#ffff00][$MissileDamage][/#][/c]

  --:MissileLoop|
     -->FireMissile|[$DisplayCount.Total]
     --=DisplayCount|[$DisplayCount] + 1
     --?[$DisplayCount] -le [$MissileCount]|MissileLoop|EndMacro
  --X|

  --:FireMissile|
     --&ThisTarget|[&target[%1%]]
     -->PlayEffects|@{selected|token_id};[&ThisTarget];none;burst-smoke;beam-magic
     -->Attack|[&ThisTarget]
  --<|

  --:EndMacro|

  --X|

  --:PROCEDURES|

  --:GetAndCheckSlotInformation|
     --=SlotLevel|?{Spell Slot Level?|2|3|4|5|6|7|8|9}
     --=SlotsTotal|[*S:lvl[$SlotLevel]_slots_total]
     --=SlotsExpended|[*S:lvl[$SlotLevel]_slots_expended]
     --?[$SlotsExpended.Total] -ge [$SlotsTotal.Total]|NoSlotsLeft

  --:DeductSpellSlot|
     --=SlotsExpended|[$SlotsExpended] + 1
     --@setattr|_charid [*S:character_id] _lvl[$SlotLevel]_slots_expended|[$SlotsExpended] _silent
     --=SlotsRemaining|[$SlotsTotal] - [$SlotsExpended]
  --<|

  --:NoSlotsLeft|
     --+|[*S:character_name] has no level [$SlotLevel.Total] spell slots available.
  --X|

--:Attack|
    --?"[*[%1%]:npc_ac]" -gt 0|=TargetAC;[*[%1%]:npc_ac]|=TargetAC;[*[%1%]:ac]
    --=TotalDamage|[$MissileDamage]
    --?"[*[%1%]:npc_immunities]" -inc "[&DamageType]"|Immune
    --?"[*[%1%]:npc_resistances]" -inc "[&DamageType]"|>DamageResist;[%1%];[$MissileDamage]
    --?"[*[%1%]:npc_vulnerabilities]" -inc "[&DamageType]"|>DamageVuln;[%1%];[$MissileDamage]

    --=AttackRoll|1d20 [BASE] + [*S:spell_attack_bonus]
    --+Attack|[*S:character_name] rolls [$AttackRoll] vs AC [$TargetAC].

  --:Determine results|
    --?[$AttackRoll.Base] -eq 1|>Fumble;[&ThisTarget]
    --?[$AttackRoll.Total] -lt [$TargetAC.Total]|>Miss;[&ThisTarget]
    --?[$AttackRoll.Base] -eq 20]>DamageCrit;[&ThisTarget];[$TotalDamage]
    --?[$AttackRoll.Total] -ge [$TargetAC.Total] -and [$AttackRoll.Base] -ne 20|>Hit;[&ThisTarget];[$TotalDamage]
  --X|

  --:DamageResist|
    --=TotalDamage|[%2%] \ 2
    --+[b]Resistant![/b]|[b][*[%1%]:character_name] takes [$TotalDamage] damage![/b]
  --<|

  --:DamageVuln|
    --=TotalDamage|[%2%] * 2
    --+[b]Vulnerable![/b]|[b][*[%1%]:character_name] takes [$TotalDamage] damage![/b]
  --<|

  --:Fumble|
      --+Fumble!|The attack on [*[%1%]:character_name] went horribly wrong.
  --^MissileLoop|

  --:Miss|
      --+Miss!|The attack on [*[%1%]:character_name] missed.
  --^MissileLoop|

  --:Hit| pass Damage string 
    --+Hit!|[*S:character_name]'s Spell hits [*[%1%]:character_name] for [$TotalDamage] [&DamageType] damage.
  -->ApplyDamage|[%1%];[$TotalDamage]

  --:DamageCrit|
    --=TotalDamage|[%2%] * 2
    --+[b]Crit![/b]|[b][*[%1%]:character_name] takes [$TotalDamage] [&DamageType] damage![/b]
  -->ApplyDamage|[%1%];[$TotalDamage]

  --:Immune|
     --=DisplayCount|[$DisplayCount] + 1
     --+|[b][*[%1%]:character_name] is immune to [&DamageType] damage![/b]
  --^MissileLoop|

  --:ApplyDamage|
    --@alter|_target|[%1%] _bar|1 _amount|-[%2%]
     --=DisplayCount|[$DisplayCount] + 1
     --?[$DisplayCount] -le [$MissileCount]|MissileLoop|EndMacro

  --:BuildAndAskTargets|
     --&TargetString|
     --=targetCount|1
     --:TargetLoop|
        --&TargetString|+t;target[$targetCount.Raw];Missile [$targetCount.Raw] Target
        --=targetCount|[$targetCount.Total] + 1
        --?[$targetCount.Total] -le [%1%]|>AddSeparator
        --?[$targetCount.Total] -le [%1%]|TargetLoop
     --iClick button below to select targets. The same target may be selected more than once;Select [%1%] Targets|[&TargetString]
  --<|

  --:AddSeparator|
     --&TargetString|+||
  --<|

  --:PlayEffects|Parameters are : sourcetoken; targettoken; source effect; target effect; line effect
     --vtoken|[%1%] [%3%]
     --vtoken|[%2%] [%4%]
     --vbetweentokens|[%1%] [%2%] [%5%]
  --<|

}}

August 14 (3 years ago)

Edited October 04 (3 years ago)

Spell: Scorching Ray 

My version of Scorching Ray.  Based largely on Michael C's original version but with the following differences:

  • Modified to work with TokenMod (instead of AlterBars) to apply damage.
  • Asks for targets one at a time instead of all at once. 
  • Formatting changes


!script {{ 
  
  --/|Script Name : Scoring Ray
  --/|Version     : 1.0
  --/|Requires SC : 1.3.7+, TokenMod
  --/|Author      : Will M.
  --/|Updated     : 8/14/2021

  --/|Description : Scorching Ray Spell
  --/|              
  --/|              

  --#title|Scorching Ray
  --#sourceToken|@{selected|token_id}
  --#emoteText|@{selected|character_name} Casts Scorching Rays!
  --&TFColor|#FFFFFF
  --&STFColor|#000000
  --&FColor1|#000000
  --&FColor2|#000000
  --&EBColor|#FFFFFF
  --&BColor1|#FFFFFF
  --&BColor2|#FFFFFF

  --#titlecardbackground|[&BColor1]
  --#titlecardbackgroundimage|linear-gradient(to bottom, #FFF000, #FF0000)
  --#titleFontColor|[&TFColor]
  --#subtitleFontColor|[&STFColor]
  --#emoteBackground|[&EBColor]
  --#titlefontsize|2.0em
  --#titlefontlineheight|1.2em
  --#titlefontface|Times New Roman
  --#norollhighlight|0
  --#hideTitleCard|0
  --#bodyfontsize|12px

  --#oddrowbackground|[&BColor1]
  --#oddrowfontcolor|[&FColor2]
  --#evenrowbackground|[&BColor2]
  --#evenrowfontcolor|[&FColor1]
  --#leftsub|Level 2 | Evocation | Action
  --#rightsub| 120' | V S | Fire

  --#debug|1

  --:STEP1| Setup 

    --&DamageType|fire
    --=MissileDamage|2d6
    --=DisplayCount|0

    --+|You create three rays of fire and hurl them at targets within range. You can hurl them at one target or several.  Make a ranged spell attack for each ray. On a hit, the target takes 2d6 fire damage.
    --+|[b]At Higher Levels.[/b] When you cast this spell using a spell slot of 3rd level or higher, you create one additional ray for each slot level above 2nd.
    --+|[br]
    --+|[c][b]Spell Save DC: [#FF0000][*S:spell_save_dc][/#]   Damage: [#FF0000][$MissileDamage.Raw][/#][/b][/c]
    --+|[br]

    --+|[b][c]Spell Level?[/c][/b]
    --+|[c][rbutton]2nd::STEP2;2[/rbutton][rbutton]3rd::STEP2;3[/rbutton][rbutton]4th::STEP2;4[/rbutton][rbutton]5th::STEP2;5[/rbutton][/c]
    --+|[c][rbutton]6th::STEP2;6[/rbutton][rbutton]7th::STEP2;7[/rbutton][rbutton]8th::STEP2;8[/rbutton][rbutton]9th::STEP2;9[/rbutton][/c]
    --+|[br]
    --+|After picking a level above, you will be asked to select a series of targets until all your rays are delivered - [b]Good Luck![/b]

    --X|

  --:STEP2|
    --&SlotLevel|[&reentryval]
    --=SlotsTotal|[*S:lvl[&SlotLevel]_slots_total]
    --=SlotsRemaining|[*S:lvl[&SlotLevel]_slots_expended]
    --?[$SlotsRemaining.Total] -le 0|NoSlotsLeft
    --=MissileCount|[&SlotLevel] - 2 + 3


  --:MissileLoop| 
    --=DisplayCount|[$DisplayCount] + 1

    --?[$DisplayCount] -gt [$MissileCount]|EndMacro
    --?[$DisplayCount] -ne 1|[
      --+|[hr]
      --+|[br]
      --+|[c][rbutton]Next Target::NEXT_TARGET[/rbutton][/c]
      --+|[br]
      --+|[c][b]Spell Save DC: [#FF0000][*S:spell_save_dc][/#]   Damage: [#FF0000][$MissileDamage.Raw][/#][/b][/c]
      --+|[br]
      --X|
    --]|

    --:NEXT_TARGET|
    --I Select the target of your Scoring Ray.;Scoring Ray #[$DisplayCount].|t;ThisTarget;Scorching Ray #[$DisplayCount]:
    --#leftsub|Ray # [$DisplayCount.Raw]
    --#rightsub|[*[&ThisTarget]:t-name]
    --#targetToken|[&ThisTarget]
    --#emoteText|Scorching Ray #[$DisplayCount.Raw]
    -->PlayEffects|@{selected|token_id};[&ThisTarget];none;burst-smoke;beam-magic

    --&DamageResistNote|
    --=TotalDamage|[$MissileDamage]

    --?"[*[&ThisTarget]:npc_ac]" -gt 0|[
      --=TargetAC|[*[&ThisTarget]:npc_ac]
      --?"[*[&ThisTarget]:npc_immunities]" -inc "[&DamageType]"|>Immune
      --?"[*[&ThisTarget]:npc_resistances]" -inc "[&DamageType]"|>DamageResist
      --?"[*[&ThisTarget]:npc_vulnerabilities]" -inc "[&DamageType]"|>DamageVuln
    --]|[
      --=TargetAC|[*[&ThisTarget]:ac]
    --]|
    --=AttackRoll|1d20 [BASE] + [*S:spell_attack_bonus]

    --/|Determine results|
    --?[$AttackRoll.Base] -eq 1|FUMBLE
    --?[$AttackRoll.Base] -eq 20|CRITICAL
    --?[$AttackRoll.Total] -lt [$TargetAC.Total]|MISS
    --?[$AttackRoll.Total] -ge [$TargetAC.Total]|HIT

    --X|
  --<|

  --:EndMacro|
  --X|

  --/|PROCEDURES

  --:DeductSpellSlot|
     --=SlotsRemaining|[$SlotsRemaining] - 1
     --@setattr|_charid [*S:character_id] _lvl[&SlotLevel]_slots_expended|[$SlotsRemaining] _silent
  --<|

  --:NoSlotsLeft|
     --+|[*S:character_name] has no level [&SlotLevel] spell slots available.
  --X|

  --:DamageResist|
    --=TotalDamage|[$MissileDamage] \ 2
    --&DamageResistNote|(Resistant)
  --<|
  --:DamageVuln|
    --=TotalDamage|[$MissileDamage] * 2
    --&DamageResistNote|(Vulnerable)
  --<|
  --:Immune|
    --=TotalDamage|0    
    --&DamageResistNote|(Immune)
  --<|


  --:FUMBLE|
      --+&#x1F613;Ray #[$DisplayCount.Raw] Fumbles! |[*S:character_name] rolls [$AttackRoll] to attack [*[&ThisTarget]:t-name] and something went horribly wrong.
  --^MissileLoop|

  --:MISS|
      --+&#x274C;Ray #[$DisplayCount.Raw] Misses! |[*S:character_name] rolls [$AttackRoll] to attack [*[&ThisTarget]:t-name] and missed.
  --^MissileLoop|

  --:HIT| pass Damage string 
    --+&#x1F3AF;Ray #[$DisplayCount.Raw] hits! |[*S:character_name] rolls [$AttackRoll] to attack and hits [*[&ThisTarget]:t-name] for [$TotalDamage] [&DamageType] damage. [&DamageResistNote]
  -->ApplyDamage|
  --^MissileLoop|

  --:CRITICAL|
    --=TotalDamage|[$TotalDamage] * 2
    --+&#x2757;&#x2757;&#x2757;Crits!|[*S:character_name] rolls [$AttackRoll] to attack and CRITS [*[&ThisTarget]:t-name] for [$TotalDamage] [&DamageType] damage. [&DamageResistNote]
  -->ApplyDamage|
  --^MissileLoop|

  --:ApplyDamage|
    
    --=CurrentHP|[*[&ThisTarget]:t-bar1_value]
    --@token-mod|_ids [&ThisTarget] _ignore-selected _set bar1_value|-[$TotalDamage.Raw] 
    --/|@alter|_target|[&ThisTarget] _bar|1 _amount|-[$TotalDamage.Raw]

    --/|Did that kill them?
    --?[$CurrentHP.Raw] -gt [$TotalDamage.Raw]|ALIVE|DEAD

    --:ALIVE|
      --/+|[*[&ThisTarget]:character_name] is still alive and kicking!
      --<|
    --:DEAD|
      --+Congrats|You managed to kill [*[&ThisTarget]:character_name]
      --@token-mod|_ids [&ThisTarget] _ignore-selected _set statusmarkers|dead bar1_value|0      
      --<|

  --:PlayEffects|Parameters are : sourcetoken; targettoken; source effect; target effect; line effect
     --vtoken|[%1%] [%3%]
     --vtoken|[%2%] [%4%]
     --vbetweentokens|[%1%] [%2%] [%5%]
  --<|
}}

  • Spell: Scorching Ray - Link
August 25 (3 years ago)

Hello all Magic Scriptcards writers !

Here's a little demand from someone who absolutely cannot code !


I'd like to know if anyone could create a scriptcard that would do the same as grpcheck and apply damages scripts but with the slight difference that these checks would take into consideration the immunities/resistances/vulnerabilities of the selected tokens.


As a reminder, you can have a look on how the groupcheck and apply damages works on this very good Nick Olivo's Group Check and apply damage video.

The only thing about this script is that it doesn't make any difference if the monster is especially affected by fire or cold or whatsoever. So there will probably be a need for including the damage type query in the scriptcard.


I know that fireball scriptcard for example does all this, but i really would like to have a similar and generic dm accessible group check+apply damages procedure only.


Please accept the challenge :)

August 28 (3 years ago)

Edited August 28 (3 years ago)

5E Hexblade's Curse

I handle this like I do Hunter's mark.  You will need an attribute added called hexblade.  I also keep track of this on the class_resource.  The rest API script I use will reset it on a short or long rest.  This will also use token-mod to mark the token.

!scriptcards{{

  --:Hexblade's Curse|
  --#title|Hexblade's Curse
  --#rightsub|Class Ability
  --#leftsub|30 Feet
  --#sourceToken|@{selected|token_id}
  --#targetToken|@{target|token_id}


  -->GetAndCheckSlotInformation|

  --#emoteText| @{selected|token_name} has chosen @{target|token_name} as their next victim of vengance.
  --@token-mod| _ids @{target|token_id} _set statusmarkers|death-zone
  --@setattr|_charid [*S:character_id] _hexblade|[*T:t-id] _silent
  --@act| -1| 10| _Hexblade Curse Braeden

  -->DeductSpellSlot|

  --:AllDone|
  --X|

  --:GetAndCheckSlotInformation|
  --=SlotsTotal|0
  --=SlotsExpended|[*S:class_resource]
  --?[$SlotsExpended.Total] -eq [$SlotsTotal.Total]|NoSlotsLeft
  --<|

  --:DeductSpellSlot|
  --=SlotsLeft|[$SlotsExpended] - 1
  --@setattr|_charid [*S:character_id] _class_resource|[$SlotsLeft] _silent
  --+|You need to rest before you can curse someone else.
  --X|Full Stop

  --:NoSlotsLeft|
  --+|You need to rest before you can do this again.
  --#emoteText|[*S:character_name] cannot use Hexblade's Curse
  --X|NoSlotsLeftStop

}}

Next you will need to add this to your attack macro.  I added this to check if a 19 was roll for Crit.

  --?"@{selected|hexblade}" -ninc "@{target|token_id}"|notHexed
  --?[$AttackRoll.Base] -eq 19|Crit
  --:notHexed|

 I usually put   -->CheckHexBlade| right after the attack roll.

  --:CheckHexBlade|
  --&HexBlade|
  --+|@{selected|hexblade}
  --+|@{target|token_id}
  --?"@{selected|hexblade}" -ninc "@{target|token_id}"|noHexBlade
  --&HexBlade|+ + @{pb} [Hexblade Curse]
  --:noHexBlade|
  --<|


August 28 (3 years ago)

Edited August 28 (3 years ago)

5E Pact of the Blade

No one should have to create this again.  First thing is the Warlock using their action to create the weapon.  You will need to create an attribute called pactblade.  It will warn the GM to unequip shields or other weapons if they select a 2 handed weapon.

!Scriptcard {{ 

  --#sourceToken|@{selected|token_id}
  --#Title|Pact of the Blade
  --#leftsub|Class Ability
  --#rightsub|Action
  --&Weapon|?{Choose what weapon you would like to create.|Greatsword|Longsword|Glaive|Halberd|Club|Dagger|Greatclub|Handaxe|Javelin|Light hammer|Mace|Quarterstaff|Sickle|Spear|Battleaxe|Flail|Greataxe|Lance|Maul|Morningstar|Pike|Rapier|Scimitar|Shortsword|Triden|War Pick|Warhammer|Whip}
  --#emoteText|@{selected|character_name} creates a magical [&Weapon] in his empty hand.
  --@setattr|_charid [*S:character_id] _pactblade|[&Weapon] _silent
  --?[&Weapon] -inc "Greatclub" -or "Glaive" -or "Greataxe" -or "Greatsword" -or "Halberd" -or "Maul" -or "Pike"|TwoHanded
  --X|
  --:TwoHanded|
  --*|Uneqiup Shield and other weapon.


}}

Next is the attack script.   It does have the hexblade curse script I added the post before this.

!Scriptcard {{ 

  --#sourceToken|@{selected|token_id}
  --#targetToken|@{target|token_id}
 
  --&Which|@{selected|pactblade}
  --?"[&Which]" -inc "Club"|>Attack;Club;bludgeoning;1d4; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Dagger"|>Attack;Dagger;piercing;1d4; @{dexterity_mod} [DEX];none;no;5 ft;thrown;none;none
  --?"[&Which]" -inc "Greatclub"|>Attack;Greatclub;bludgeoning;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Handaxe"|>Attack;Handaxe;slashing;1d6; @{strength_mod} [STR];none;no;5 ft;thrown;none;none
  --?"[&Which]" -inc "Javelin"|>Attack;Javelin;piercing;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Light hammer"|>Attack;Greatclub;bludgeoning;1d4; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Mace"|>Attack;Mace;bludgeoning;6; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Quarterstaff"|>Attack;Quarterstaff;bludgeoning;1d6; @{strength_mod} [STR];Versa;1d8;5 ft;melee;none;none
  --?"[&Which]" -inc "Sickle"|>Attack;Sickle;slashing;1d4; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Spear"|>Attack;Spear;piercing;1d6; @{strength_mod} [STR];Versa;1d8;5 ft;melee;none;none
  --?"[&Which]" -inc "Greatclub"|>Attack;Greatclub;bludgeoning;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Battleaxe"|>Attack;[&Which];slashing;1d8; @{strength_mod} [STR];Versa;1d10;5 ft;melee;none;none
  --?"[&Which]" -inc "Flail"|>Attack;[&Which];bludgeoning;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Glaive"|>Attack;[&Which];slashing;1d10; @{strength_mod} [STR];none;no;10 ft;melee;none;none
  --?"[&Which]" -inc "Greataxe"|>Attack;[&Which];slashing;1d12; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Greatsword"|>Attack;[&Which];slashing;2d6; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Halberd"|>Attack;[&Which];slashing;1d10; @{strength_mod} [STR];none;no;10 ft;melee;none;none
  --?"[&Which]" -inc "Lance"|>Attack;[&Which];piercing;1d12; @{strength_mod} [STR];none;no;10 ft;melee;none;none
  --?"[&Which]" -inc "Longsword"|>Attack;[&Which];slashing;1d8; @{strength_mod} [STR];Versa;1d10;5 ft;melee;none;none
  --?"[&Which]" -inc "Maul"|>Attack;[&Which];bludgeoning;2d6; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Morningstar"|>Attack;[&Which];piercing;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Pike"|>Attack;[&Which];piercing;1d10; @{strength_mod} [STR];none;no;10 ft;melee;none;none
  --?"[&Which]" -inc "Rapier"|>Attack;[&Which];piercing;1d8; @{dexterity_mod} [DEX];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Scimitar"|>Attack;[&Which];slashing;1d6; @{dexterity_mod} [DEX];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Shortsword"|>Attack;[&Which];slashing;1d6; @{dexterity_mod} [DEX];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Trident"|>Attack;[&Which];piercing;1d6; @{strength_mod} [STR];Versa;1d8;5 ft;melee;none;none
  --?"[&Which]" -inc "War pick"|>Attack;[&Which];piercing;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none
  --?"[&Which]" -inc "Warhammer"|>Attack;[&Which];bludgeoning;1d8; @{strength_mod} [STR];Versa;1d10;5 ft;melee;none;none
  --?"[&Which]" -inc "Whip"|>Attack;[&Which];slashing;1d4; @{dexterity_mod} [DEX];none;no;10 ft;melee;none;none

  --:Attack|Variables are 1 Weapon Name;2 damage type;3 damage dice amount;4 damage modifier;5 Versaile;6 Versatile Damage;7 range;8 melee or thrown;9 resource used;10 resource used name (not used in this script)

  --&Weapon|[%1%]
  --=Weap|[%1%]
  --&DamageAmount|[%3%]
  --&DamageType|[%2%]
  --&DamageMod|[%4%]
  --&Versatile|[%5%]
  --&VersitileDamage|[%6%]
  --&AttackType|[%8%]
  --&ResourceUsed|[%9%]
  --&AmmoName|[%10%]

  --?"[&AttackType]" -ninc "Thrown"|notThrown
  --iAre you going to throw the weapon;Click to select a if you are going to throw the weapon or not.|q;AttackType;Throw the weapon or Melee attack?|Melee|Thrown
  --:notThrown|

  --?"[&Versatile]" -ninc "Versa"|notVersatile
  --iThis weapon is Versatile.;Click to select if you are going to use this as a one or two-handed weapon.|q;UseVersatile;One or Two Handed|Two|One
  --?"[&UseVersatile]" -inc "One"|notVersatile
  --&DamageAmount|[&VersitileDamage]
  --:notVersatile|
  
  
  --#Title|[%1%]
  --#leftsub|[&AttackType] Attack
  --#rightsub|[%7%]

  --=AttackRoll| ?{Attack|Standard,1d20|Advantage,2d20kh1|Disadvantage,2d20kl1} + [%4%] + @{pb} [PROF]

  -->CheckHexBlade|

  --#emoteText|@{selected|token_name} attempts to attack @{target|token_name} with their Pact Weapon.
  --+Roll|You rolled a [$AttackRoll].
  --?"@{selected|hexblade}" -ninc "@{target|token_id}"|notHexed
  --?[$AttackRoll.Base] -eq 19|Crit
  --:notHexed|
  --?[$AttackRoll.Base] -eq 20|Crit
  --?[$AttackRoll.Base] -eq 1|Fumble
  --?[$AttackRoll.Total] -lt @{target|npc_AC}|Miss

  --:Hit|
  -->RollDamage|
  --:AfterDamageHit|
  -->PlayEffects|none;none;none;[&Weapon]
  --+Hit!|Your attack hit for [$Damage] [%2%] damage!
  --@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]
  --?"[&AttackType]" -ninc "Thrown"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Miss|
  --+Miss|Your attack missed!
  --?"[&AttackType]" -ninc "Thrown"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Fumble|
  --=Fumblet|[T#Fumble-Table]
  -->PlayEffects|none;none;none;Failure
  --+|[img]https://media3.giphy.com/media/duexIlfr9yYwYE23UA/giphy.gif?cid=ecf05e4735w197ln6hoja74l3ikcd7t0w971w0ljtmjp000n&rid=giphy.gif&ct=g[/img]
  --+Fumble|The attack went really bad!
  --+Bad Stuff| [$Fumblet.tableEntryText]
  --=FDamage| 1d[%3%] + [%4%]
  --=FCrit|1d[%3%] + [%4%] + 1d[%3%] [CRIT]
  --*Possible Damage| Normal Damage is [$FDamage] and Crit Damage is [$FCrit].
  --?"[&AttackType]" -ninc "Thrown"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Crit|
  -->RollDamage|crit
  --:AfterDamageCrit|
  -->PlayEffects|none;none;none;[&Weapon]
  --+Critical Hit|You deal [$Damage] [%2%] damage CRITICAL HIT!
  --@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]
  --?"[&AttackType]" -ninc "Thrown"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:RollDamage|
  --&vuln|
  --?"[*T:npc_immunities]" -inc "nonmagical"|notImmune
  --?"[*T:npc_immunities]" -inc "[&DamageType]"|immune
  --:notImmune|
  --?"[*T:npc_resistances]" -inc "nonemagical"|notResistant
  --?"[*T:npc_resistances]" -inc "[&DamageType]"|HalfD
  --:notResistant|
  --?"[*T:npc_vulnerabilities]" -inc "[&DamageType]"|DoubleD
  --^gettoit|
  --:HalfD|
  --&vuln| \ 2
  --^gettoit|
  --:DoubleD|
  --&vuln| * 2
  --^gettoit|
  --:immune|
  --+|@{target|token_name} is immune to [&DamageType] damage.
  --&vuln| * 0
  --:gettoit|
  --?[%1%] -eq crit|CritDamage
  --=Damage|[&DamageAmount] + [&DamageMod][&HexBlade][&vuln]
  -->AfterDamageHit|
  --:CritDamage|
  --=Damage|[&DamageAmount] + [&DamageMod] + [&DamageAmount] [CRIT][&HexBlade][&vuln]
  -->AfterDamageCrit|

  --:AmmoSpent|
  --&pactblade|
  --@setattr|_charid [*S:character_id] _pactblade|[&pactblade] _silent
  --&ResourceUsed|+_name
  --&ResourceTitle|[*S:[&ResourceUsed]]
  --+|You can't use your pact blade again until you retrieve it or recreate it.
  --<|

  --:PlayEffects|Parameters are : source effect; target effect; line effect; sound effect
  --vtoken|@{selected|token_id} [%1%]
  --vtoken|@{target|token_id} [%2%]
  --vbetweentokens|@{selected|token_id} @{target|token_id} [%3%]
  --@roll20AM|_audio,play,nomenu|[&Weapon]
  --<|

  --:CheckHexBlade|
  --&HexBlade|
  --?"@{selected|hexblade}" -ninc "@{target|token_id}"|noHexBlade
  --&HexBlade|+ + @{pb} [Hexblade Curse]
  --:noHexBlade|
  --<|

  --:NoBlade|
  --+|You don't have a pact blade.
  --X|

}}
August 28 (3 years ago)

Edited September 14 (3 years ago)

5E basic attack script V1.1

Here is an example of a basic attack script I use.  I like it this way because if a weapon is bought or discovered, I can add it quickly.  As always, I am not a programmer, so if you have any recommendations, it would be appreciated.  I might have missed it, but I didn't see anyone else post one, so I thought I would share mine.

I would like to add library references, but for some reason the variable carry downs, i.e. [%1%], don't seem to be working.  I don't know if I am doing something wrong or how to fix it.  Once I figure it out, I will add those.

V1.1 updates

I added Kurt's Ammo check script so that you just need the name of the Ammo used, you don't have to change it for each Ammo slot.

I added a magical weapon section.

I added a check for proficiency that the DM changes with yes or no.

Added the formatting section that Craven uses.  I thought that was nice.

Separated out vulnerability check from damage roll.  I use this with things like hunters and paladins because I will add procedures that do their own damage, such as Ensnaring Strike, that might do a different damage type.  This will allow me to reference the vulnerability/resistance check an additional time without writing it out.

!Scriptcard {{ 

  --#sourceToken|@{selected|token_id}
  --#targetToken|@{target|token_id}

--/|                >>>>> Formatting <<<<< 
  --#titlecardbackgroundimage|linear-gradient(360deg, rgba(2,0,36,1) 0%, rgba(0,227,208,1) 100%); 
  --#emoteBackground|#transparent
  --#titleCardBackground|#00e3d0
  --#titlefontsize|1.75em
  --#titlefontlineheight|1.75em
  --#titleFontColor|white
  --#titlefontface|Shadows Into Light
  --#subtitleFontSize|12px
  --#subtitleFontFace|Verdana
  --#evenRowBackground|#B6AB91
  --#evenRowFontColor|#000000
  --#oddRowBackground|#CEC7B6
  --#oddRowFontColor|#000000
  --#Title|Attack
  --#whisper|self,gm


  --/his will whisper the possible attacks that can be used.  It will whisper the buttons to the PC and the DM, that way the DM can see where the Player is at in the process.
   --+Choose your weapon.|[rbutton]Dragon Slayer 1 handed::knowYourWeapon;5[/rbutton][rbutton]Dragon Slayer 2 handed::knowYourWeapon;6[/rbutton][rbutton]Ice Pick::knowYourWeapon;3[/rbutton][rbutton]Handaxe Thrown::knowYourWeapon;2[/rbutton][rbutton]Handaxe Melee::knowYourWeapon;1[/rbutton][rbutton]Sling::knowYourWeapon;4[/rbutton]
  --X|
  --:knowYourWeapon|
  --#whisper|self,gm
  --=Which|[&reentryval]
  --?[$Which] -eq 1|>Attack;Handaxe;slashing;1d6; @{strength_mod} [STR];Handaxe;no;5 ft;melee;no;0;yes
  --?[$Which] -eq 2|>Attack;Handaxe;slashing;1d6; @{strength_mod} [STR];Handaxe;yes;20/60;thrown;no;0;yes
  --?[$Which] -eq 3|>Attack;Ice Pick;piercing;1d8; @{strength_mod} [STR];none;no;5 ft;melee;none;none;no;0;yes
  --?[$Which] -eq 4|>Attack;Sling;bludgeoning;1d4; @{dexterity_mod} [DEX];Sling bullets;yes;30/120;ranged;no;0;yes
  --?[$Which] -eq 5|>Attack;Dragon Slayer;slashing;1d8; @{strength_mod} [STR];none;no;5 ft;melee;yes;1;yes
  --?[$Which] -eq 6|>Attack;Dragon Slayer;slashing;1d10; @{strength_mod} [STR];none;no;5 ft;melee;yes;1;yes

  --/This will pass down the variables to save them for use later.

  --:Attack|Variables are 1 Weapon Name;2 damage type;3 damage dice amount;4 damage modifier;5 ammo;6 If it will use ammo;7 range;8 melee, ranged, or thrown;9 magical;10 Magic Level (Sword +2 would just be 2.);Profficient(Yes or No)

  --&Weapon|[%1%]
  --=Weap|[%1%]
  --&DamageType|[%2%]
  --&DamageAmount|[%3%]
  --&DamageMod|[%4%]
  --&ResourceUsed|[%5%]
  --&SpendAmmo|[%6%]
  --&Range|[%7%]
  --&AttackType|[%8%]
  --&Magical|[%9%]
  --&MagicLvl|[%10%]
  --&Prof|[%11%]

  --#Title|[&Weapon]
  --#leftsub|[&AttackType] Attack
  --#rightsub|[&Range]

  -->Profficient|Check for the yes or no on &Prof.  If yes, will add profiency bonus.
  -->MagicalWeapon|Will check if yes or no on &Magical and add &MagicLvl bonus to attack and damage.  This example also adds damage from Dragon slayer for example.

  --/This section will check if there is a resource needed for an attack.  Since a handaxe can be thrown, the PC may not have it in order to attack.  First it will see if there is Ammo needed, then it will find where it is, and then it will check if the PC still has some.
  --?"[&ResourceUsed]" -eq "none"|noAmmoNeeded
  -->GetAndCheckAmmoInformation|[*S:character_id];[&ResourceUsed];Ammoname;Ammo
  -->AmmoAvailable|
  --:noAmmoNeeded|

  --/This will whisper to the DM and Player the possible rolls and allow the DM to inform the player for where they ar at.
  --+Choose an attack roll type.|[rbutton]Standard::knowYourRoll1;1d20[/rbutton][rbutton]Advantage::knowYourRoll1;2d20kh1[/rbutton][rbutton]Disadvantage::knowYourRoll1;2d20kl1[/rbutton]

  --X| DONE

  --:knowYourRoll1|
  --=AttackRoll|[&reentryval] + [&DamageMod][&PB]


  --#emoteText|@{selected|token_name} attempts to attack @{target|token_name} with their [&Weapon].
  -->RollResults|I have a seperate procedure for roll result due to PCs having spells and abilities like Bless and Bardic Inspiration.

  --?[$AttackRoll.Base] -eq 20|Crit
  --?[$AttackRoll.Base] -eq 1|Fumble

  --/This is where you can put roll modifier procedures like bless and bardic inspiration, as these will just add to the roll, they won't affect Crit or Fumble.  I will provide examples of those procedures of how I have them at the bottom.
  --=AttackRoll|[$AttackRoll] + [$BlessRoll] + [$BardicRoll]
  --?[$AttackRoll.Total] -lt @{target|npc_AC}|Miss

  --:Hit|
  --#whisper|
  -->Vulnerable|
  -->RollDamage|
  -->PlayEffects|none;none;none;[&Weapon]
  --+Hit!|Your attack hit for [$Damage] [&DamageType] damage!
  --@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]
  --?"[&SpendAmmo]" -eq "no"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Miss|
  --#whisper|
  --+Miss|Your attack missed!
  --?"[&SpendAmmo]" -eq "no"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Fumble|This will roll a fumble table for a "Bad" thing that happened and show it to everyone.  You can intrupret how you want to use it.  I got mine from https://saveversus.wordpress.com/2014/09/15/fumble-charts-dd-5th-edition/
  --#whisper|
  --=Fumblet|[T#Fumble-Table]
  -->PlayEffects|none;none;none;Failure
  --+|[img]https://media3.giphy.com/media/duexIlfr9yYwYE23UA/giphy.gif?cid=ecf05e4735w197ln6hoja74l3ikcd7t0w971w0ljtmjp000n&rid=giphy.gif&ct=g[/img]
  --+Fumble|The attack went really bad!
  --+Bad Stuff| [$Fumblet.tableEntryText]
  --=FDamage| [&DamageAmount] + [&DamageMod]
  --=FCrit|[&DamageAmount] + [&DamageMod] + [&DamageAmount] [CRIT]
  --*Possible Damage| Normal Damage is [$FDamage] and Crit Damage is [$FCrit].
  --?"[&SpendAmmo]" -eq "no"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Crit|
  --#whisper|
  -->Vulnerable|
  -->RollDamage|crit
  -->PlayEffects|none;none;none;[&Weapon]
  --+Critical Hit|You deal [$Damage] [%2%] damage CRITICAL HIT!
  --@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]
  --?"[&SpendAmmo]" -eq "no"|noAmmoSpent
  -->AmmoSpent|
  --:noAmmoSpent|
  --X|

  --:Vulnerable|
  --&vuln|
  --?"[*T:npc_vulnerabilities]" -inc "[&DamageType]"|DoubleD
  --?"[&Magical]" -inc "yes"|MagVuln
  --?"[*T:npc_resistances]" -inc "[&DamageType]"|HalfD
  --?"[*T:npc_immunities]" -inc "[&DamageType]"|immune
  --<|
  --:MagVuln|
  --?"[*T:npc_immunities]" -inc "nonmagical"|notImmune
  --?"[*T:npc_immunities]" -inc "[&DamageType]"|immune
  --:notImmune|
  --?"[*T:npc_resistances]" -inc "nonmagical"|notResistant
  --?"[*T:npc_resistances]" -inc "[&DamageType]"|HalfD
  --:notResistant|
  --<|
  --:HalfD|
  --&vuln| \ 2 [Resistant]
  --<|
  --:DoubleD|
  --&vuln| * 2 [Vulnerable]
  --<|
  --:immune|
  --+|@{target|token_name} is immune to [&DamageType] damage.
  --&vuln| * 0 [Immune]
  --<|

  --:RollDamage|
  --?[%1%] -eq crit|CritDamage
  --=Damage|[&DamageAmount] + [&DamageMod][&MagWeapDamBonus][&vuln]
  --<|
  --:CritDamage|
  --=Damage|[&DamageAmount] + [&DamageMod] + [&DamageAmount] [CRIT][&MagWeapDamBonus][&vuln]
  --<|

--/This is going to find the ammo used on the character sheet and determine how much is available.
--:GetAndCheckAmmoInformation|character_id;resourceName;Ammoname;Ammo
--?"[%2%]" -eq "[*[%1%]:class_resource_name]"|_Lib5E_IsResourceClass
--?"[%2%]" -eq "[*[%1%]:other_resource_name]"|_Lib5E_IsResourceOther
--Rfirst|[%1%];repeating_resource
--:_Lib5E_ResourceLoop|
--?"[*R:resource_left_name]" -eq "[%2%]"|_Lib5E_IsResourceLeft
--?"[*R:resource_right_name]" -eq "[%2%]"|_Lib5E_IsResourceRight
--Rnext|
--?"[*R:resource_left_name]" -ne "NoRepeatingAttributeLoaded"|_Lib5E_ResourceLoop
--&[%3%]|NotFound --&[%4%]|NotFound --$[%4%]|0 
--<|
--:_Lib5E_IsResourceClass| --&[%3%]|class_resource_name --&[%4%]|class_resource --=[%4%]|[*[%1%]:class_resource] --<|
--:_Lib5E_IsResourceOther| --&[%3%]|other_resource --&[%4%]|other_resource --=[%4%]|[*[%1%]:other_resource] --<|
--:_Lib5E_IsResourceLeft| --&[%3%]|[*R>resource_left_name] --&[%4%]|[*R>resource_left] --=[%4%]|[*R:resource_left] --<|
--:_Lib5E_IsResourceRight| --&[%3%]|[*R>resource_right_name] --&[%4%]|[*R>resource_right] --=[%4%]|[*R:resource_right] --<|
--<|


  --:AmmoAvailable|This will determine if the Ammo needed is available.
  --?[$Ammo] -eq 0|NoAmmoLeft
  --=Ammo|[$Ammo] - 1
  --<|

  --:NoAmmoLeft|This will inform the PC that they are out of that ammo they tried to use.
  --#whisper|
  --+|[*S:character_name] has no [&ResourceUsed] left.
  --#emoteText|[*S:character_name] is all out of [&ResourceUsed].
  --X|NoSlotsLeftStop

  --:AmmoSpent|This will reduce the ammo if used.
  --@setattr|_charid [*S:character_id] _[&Ammo]|[$Ammo] _silent
  --+|[&ResourceUsed] Left: [$Ammo] 
  --X|


  --:PlayEffects|Parameters are : source effect; target effect; line effect; sound effect
  --vtoken|@{selected|token_id} [%1%]
  --vtoken|@{target|token_id} [%2%]
  --vbetweentokens|@{selected|token_id} @{target|token_id} [%3%]
  --@roll20AM|_audio,play,nomenu|[&Weapon]
  --<|

  --:Profficient|
  --&PB|
  --?[&Prof] -inc "no"|NotProf
  --&PB|+ + @{pb} [PROF]
  --:NotProf|
  --<|


  --:MagicalWeapon|This will check to see if the weapon is magical and add the correct attributes.
  --&MagWeapHitBonus|
  --&MagWeapDamBonus|
  --?"[&Magical]" -inc "Yes"|YesMagic
  --<|
  --:YesMagic|
  --&MagWeapHitBonus|+ + [&MagicLvl] [Magical Weapon]
  --&MagWeapDamBonus|+ + [&MagicLvl] [Magical Weapon]
  --?"[*T:npc_type]" -inc "dragon"|dragon
  --<|
  --:dragon|
  --&MagWeapDamBonus|+ + 3d6 [Dragon Slayer]
  --<|

  --:RollResults|This will display the roll results depending on if you have Bardic inspiration or bless activated.  This will allow you to mouse over the results and see what happened.
  --?[$BardicRoll] -ge 1 -and [$BlessRoll] -ge 1|BothBardAndBless
  --?[$BardicRoll] -ge 1|BardTalk
  --?[$BlessRoll] -ge 1|BlessTalk
  --+Attack Roll|You rolled a [$AttackRoll] to hit.
  --<|
  --:BardTalk|
  --+Attack Roll|You rolled a [$AttackRoll] to hit.
  --+Bardic Inspiration|You rolled [$BardicRoll] for bardic inspiration.
  --<|
  --:BlessTalk|
  --+Attack Roll|You rolled [$AttackRoll] to hit and [$BlessRoll] from blessed.
  --<|
  --:BothBardAndBless|
  --+Attack Roll|You rolled [$AttackRoll] to hit, [$BlessRoll] from blessed, and [$BardicRoll] for bardic inspiration.
  --<|

  --:Bardic|The player character will need an attribut under the Attributes & Abilities tab called Bard.  This should get toggled on when the bard uses Bardic Inspiration on the character.
  --=BardicRoll|0
  --?@{selected|Bard} -eq 1|BardOn
  -->AfterBardic|
  --:BardOn|
  --?[$Bless] -ne 0|BardBlessed
  --+You rolled a [$AttackRoll.Base] for attack for a total of [$AttackRoll].  Do you want to use Bardic Inspiration?|[rbutton]Yes::BardYes[/rbutton][rbutton]No::AfterBardic[/rbutton]
  --X| DONE
  --:BardBlessed|
  --+You rolled a [$AttackRoll.Base] for attack for a total of [$AttackRoll].  You rolled [$BlessRoll] for blessed. Do you want to use Bardic Inspiration?|[rbutton]Yes::BardYes[/rbutton][rbutton]No::AfterBardic[/rbutton]
  --X| DONE
  --:BardYes|
  --?@{Bard|level} -eq 20|>BardDie;20
  --?@{Bard|level} -lt 20|>BardDie;@{Bard|level} \ 5 + 1 * 2 + 4
  --:BardDie|
  --=BardicRoll| 1d[%1%]
  --@setattr|_charid @{selected|character_id} _Bard|0 _silent
  -->AfterBardic|


  --:CheckBless|This will look at the savemod on the PC character sheet to see if they have bless.  I usually have Bless as the first glabal save modifier.
  --=Bless|@{selected|repeating_savemod_$0_global_save_active_flag}
  --?[$Bless] -ne 0|Blessed
  --=BlessRoll|0
  --<|
  --:Blessed|
  --=BlessRoll|1d4
  --<|

}}




August 28 (3 years ago)

5E Bardic Inspiration

This one is pretty simple.  First, you will need to add an attribute called Bard to all the other PCs.  I have the bard use the ability on another character.  

!scriptcards{{
  --#Title|Bardic Inspiration
  --#leftsub|Class Ability
  --#rightsub|Bonus Action 60 Feet
  --#sourceToken|@{selected|token_id}
  --#targetToken|@{target|token_id}

  -->GetAndCheckSlotInformation|

  --#emoteText|@{selected|token_name} gives @{target|token_name} Bardic Inspiration with some tasty jams.
  --@setattr|_charid @{target|character_id} _Bard|1 _silent
  -->PlayEffects|@{selected|token_id};@{target|token_id}|none|none|none|Bardic Inspiration
  -->ApplyDamage|

  --:GetAndCheckSlotInformation|
  --=SlotsTotal|0
  --=SlotsExpended|@{selected|repeating_resource_$0_resource_left}
  --?[$SlotsExpended] -eq [$SlotsTotal]|NoSlotsLeft
  --=SlotsExpended|[$SlotsExpended] - 1
  --<|

  --:NoSlotsLeft|
  --#emoteText|@{selected|token_name} doesn't have what it takes to cast Bardic Inspiration.
  --+|You need a long rest before you can do that again.
  --X|


  --:ApplyDamage|
  --@setattr|_charid [*S:character_id] _repeating_resource_$0_resource_left|[$SlotsExpended] _silent
  --+|bardic Inspiration Left left: [$SlotsExpended]
  --X|

  --:PlayEffects|Parameters are : sourcetoken; targettoken; source effect; target effect; line effect; sound effect
  --vtoken|[%1%] [%3%]
  --vtoken|[%2%] [%4%]
  --vbetweentokens|[%1%] [%2%] [%5%]
  --@roll20AM|_audio,play,nomenu|Bardic Inspiration
  --<|

}}

In the attack macro for the other PCs, I add this right after I check for Crit or Fumble check:

  --?[$AttackRoll.Base] -eq 20|Crit

  --?[$AttackRoll.Base] -eq 1|Fumble

  -->Bardic|

  --:AfterBardic|

  --=AttackRoll|[$AttackRoll] + [$BardicRoll]

and then I have this that will check if they have bardic inspiration and then ask if they want to use it:

  --:Bardic|
  --?@{selected|Bard} -eq 1|BardOn
  -->AfterBardic|
  --:BardOn|
  --iYou rolled a [$AttackRoll.Base] for attack for a total of [$AttackRoll].;Click this button to to decide if you want to use Bardic Inspraition.|q;maybe;Yes or No?|Yes|No|
  --?"[&maybe]" -inc "yes"|BardYes
  -->AfterBardic|
  --:BardYes|
  --=BardDie|@{Bob|class2_classlevel} \ 5 * 2 + 6
  --=BardicRoll| 1d[$BardDie]
  --+Bardic Inspiration|You added [$BardicRoll] to your roll.
  --@setattr|_charid @{selected|character_id} _Bard|0 _silent
  -->AfterBardic|

Our bard's name is Bob and he is multileveled into Bard.  You will need to change @{Bob|class2_classlevel} to match your bards name and level.  You can do the same thing for savings rolls and ability checks very easily.


I would also recommend adding this to turn it off or for a rest:

  --@setattr|_charid @{selected|character_id} _Bard|0 _silent




Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  

That's a cool script. One question though, how complicated would it be to add the limitation when encountering a wall or a door (or a window of course).

For the moment, tokens pass through the walls when blown away against one wall.

August 30 (3 years ago)

Edited August 30 (3 years ago)


My weapons script and break down. If anyone has a question send me a message and I will try to help. I am no expert at this and I am sure it can be done better but it works. 

First the code: 

!scriptcard  {{   
+++dnd5elib+++
--#title|Dagger  
--#leftsub|Melee Attack, Thrown
--#rightsub|Range: 5' :20/60, Finesse    
--#sourceToken|@{selected|token_id}   
--#targetToken|@{target|token_id}   
--#emoteText|@{selected|token_name} attacks @{target|token_name}  

--/|                >>>>> Formatting <<<<< 
  --#titlecardbackgroundimage|linear-gradient(360deg, rgba(2,0,36,1) 0%, rgba(147,39,41,1) 100%); 
  --#emoteBackground|#transparent
  --#titleCardBackground|#932729
  --#titlefontsize|1.75em
  --#titlefontlineheight|1.75em
  --#titleFontColor|white
  --#titlefontface|Shadows Into Light
  --#subtitleFontSize|12px
  --#subtitleFontFace|Verdana
  --#evenRowBackground|#B6AB91
  --#evenRowFontColor|#000000
  --#oddRowBackground|#CEC7B6
  --#oddRowFontColor|#000000


--:|What is the Base Weapons Damage express 1dx
--&BaseWeaponDamage|1d4

--:|Magic change settings here
--=Magic|0

--:|Damage Type Slashing, Bludgeoning, Piercing
--=DamageType|Piercing

--:| Check for attack mods like Bless and Damage mods like Sneak Attack 
-->Lib5E_Active_Global_Attack_Modifiers|@{selected|character_id};Bless
-->Lib5E_Active_Global_Damage_Modifiers|@{selected|character_id};Sneak;CritDam

--:|Get Targets AC
--=TargetAC|@{target|npc_ac}   
--?[$TargetAC.Total] -gt 0|DoneWithAC   
--=TargetAC|@{target|ac}   
--:DoneWithAC| 

--?[*S:strength_mod] -gt [*S:dexterity_mod]|>SetMod;strength|>SetMod;dexterity

--:|Advantage, Disadvantage, Normal
--&RollType|?{Advantage or Disadvantage?|Normal,1d20|Advantage,2d20kh1|Disadvantage,2d20kl1}

--=AttackRoll|[&RollType] [BASE] + [&FinesseMod] [MOD] + [*S:pb] [PROF] + [$Magic] [Magic] [&Bless]
--+Attack|@{selected|token_name} rolls [$AttackRoll] vs AC [$TargetAC].
--+Base roll:| [b] [$AttackRoll.Base] [/b]   
--?[$AttackRoll.Base] -eq 20|Crit   
--?[$AttackRoll.Base] -eq 1|Fumble   
--?[$AttackRoll.Total] -ge [$TargetAC.Total]|Hit  
 --+Miss|The attack missed.   
--^Final|    

--:Fumble|   
--+Fumble!|The attack went horribly wrong.   
--^Final|    

--:Hit|   
--=Damage| [&BaseWeaponDamage] + [&FinesseMod] [MOD] + [$Magic] [Magic] [&Sneak]   
--+Hit!|The attack hit @{target|token_name} for [$Damage] [$DamageType.RollText]. 
  --+Rolled:|[b][$Damage.Text] [/b]   
--@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]   
--^Healthcheck|    

--:Crit|   
  --=Damage|[&BaseWeaponDamage]+ [&FinesseMod] [MOD] + [&BaseWeaponDamage] [CRIT] [&Sneak] [&CritDam]   
  --+Critical Hit!|The attack hit @{target|token_name} for [$Damage] [$DamageType.RollText].   
  --@alter|_target|@{target|token_id} _bar|1 _amount|-[$Damage]

--:Healthcheck|
--=targethp|@{target|Bar1}-[$Damage]   
--?[$targethp] -lt 1|Dead
--^Final|

--:Dead|
--+Status:|[b]@{target|token_name} is Dead and worth @{target|npc_XP}[/b]
--@token-mod|_ids @{Target|token_id} _set statusmarkers|path-dead
--:Final|

--:SetMod|which mod to use
--&FinesseMod|[*S:[%1%]_mod]
--<|

--:Final| 
--X|
}}

What it looks like: 

Break down:


The Finesse part is use for Finesse weapons and I use --&FinesseMod|[*S:strength_mod]

Other changes I use are for Versatile and Great Weapon Fighting. 

--:|What is the Base Weapons Damage express 1dx
--&BaseWeaponDamage|1d8

--:|What is the Base Weapons Damage express 1dx 1dxro<2 re-roll once if less then 2
--&BaseWeaponDamage|1d8ro<2

--:|What is the Base Weapons Damage express 1dx
--&BaseWeaponDamage|?{ How many hands?|1,1d6|2,1d8}

--&BaseWeaponDamage|?{ How many hands?|1,1d6|2,1d8ro<2}

--&BaseWeaponDamage|?{Do you have Great Weapon Fighting?|Yes,2d6ro<2|No,2d6}

Hope this can help someone. 

Craven

August 30 (3 years ago)

I'm just starting to teach myself how to write these scripts. I want to do an Eldritch Blast. Is anyone working on this? If not I'll post what I come up with once I get it to work.


Gene S. said:

I'm just starting to teach myself how to write these scripts. I want to do an Eldritch Blast. Is anyone working on this? If not I'll post what I come up with once I get it to work.


I think that Will M. has created one on this https://github.com/MadCar-Dev/Default


Have a look at it

August 31 (3 years ago)


Lionel V. said:


Gene S. said:

I'm just starting to teach myself how to write these scripts. I want to do an Eldritch Blast. Is anyone working on this? If not I'll post what I come up with once I get it to work.


I think that Will M. has created one on this https://github.com/MadCar-Dev/Default


Have a look at it


That is really good. I want to add to it so the caster can select multiple targets and some other functionality. Thanks for the info.

September 02 (3 years ago)

Kurt, I'm trying to get this updated to check and deduct spell slots. Any guidance?

Kurt J. said:

5E Lightning Bolt (Easily changeable for other line-based spells)

September 05 (3 years ago)

Edited September 06 (3 years ago)

This is great. I'm curious if there is a way to run a macro from the script? I have a macro that i use to mark a token as dead and that automatically adds the XP to a character that i call Viewers (I got the idea from Carnivorous Meat on YouTube). Here is the macro I have:

/fx nova-blood @{selected|token_id}

/w gm @{selected|token_name} has died.

!token-mod --set statusmarkers|=dead

!token-mod --set bar3_value|0

!token-mod --set bar3_max|0

!token-mod --off light_hassight

!token-mod --off showname

!token-mod --set aura1_radius| aura2_radius| 

!wammo @{Viewers|character_id} experience [[@{selected|npc_xp}*?{Award experience (Y=1/N=0)?|1}]] EarnedXP

!noturn

 Any ideas?

Craven said:


My weapons script and break down. If anyone has a question send me a message and I will try to help. I am no expert at this and I am sure it can be done better but it works. 




September 06 (3 years ago)

Will, 

I'm trying to rework this for another spell. Is there a way to query each target for something like Hex?

Will M. said:

Spell: Scorching Ray 

My version of Scorching Ray.  Based largely on Michael C's original version but with the following differences:

  • Modified to work with TokenMod (instead of AlterBars) to apply damage.
  • Asks for targets one at a time instead of all at once. 
  • Formatting changes


September 06 (3 years ago)

Kurt,

I'm trying to update this for a breath weapon for a dragonborn character. His breath weapon is a 30ft line. How do I stop the calculation at 30ft? Also it keeps crashing my sandbox. Any ideas?

Kurt J. said:

5E Lightning Bolt (Easily changeable for other line-based spells)




September 06 (3 years ago)

With some help from Kurt and David, I made 1 change to Will's Awesome Spell Book.  Just before the Cast Spell sheetbutton, I added:

--~MacroName|string;replaceall; ;;[*R:spellname]

I then changed the button to be:

--+|[c][sheetbutton] Cast Spell 慄::@{selected|character_name}::[&MacroName][/sheetbutton][/c]

I generally have a macro for every spell.  Now I will just change the macro name to the spell name with no spaces and it uses the macro for the spell.

Thanks for the Spell Book Will and for the help David and Kurt.

Will's spell book:

https://github.com/MadCar-Dev/Default/blob/main/ScriptCards/Spellbook.sc

Will:

https://app.roll20.net/users/464055/will-m

David:

https://app.roll20.net/users/3987469/david-m

Kurt:

https://app.roll20.net/users/2365448



September 07 (3 years ago)

This looks awesome.  I might be missing something, but is there a way to tell who the target was other than AC once an action was taken?

Kurt J. said:

5E Action Menu Script

This ScriptCards script will display (to the person executing the script) a menu containing buttons for actions (NPCs), attacks (PCs) and spells (Both). These buttons can be clicked to execute the action, which will be displayed as an output card to everyone.

While not technically required, there are some features that won't work on ScriptCards below 1.3.9.

  • With any character token selected, executing the macro will present the caller with a list of actions and spells available to that character as a set of buttons.
  • Items in the Character's "Attacks & Spellcasting" section will only be displayed as actions if the AREN'T a spell (they will be displayed under the appropriate spell level instead).
  • The reentrant functions attempt to analyze the attack or spell and construct an appropriate output card. This should work for most 5e spells and attacks.
  • You can define a "spell mule" (see the beginning of the script). If you do, the script will check for Ability names on the spell mule character that match the names of the spells it is creating buttons for. If it finds on (CASE SENSITIVE) it will create a sheet button to that ability instead of a reentrant button. This allows odd-ball spells to fire their own custom scripts from the same card interface (I've got a character named "Spell_Mule" in my game, with an ability "Fireball" that contains the fireball macro. When the card is displayed and fireball is clicked it will run the full fireball script instead of trying to come up with something on its own).
  • If you wish to suppress the output of ACs from public view, change the "showGmInfo" value near the top of the script from 0 to 1.
  • If you don't upgrade to 1.3.9, the formatting will look a little weird and the spell mule stuff won't work, but otherwise the script should function.


The script is hosted on a GIST, and is available here. It is likely to be updated and revised as bugs are discovered, etc. I do intend to add support for global modifiers, but I haven't gotten there yet.

Here is a sample video using the script for a couple of PCs and NPCs, as well as how to use the "Spell_Mule" to substitute custom scripts for spells. In this case, I fire the Lightning Bolt spell without the Spell_Mule setup and then set up the mule and fire it again to see the custom script.






September 07 (3 years ago)
Kurt J.
Pro
API Scripter


Justin G. said:

This looks awesome.  I might be missing something, but is there a way to tell who the target was other than AC once an action was taken?

Kurt J. said:

5E Action Menu Script

This ScriptCards script will display (to the person executing the script) a menu containing buttons for actions (NPCs), attacks (PCs) and spells (Both). These buttons can be clicked to execute the action, which will be displayed as an output card to everyone.

While not technically required, there are some features that won't work on ScriptCards below 1.3.9.

  • With any character token selected, executing the macro will present the caller with a list of actions and spells available to that character as a set of buttons.
  • Items in the Character's "Attacks & Spellcasting" section will only be displayed as actions if the AREN'T a spell (they will be displayed under the appropriate spell level instead).
  • The reentrant functions attempt to analyze the attack or spell and construct an appropriate output card. This should work for most 5e spells and attacks.
  • You can define a "spell mule" (see the beginning of the script). If you do, the script will check for Ability names on the spell mule character that match the names of the spells it is creating buttons for. If it finds on (CASE SENSITIVE) it will create a sheet button to that ability instead of a reentrant button. This allows odd-ball spells to fire their own custom scripts from the same card interface (I've got a character named "Spell_Mule" in my game, with an ability "Fireball" that contains the fireball macro. When the card is displayed and fireball is clicked it will run the full fireball script instead of trying to come up with something on its own).
  • If you wish to suppress the output of ACs from public view, change the "showGmInfo" value near the top of the script from 0 to 1.
  • If you don't upgrade to 1.3.9, the formatting will look a little weird and the spell mule stuff won't work, but otherwise the script should function.


The script is hosted on a GIST, and is available here. It is likely to be updated and revised as bugs are discovered, etc. I do intend to add support for global modifiers, but I haven't gotten there yet.

Here is a sample video using the script for a couple of PCs and NPCs, as well as how to use the "Spell_Mule" to substitute custom scripts for spells. In this case, I fire the Lightning Bolt spell without the Spell_Mule setup and then set up the mule and fire it again to see the custom script.







I've updated the GitHub with version 1.6.5 of this script. It corrects a couple of bugs, and now enables emote display with the source/target tokens and a description of the action.

September 09 (3 years ago)

You da man.

Kurt J. said:


Justin G. said:

This looks awesome.  I might be missing something, but is there a way to tell who the target was other than AC once an action was taken?

Kurt J. said:

5E Action Menu Script

This ScriptCards script will display (to the person executing the script) a menu containing buttons for actions (NPCs), attacks (PCs) and spells (Both). These buttons can be clicked to execute the action, which will be displayed as an output card to everyone.

While not technically required, there are some features that won't work on ScriptCards below 1.3.9.

  • With any character token selected, executing the macro will present the caller with a list of actions and spells available to that character as a set of buttons.
  • Items in the Character's "Attacks & Spellcasting" section will only be displayed as actions if the AREN'T a spell (they will be displayed under the appropriate spell level instead).
  • The reentrant functions attempt to analyze the attack or spell and construct an appropriate output card. This should work for most 5e spells and attacks.
  • You can define a "spell mule" (see the beginning of the script). If you do, the script will check for Ability names on the spell mule character that match the names of the spells it is creating buttons for. If it finds on (CASE SENSITIVE) it will create a sheet button to that ability instead of a reentrant button. This allows odd-ball spells to fire their own custom scripts from the same card interface (I've got a character named "Spell_Mule" in my game, with an ability "Fireball" that contains the fireball macro. When the card is displayed and fireball is clicked it will run the full fireball script instead of trying to come up with something on its own).
  • If you wish to suppress the output of ACs from public view, change the "showGmInfo" value near the top of the script from 0 to 1.
  • If you don't upgrade to 1.3.9, the formatting will look a little weird and the spell mule stuff won't work, but otherwise the script should function.


The script is hosted on a GIST, and is available here. It is likely to be updated and revised as bugs are discovered, etc. I do intend to add support for global modifiers, but I haven't gotten there yet.

Here is a sample video using the script for a couple of PCs and NPCs, as well as how to use the "Spell_Mule" to substitute custom scripts for spells. In this case, I fire the Lightning Bolt spell without the Spell_Mule setup and then set up the mule and fire it again to see the custom script.







I've updated the GitHub with version 1.6.5 of this script. It corrects a couple of bugs, and now enables emote display with the source/target tokens and a description of the action.




September 10 (3 years ago)


Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  


Very cool!  I was able to take this and quickly modify it for my player that has the Telekinetic feat which can push or pull a target 5 ft.  But your code was supereasy to understand and will be impressive the next time they use that ability! :-)

September 11 (3 years ago)


Lionel V. said:


Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  

That's a cool script. One question though, how complicated would it be to add the limitation when encountering a wall or a door (or a window of course).

For the moment, tokens pass through the walls when blown away against one wall.

I thought about that while I was writing it, but there isn't a way to read the map layer and determine what's a wall.  It may be that you would could use the Dynamic Lighting lines to draw borders and select the option to restrict token movement.  Not sure if that would work as I've not tested it.


September 11 (3 years ago)

I tested this and lines on the Lighting Layer and with Restrict Movement option enabled, it does not prevent the token from moving through the wall.  I think this may be a limitation of tokenmod (doesn't check or respect dynamic lighting barriers).

Will M. said:


Lionel V. said:


Will M. said:

Scriptcard for "Gust of Wind" spell

The following script can be used to execute a D&D 5e "Gust of Wind" spell attack

This new script requires version 1.3.9a+ of scriptcards, specifically the new math "Angle" function.  

That's a cool script. One question though, how complicated would it be to add the limitation when encountering a wall or a door (or a window of course).

For the moment, tokens pass through the walls when blown away against one wall.

I thought about that while I was writing it, but there isn't a way to read the map layer and determine what's a wall.  It may be that you would could use the Dynamic Lighting lines to draw borders and select the option to restrict token movement.  Not sure if that would work as I've not tested it.





September 12 (3 years ago)

This is awesome for line-based spells and easily adaptable!  Thanks.  

One question: How would I only target tokens on the object layer (or remove tokens on the gm or map layer).  As it stands, if the line goes through a token on the gm layer it shows in the output (and takes damage).  Or maybe this can be an option to customize at the top (which layers to include)?

Kurt J. said:

5E Lightning Bolt (Easily changeable for other line-based spells)

NOTE: This requires v1.2.8+ of ScriptCards and uses AlterBars to apply damage.

NOTE 2: Updated on 5/19/2021 to fix a bug in the saving throw roll

This script requires a selected token and a target token. The token can be a non-creature token if you want to create one for spell targeting. The script will calculate a line between the two tokens and determine which squares are impacted by the spell and apply damage to the tokens hit taking resistance, vulnerability, and immunity into account.

The script can easily be updated for other line-based spells by changing the variables near the top of the script, including spellName, spellDamageDice, spellDamageDieType, damageType, and saveType. You can alter the list of spell levels the player can select from by changing the SpellLevel roll query.



September 13 (3 years ago)
Kurt J.
Pro
API Scripter

I have made some updates to my 5E sample scripts on the GitHub:

  • Dragon Breath has had some formatting cleaned up. I plan to do a code walkthrough youtube video on this script in the near future, so I wanted to add some additional comments and rearrange a couple of things.
  • Dragon Breath, Lightning Bolt, and Burning Hands have all been updated to allow for a "checkLayers" setting to mask out tokens on some layers. By default, both object and gmlayer tokens are included, since invisible tokens don't normally escape AOE damage just because they are invisible, but it is now customizable as a setting in all three scripts.
  • Lightning Bolt and Burning Hands have received ports of my newer apply damage code, allowing for settings for the script (alterbar or token-mod) to use and the bar to change.

The fireball sample will need more or less a complete rewrite to incorporate these features, but I'll work on that over the next week or so. I'll probably use one of the above scripts as a base for rewriting it.

September 14 (3 years ago)

That's great!  I did get it to skip tokens on the gmlayer by adjusting it with your modifications and adding: 

    --?[&checkLayers] -ninc [*[&tokenid]:t-layer]|skipThisToken

I also added this to skip over tokens that were already "dead".  I referenced the new &hitPointsBar variable.

    --?[*[&tokenid]:t-bar[&hitPointsBar]_value] -le 0|skipThisToken

Very nice.  Thanks!

Kurt J. said:

I have made some updates to my 5E sample scripts on the GitHub:

  • Dragon Breath has had some formatting cleaned up. I plan to do a code walkthrough youtube video on this script in the near future, so I wanted to add some additional comments and rearrange a couple of things.
  • Dragon Breath, Lightning Bolt, and Burning Hands have all been updated to allow for a "checkLayers" setting to mask out tokens on some layers. By default, both object and gmlayer tokens are included, since invisible tokens don't normally escape AOE damage just because they are invisible, but it is now customizable as a setting in all three scripts.
  • Lightning Bolt and Burning Hands have received ports of my newer apply damage code, allowing for settings for the script (alterbar or token-mod) to use and the bar to change.

The fireball sample will need more or less a complete rewrite to incorporate these features, but I'll work on that over the next week or so. I'll probably use one of the above scripts as a base for rewriting it.




September 14 (3 years ago)


Kurt J. said:

The fireball sample will need more or less a complete rewrite to incorporate these features, but I'll work on that over the next week or so. I'll probably use one of the above scripts as a base for rewriting it.

I ended up doing a rewrite of the fireball script for myself using the above features.  But I also do it a little differently by spawning a target icon on the caster, letting them move that to target the AoE spell, then clicking a button to "cast" the spell.  I had to reverse some of the variables since the source is now the target icon, not the spellcaster, but ended up getting it working pretty smoothly.  I look forward to seeing what you come up with on the updated Fireball script.


September 16 (3 years ago)

Scriptcard for Cone of Cold Spell

  • Based off of Kurt's Burning Hands Scriptcard
  • Can be used for Breath Weapon attack of Dragon by changing damage type.  Or prompt for damage type with ?{Damage Type|acid|cold|fire|lightning|poison}
  • Arrays are expanded for 60 ft cones (I used Excel to map out the cells).  Visually, the Up, Down, Left and Right arrays are overlapped by the Diagonals, but the arrays are the full area of effect.
  • Expanded Saving Throws section to show if target was Resistant, Immune or Vulnerable
  • Maybe some other changes, since I based this off my Burning Hands script which was based on Kurt's
!script {{
  --/|Based on Kurt's Burning Hands script. Updated arrays for 60' cone and other parameters.
  --&spellName|Cone of Cold
  
  --/|Note: because the spell will be cast at a min level of 5, we use 3 here to get the total dice (3+5=8)
  --&spellL0DamageDice|3
  
  --/|Prompt for the spell level. Update this to account for the minimum level of the spell
  --=SpellLevel|?{Spell Slot Level?|5|6|7|8|9}
  --&spellDamageDieType|8
  --&damageType|cold
  --&saveType|constitution
  --&tokenVFX|burn-frost
  --&lineVFX|breath-frost
  --/|Set this to either "token-mod", "alterbars", or anything else to not apply damage
  --&damageApplyScript|token-mod
  --/|Set this to the bar number you use to track hit points
  --&hitPointsBar|1
  --/|Set this to a list of layers to a semicolon separated check for tokens on. By default, objects and gmlayer are checked.
  --/|possible values are objects, gmlayer, and map, so to check all three, use "objects;gmlayer;map"
  --&checkLayers|objects
  
  --/|Source Token is the caster, and target token is the "end of the line". Can be a non-creature (no represents) token.
  --#sourcetoken|@{selected|token_id}
  --/|Get all of the tokens on the page so we can cache their positions
  --~|array;pagetokens;alltokens;@{selected|token_id}
  --#leftsub|Save DC @{selected|spell_save_dc}
  --#rightsub|Spell Level: [$SpellLevel] 
  --#title|[&spellName]
  --#emoteBackground|#eeffee
  --#emoteText|*@{selected|token_name} casts [&spellName].*
 -->GetAndCheckSlotInformation|
 -->DeductSpellSlot|
  --/|Calculate damage based on spell slot.
  --=DamageDice|[$SpellLevel.Total] + [&spellL0DamageDice]
  --=Damage|[$DamageDice.Total]d[&spellDamageDieType]
  --=HalfDamage|[$Damage.Total] \ 2
  --=DoubleDamage|[$Damage.Total] * 2
  --=ImmuneDamage|[$Damage.Total] * 0
  --=QuarterDamage|[$Damage.Total] \ 4
  --/|Determine damage subroutine. Start by assuming we aren't going to apply damage
  --&damageRoutine|DontApplyDamage
  --?[&damageApplyScript] -eq "token-mod"|&damageRoutine;ApplyDamageTokenmod
  --?[&damageApplyScript] -eq "alterbars"|&damageRoutine;ApplyDamageAlterbars
  --/|Since we want to be able to hover over a roll and see the dice details, output the rolled damage at the
  --/|top of the card. If all critters make their save, the half damage roll won't contain the details.
  --+|[c][b]Damage Roll: [/b][$Damage][/c]
  --+|[c]60ft cone, [$Damage.RollText] [&damageType] damage[/c] 
  
  --/|Create an array to hold the tokens that are intersected by the line.
  --~|array;define;tokensHit;
  
  -->createTokenLookup|
  --/|Prompt for a direction for the cast, and define arrays that indicate the relative spaces that will be hit.
  --&direction|?{Direction|&#x2B06; (UP),U|&#x2197; (UP-RIGHT),UR|&#x27A1; (RIGHT),R|&#x2198; (DOWN-RIGHT),DR|&#x2B07; (DOWN),D|&#x2199; (DOWN-LEFT),DL|&#x2B05; (LEFT),L|&#x2196 (UP-LEFT);,UL|}
  --~|array;define;U;0,-1;-1,-2;0,-2;1,-2;-1,-3;0,-3;1,-3;-2,-4;-1,-4;0,-4;1,-4;2,-4;-2,-5;-1,-5;0,-5;1,-5;2,-5;-3,-6;-2,-6;-1,-6;0,-6;1,-6;2,-6;3,-6;-3,-7;-2,-7;-1,-7;0,-7;1,-7;2,-7;3,-7;-4,-8;-3,-8;-2,-8;-1,-8;0,-8;1,-8;2,-8;3,-8;4,-8;-4,-9;-3,-9;-2,-9;-1,-9;0,-9;1,-9;2,-9;3,-9;4,-9;-5,-10;-4,-10;-3,-10;-2,-10;-1,-10;0,-10;1,-10;2,-10;3,-10;4,-10;5,-10;-5,-11;-4,-11;-3,-11;-2,-11;-1,-11;0,-11;1,-11;2,-11;3,-11;4,-11;5,-11;-6,-12;-5,-12;-4,-12;-3,-12;-2,-12;-1,-12;0,-12;1,-12;2,-12;3,-12;4,-12;5,-12;6,-12
  --~|array;define;D;0,1;-1,2;0,2;1,2;-1,3;0,3;1,3;-2,4;-1,4;0,4;1,4;2,4;-2,5;-1,5;0,5;1,5;2,5;-3,6;-2,6;-1,6;0,6;1,6;2,6;3,6;-3,7;-2,7;-1,7;0,7;1,7;2,7;3,7;-4,8;-3,8;-2,8;-1,8;0,8;1,8;2,8;3,8;4,8;-4,9;-3,9;-2,9;-1,9;0,9;1,9;2,9;3,9;4,9;-5,10;-4,10;-3,10;-2,10;-1,10;0,10;1,10;2,10;3,10;4,10;5,10;-5,11;-4,11;-3,11;-2,11;-1,11;0,11;1,11;2,11;3,11;4,11;5,11;-6,12;-5,12;-4,12;-3,12;-2,12;-1,12;0,12;1,12;2,12;3,12;4,12;5,12;6,12
  --~|array;define;R;1,0;2,-1;2,0;2,1;3,-1;3,0;3,1;4,-2;4,-1;4,0;4,1;4,2;5,-2;5,-1;5,0;5,1;5,2;6,-3;6,-2;6,-1;6,0;6,1;6,2;6,3;7,-3;7,-2;7,-1;7,0;7,1;7,2;7,3;8,-4;8,-3;8,-2;8,-1;8,0;8,1;8,2;8,3;8,4;9,-4;9,-3;9,-2;9,-1;9,0;9,1;9,2;9,3;9,4;10,-5;10,-4;10,-3;10,-2;10,-1;10,0;10,1;10,2;10,3;10,4;10,5;11,-5;11,-4;11,-3;11,-2;11,-1;11,0;11,1;11,2;11,3;11,4;11,5;12,-6;12,-5;12,-4;12,-3;12,-2;12,-1;12,0;12,1;12,2;12,3;12,4;12,5;12,6
  --~|array;define;L;-1,0;-2,-1;-2,0;-2,1;-3,-1;-3,0;-3,1;-4,-2;-4,-1;-4,0;-4,1;-4,2;-5,-2;-5,-1;-5,0;-5,1;-5,2;-6,-3;-6,-2;-6,-1;-6,0;-6,1;-6,2;-6,3;-7,-3;-7,-2;-7,-1;-7,0;-7,1;-7,2;-7,3;-8,-4;-8,-3;-8,-2;-8,-1;-8,0;-8,1;-8,2;-8,3;-8,4;-9,-4;-9,-3;-9,-2;-9,-1;-9,0;-9,1;-9,2;-9,3;-9,4;-10,-5;-10,-4;-10,-3;-10,-2;-10,-1;-10,0;-10,1;-10,2;-10,3;-10,4;-10,5;-11,-5;-11,-4;-11,-3;-11,-2;-11,-1;-11,0;-11,1;-11,2;-11,3;-11,4;-11,5;-12,-6;-12,-5;-12,-4;-12,-3;-12,-2;-12,-1;-12,0;-12,1;-12,2;-12,3;-12,4;-12,5;-12,6
  --~|array;define;UR;1,-1;1,-2;1,-3;2,-1;2,-2;2,-3;2,-4;2,-5;2,-6;3,-1;3,-2;3,-3;3,-4;3,-5;3,-6;3,-7;3,-8;3,-9;4,-2;4,-3;4,-4;4,-5;4,-6;4,-7;4,-8;4,-9;4,-10;4,-11;4,-12;5,-2;5,-3;5,-4;5,-5;5,-6;5,-7;5,-8;5,-9;5,-10;5,-11;5,-12;5,-13;6,-2;6,-3;6,-4;6,-5;6,-6;6,-7;6,-8;6,-9;6,-10;6,-11;6,-12;7,-3;7,-4;7,-5;7,-6;7,-7;7,-8;7,-9;7,-10;7,-11;8,-3;8,-4;8,-5;8,-6;8,-7;8,-8;8,-9;8,-10;9,-3;9,-4;9,-5;9,-6;9,-7;9,-8;9,-9;10,-4;10,-5;10,-6;10,-7;10,-8;11,-4;11,-5;11,-6;11,-7;12,-4;12,-5;12,-6;13,-5
  --~|array;define;DR;1,1;2,1;3,1;1,2;2,2;3,2;4,2;5,2;6,2;1,3;2,3;3,3;4,3;5,3;6,3;7,3;8,3;9,3;2,4;3,4;4,4;5,4;6,4;7,4;8,4;9,4;10,4;11,4;12,4;2,5;3,5;4,5;5,5;6,5;7,5;8,5;9,5;10,5;11,5;12,5;13,5;2,6;3,6;4,6;5,6;6,6;7,6;8,6;9,6;10,6;11,6;12,6;3,7;4,7;5,7;6,7;7,7;8,7;9,7;10,7;11,7;3,8;4,8;5,8;6,8;7,8;8,8;9,8;10,8;3,9;4,9;5,9;6,9;7,9;8,9;9,9;4,10;5,10;6,10;7,10;8,10;4,11;5,11;6,11;7,11;4,12;5,12;6,12;5,13
  --~|array;define;UL;-1,-1;-1,-2;-1,-3;-2,-1;-2,-2;-2,-3;-2,-4;-2,-5;-2,-6;-3,-1;-3,-2;-3,-3;-3,-4;-3,-5;-3,-6;-3,-7;-3,-8;-3,-9;-4,-2;-4,-3;-4,-4;-4,-5;-4,-6;-4,-7;-4,-8;-4,-9;-4,-10;-4,-11;-4,-12;-5,-2;-5,-3;-5,-4;-5,-5;-5,-6;-5,-7;-5,-8;-5,-9;-5,-10;-5,-11;-5,-12;-5,-13;-6,-2;-6,-3;-6,-4;-6,-5;-6,-6;-6,-7;-6,-8;-6,-9;-6,-10;-6,-11;-6,-12;-7,-3;-7,-4;-7,-5;-7,-6;-7,-7;-7,-8;-7,-9;-7,-10;-7,-11;-8,-3;-8,-4;-8,-5;-8,-6;-8,-7;-8,-8;-8,-9;-8,-10;-9,-3;-9,-4;-9,-5;-9,-6;-9,-7;-9,-8;-9,-9;-10,-4;-10,-5;-10,-6;-10,-7;-10,-8;-11,-4;-11,-5;-11,-6;-11,-7;-12,-4;-12,-5;-12,-6;-13,-5
  --~|array;define;DL;-1,1;-1,2;-1,3;-2,1;-2,2;-2,3;-2,4;-2,5;-2,6;-3,1;-3,2;-3,3;-3,4;-3,5;-3,6;-3,7;-3,8;-3,9;-4,2;-4,3;-4,4;-4,5;-4,6;-4,7;-4,8;-4,9;-4,10;-4,11;-4,12;-5,2;-5,3;-5,4;-5,5;-5,6;-5,7;-5,8;-5,9;-5,10;-5,11;-5,12;-5,13;-6,2;-6,3;-6,4;-6,5;-6,6;-6,7;-6,8;-6,9;-6,10;-6,11;-6,12;-7,3;-7,4;-7,5;-7,6;-7,7;-7,8;-7,9;-7,10;-7,11;-8,3;-8,4;-8,5;-8,6;-8,7;-8,8;-8,9;-8,10;-9,3;-9,4;-9,5;-9,6;-9,7;-9,8;-9,9;-10,4;-10,5;-10,6;-10,7;-10,8;-11,4;-11,5;-11,6;-11,7;-12,4;-12,5;-12,6;-13,5
  --/|Call the "checkForTokenHits" subroutine. The passed parameter will be the per-space VFX. Leave blank for none.
  -->checkForTokenHits|[&tokenVFX]
  --/|The first item in the array will be a blank dummy item, so remove it.
  --~|array;removeat;tokensHit;0
  
  --/|Loop through the tokensHit tokens and roll saves for each one and apply damage
  --~tokenid|array;getfirst;tokensHit
  --?[&tokenid] -eq ArrayError|endOutput
  --:loopDisplay|
  --=SaveRoll|1d20 + [*[&tokenid]:[&saveType]_save_bonus]
 --/|Make the Saving Throw, checking whether creature is immune, resistant, or vulnerable. Output Result and Apply Damage. 
  --/|Compare the save roll to the save DC and either apply full or half damage
  --?"[*[&tokenid]:npc_immunities]" -inc "[&damageType]"|Immune
  --?"[*[&tokenid]:npc_resistances]" -inc "[&damageType]"|Resistant
  --?"[*[&tokenid]:npc_vulnerabilities]" -inc "[&damageType]"|Vulnerable
  --?[$SaveRoll.Total] -lt @{selected|spell_save_dc}|>FailedSave|>madeSave
  --/|Here are various damage applications if the creature is immune, resistant, or vulnerable. In some cases, we will reuse output lines,
  --/|for example, a resistant creature that fails its save will jump to "madeSave", since that is the correct damage amount. (half), while
  --/|a vulnerable creature that makes its save will jump to "FailedSave" since that will be normal damage.
  --/|Output a line, apply damage and add status marker for a failed saving throw 
  --:FailedSave|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$Damage.Total]
  --+[*[&tokenid]:t-name]:|Fail [r][$Damage] [&damageType][/r]
  --^afterSave|
  
  --:Immune|
  --+[*[&tokenid]:t-name]:|Immune [r][$ImmuneDamage] [&damageType][/r]
  --^afterSave|
  --:Resistant|
  --?[$SaveRoll.Total] -lt @{selected|spell_save_dc}|>ResistantFail|>ResistantSave
  --^afterSave|
  --/|Output a line and apply damage for a successful saving throw for Resistant
  --:ResistantSave|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$QuarterDamage.Total]
  --+[*[&tokenid]:t-name]:|Save (Resistant) [r][$QuarterDamage] [&damageType][/r]
  --^afterSave|
  --/|Output a line, apply damage and add status marker for a failed saving throw for Resistant
  --:ResistantFail|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$HalfDamage.Total]
  --+[*[&tokenid]:t-name]:|Fail (Resistant) [r][$HalfDamage] [&damageType][/r]
  --^afterSave|
  --:Vulnerable|
  --?[$SaveRoll.Total] -lt @{selected|spell_save_dc}|>VulnerableFail|>VulnerableSave
  --^afterSave|
  --/|Output a line for a successful saving throw for Vulnerable
  --:VulnerableSave|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$Damage.Total]
  --+[*[&tokenid]:t-name]:|Save (Vulnerable) [r][$Damage] [&damageType][/r]
  --^afterSave|
  --/|Output a line, apply damage and status marker for a failed saving throw for Vulnerable
  --:VulnerableFail|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$DoubleDamage.Total]
  --+[*[&tokenid]:t-name]:|Fail (Vulnerable) [r][$DoubleDamage] [&damageType][/r]
  --^afterSave|
  --/|Output a line and apply damage for a successful saving throw
  --:madeSave|
  -->[&damageRoutine]|[&tokenid];[&hitPointsBar];[$HalfDamage.Total]
  --+[*[&tokenid]:t-name]:|Save [r][$HalfDamage] [&damageType][/r]
  
  --:afterSave|
  --~tokenid|array;getnext;tokensHit
  --?[&tokenid] -ne ArrayError|loopDisplay
  --/|Put a visual effect on impacted tokens
  --vtoken|[&tokenid] [&tokenVFX]
  --~tokenid|array;getnext;inRange
  --?[&tokenid] -ne ArrayError|loopDisplay
  --/|Add some extra visual effects - a nova-fire at the target, and a beam-fire from source to target
  --vbetweentokens|@{selected|token_id} @{target|token_id} [&lineVFX]
  --:endOutput| 
  --X|
  
  --:ApplyDamageTokenmod|Parameters are tokenid;bar#;amount
  --@token-mod|_ignore-selected _ids [%1%] _set bar[%2%]_value|-[%3%]!
  --<| 
  --/|AlterBars supports relative values for the amount parameter, so we just pass it the value with a "-" in front of it.
  --:ApplyDamageAlterbars|Parameters are tokenid;bar#;amount
  --@alter|_target|[%1%] _bar|[%2%] _amount|-[%3%] _show|none
  --<|
  --/|Just a dummy routine that doesn't do anything, but it is easier to do it this way than adding logic to see if we are
  --/|skipping applying damage in the main routine.
  --:DontApplyDamage|
  --<|
   
  --:checkForTokenHits|parameter is vfx descriptor
  --=baseX|[*S:t-left] - 1 \ 70
  --=baseY|[*S:t-top] - 1 \ 70
  --~offset|array;getfirst;?{Direction}
  --:checkTokenLoop|
  --?"[&offset]" -eq "ArrayError"|endCheckForTokenHits
  --~split|string;split;,;[&offset]
  --=thisX|[$baseX] + [&split1]
  --=thisY|[$baseY] + [&split2]
  --/|IF we passed a visual effect specifier in %1%, create a point VFX in the square
  --?"X[%1%]X" -ne "XX" |[
    --=VX|[$thisX] * 70 + 35   
    --=VY|[$thisY] * 70 + 35   
    --vpoint|[$VX] [$VY] [%1%]
  --]|
  -->checkTokens|[$thisX];[$thisY]
  --~offset|array;getnext;?{Direction}
  --^checkTokenLoop|
  --:endCheckForTokenHits|
  --<|
    
  --/|Reads the variables created by createTokenLookup to find any tokens that occupy a given space.
  --:checkTokens|x;y
  --?"X[&tok[%1%]-[%2%]]X" -ne "XX"|[
  --~split|string;split;!;[&tok[%1%]-[%2%]]
  --%P|1;[$splitCount.Total];1
  --=var|split[&P]
  --?"X[&[$var.RollText]]X" -eq "XX"|%
  --~exists|array;indexof;tokensHit;[&[$var.RollText]]
  --?[&exists] -ne ArrayError|skipAdd
  --?[&[$var.RollText]] -eq ArrayError|skipAdd
  --~|array;add;tokensHit;[&[$var.RollText]]
  --:skipAdd|
  --%|
  --<|
  
  --/|Creates a series of string variables with names like 'tok12-15' which represent the various squares that are
  --/|occupied by tokens on the page. Handle 1x1, 2x2, and 3x3 tokens by simply adding extra squares in the appropriate
  --/|pattern around the center point location. The result is that if there are two tokens at 12,15, the tok12-15 string
  --/|will contain something like "-asln34njfn2nafd!-sdnfklaserfs" (IDs separated by exclamation points) that we can use to
  --/|quickly evaluate hits by essentially asking "what is in square 12x15" by just reading the variable.
  --:createTokenLookup|
  --~tokenid|array;getfirst;alltokens
  --:tokenSetupLoop|
    --?[&tokenid] -eq ArrayError|endSetupLoop
    --?[&checkLayers] -ninc [*[&tokenid]:t-layer]|skipThisToken
    --?[*[&tokenid]:t-bar[&hitPointsBar]_value] -le 0|skipThisToken
    --=tLeft|[*[&tokenid]:t-left] - 1 \ 70
  --=tTop|[*[&tokenid]:t-top] - 1 \ 70
  --=tWidth|[*[&tokenid]:t-width]
  --?[$tWidth] -eq 70|[ 
    --&tok[$tLeft]-[$tTop]|+[&tokenid]!
    --/+[*[&tokenid]:character_name]|At [$tLeft],[$tTop] : [&tok[$tLeft.Total]-[$tTop.Total]]
  --]|
  --?[$tWidth] -eq 140|[ 
    --=NX|[$tLeft] + 1
    --=NY|[$tTop] + 1
    --&tok[$tLeft]-[$tTop]|+[&tokenid]!
    --&tok[$tLeft]-[$NY]|+[&tokenid]!
    --&tok[$NX]-[$tTop]|+[&tokenid]!
    --&tok[$NX]-[$NY]|+[&tokenid]!
  --]|
  --?[$tWidth] -eq 210|[ 
    --=PX|[$tLeft] - 1
    --=PY|[$tTop] - 1
    --=NX|[$tLeft] + 1
    --=NY|[$tTop] + 1
      --&tok[$tLeft]-[$tTop]|+[&tokenid]!
      --&tok[$PX]-[$PY]|+[&tokenid]!
    --&tok[$tLeft]-[$PY]|+[&tokenid]!
    --&tok[$NX]-[$PY]|+[&tokenid]!
      --&tok[$PX]-[$tTop]|+[&tokenid]!
    --&tok[$NX]-[$tTop]|+[&tokenid]!
      --&tok[$PX]-[$NY]|+[&tokenid]!
      --&tok[$tLeft]-[$NY]|+[&tokenid]!
      --&tok[$NX]-[$NY]|+[&tokenid]!
  --]|
  --:skipThisToken|
  --~tokenid|array;getnext;alltokens
  --^tokenSetupLoop|
  --:endSetupLoop|
  --<|
  --:GetAndCheckSlotInformation|
    --=SlotLevel|[$SpellLevel]
    --=SlotsTotal|[*S:lvl[$SlotLevel]_slots_total]
    --=SlotsExpended|[*S:lvl[$SlotLevel]_slots_expended]
    --?[$SlotsExpended.Total] -eq 0|NoSlotsLeft
    --?[$SlotsExpended.Total] -gt [$SlotsTotal.Total]|NoSlotsLeft
  --<| 
  --:DeductSpellSlot|
    --=SlotsExpended|[$SlotsExpended] -1 
    --@setattr|_charid [*S:character_id] _lvl[$SlotLevel]_slots_expended|[$SlotsExpended] _silent
    --=SlotsRemaining|[$SlotsTotal] - 1 
  --<|
  --:NoSlotsLeft|
    --+|[b][*S:character_name] has no level [$SlotLevel.Total] spell slots available.[/b]
  --X|NoSlotsLeftStop
}}


October 04 (3 years ago)

Edited October 05 (3 years ago)

Fortune Teller Script

A fun and creative role playing random fortune generator script with over 940,000 different possible outcomes.  

I was watching an old episode of "Critical Role" and saw how they incorporated a fortune teller into the story.  I absolutely suck at just making stuff up out of thin air like they can - I need prompts to help get the brain working.  So I did some research and developed this fun tool to help me improve my creative role play.  I give credit to the reddit article and author below that inspired this script if you want to research further.  

Use:  

Have player execute the script with their token selected.

Script will then select 3 separate cards for the GM to weave a fortune around (See image below).

  1. An event
  2. A person
  3. An outcome

It displays the 3 cards selected to the group chat, and whispers the extra detail/color text to the GM. 

For future reference, it will also append the detailed card info to the selected character's GM Notes field if you have The Aaron's gmnote script (See link below in requirements).  

The GM then uses the Detailed/Color text as inspiration to generate a custom fortune (scriptcards can't do all the work for you).  

Note: You can have the player execute this once for a simple fortune, or three times, one for past, one for present and one for future.  

Credits:  This is based on an article and accompanying table I found on reddit by user Bellociraptor (reddit Link).


Requirements:


!script {{

  --/|Script Name : FortuneTeller
  --/|Version     : 1.0
  --/|Requires SC : 1.4.0+
  --/|Other APIs  : SelectManager, gmnote (by The Aaron) "https://app.roll20.net/forum/post/5285545/can-token-mod-be-used-to-set-gm-notes/?pageforid=5297154#post-5297154"
  --/|Author      : Will M.

  --/|Description : Random Fortune Selector
  --/|

  --:TOP|
  --#reentrant|FortuneTeller
  --#title|Fortune Teller
  --#hideTitleCard|1
  
  --#titleCardBackground|#03038a
  --#oddRowBackground|#111111
  --#evenRowBackground|#111111
  --#oddRowFontColor|#C9A807 
  --#evenRowFontColor|#EFC809  

  --#sourceToken|@{selected|token_id}
  --#hidecard|0    
  --#emoteState|visible
  --#emoteText|@{selected|character_name} is dealt three cards

  --#bodyFontFace|Shadows Into Light
  --#bodyFontSize|2.0em 

  --/#whisper|self
  --#debug|0
  
  --/|Event/Card
  --=SelCard1|1d98
  --=SelCard2|1d98
  --=SelCard3|1d98    

  --/|Event
  -->R[$SelCard1.Raw]|
  --&SelCardName1|[&CardName]
  --&SelEvent|[&Event]

  --/|Person to be encountered
  -->R[$SelCard2.Raw]|
  --&SelCardName2|[&CardName]
  --&SelPerson|[&Person]

  --/|Outcome - Near to mid Future
  -->R[$SelCard3.Raw]|
  --&SelCardName3|[&CardName]
  --&SelOutcome|[&Outcome]

  --/| Output Fortune
  --+|[img]https://i.imgur.com/3kQPYrm.gif[/img] 

  --+|[c][&SelCardName1][/c][br]
  --+|[c][&SelCardName2][/c][br]
  --+|[c][&SelCardName3][/c]
  
  --/| Send details to GM
  
  --&tStyle|style="width:100%;padding:1px;border-spacing:0px;border-collapse:collapse;text-shadow: 0px 0px 0px black;border:0px dashed black;"
  --&trStyle1|style="border-top:1px dashed black;"
  --&trStyle2|style="border:0px dashed black;"
  --&tdStyle1|style="width:100%;text-align:center;background-color:#FFFFFF;font-family:Tahoma;font-size:12px;font-weight:bold;"
  --&tdStyle2|style="width:100%;text-align:center;background-color:#FFFFFF;font-family:Tahoma;font-size:12px;"
  

  --*|[t [&tStyle]]
        [tr [&trStyle1]] [td [&tdStyle1]]Event Card: [&SelCardName1]([$SelCard1.Raw])[/td][/tr] 
        [tr [&trStyle2]] [td [&tdStyle2]][&SelEvent][/td][/tr]
        [tr [&trStyle1]] [td [&tdStyle1]]Person Card: [&SelCardName2]([$SelCard2.Raw])[/td][/tr] 
        [tr [&trStyle2]] [td [&tdStyle2]][&SelPerson][/td][/tr]
        [tr [&trStyle1]] [td [&tdStyle1]]Outcome Card: [&SelCardName3]([$SelCard3.Raw])[/td][/tr] 
        [tr [&trStyle2]] [td [&tdStyle2]][&SelOutcome][/td][/tr]
      [/t]

  --/| Log the fortune to the GM notes of the player
  --&Log|Card #1(An Event) [&SelCardName1]: [&SelEvent] - Card #2(A Person) [&SelCardName2]: [&SelPerson] - Card #3 (An Outcome) [&SelCardName3]: [&SelOutcome]
  --@forselected+|add-cgmnote Fortune: [&Log]

  --X|

  --:R1|  --&CardName|The Crimson King  --&Event|Uncovering dangerous secrets  --&Outcome|Knowledge at great cost  --&Person|Powerful and dangerous man  --<|
  --:R2|  --&CardName|The Scarlett Queen  --&Event|Dangerous bargains  --&Outcome|Victory only at great cost  --&Person|Powerful and dangerous woman  --<|
  --:R3|  --&CardName|The Cardinal Knight  --&Event|Violence or War  --&Outcome|End reached through bloody conflict  --&Person|Angry or violent young man  --<|
  --:R4|  --&CardName|The Azure King  --&Event|Time of learning  --&Outcome|Knowledge will prove invaluable  --&Person|Sage or scholar  --<|
  --:R5|  --&CardName|The Cobalt Queen  --&Event|Something forgotten will return  --&Outcome|Forgetting a wrong or slight will cause it to happen again  --&Person|You never thought youd see him again  --<|
  --:R6|  --&CardName|The Cyan Knight  --&Event|Facing the consequences of ignorance  --&Outcome|What you dont know will hurt you  --&Person|Unexpected enemy  --<|
  --:R7|  --&CardName|The Viridian King  --&Event|Consequences  --&Outcome|Someone you wronged will have their revenge  --&Person|With a personal grudge  --<|
  --:R8|  --&CardName|The Emerald Queen  --&Event|Conspiracies  --&Outcome|A plot against you will play out  --&Person|Jealous woman  --<|
  --:R9|  --&CardName|The Jade Knight  --&Event|Rivalries  --&Outcome|If you dont take them seriously enough, a rival will best you  --&Person|Rival  --<|
  --:R10|  --&CardName|The Obsidian King  --&Event|A warned event will come to pass  --&Outcome|Success or failure will depend on how warnings were heeded  --&Person|Male practitioner of dark magic  --<|
  --:R11|  --&CardName|The Onyx Queen  --&Event|A change of forture  --&Outcome|A reversal, either good or bad  --&Person|Woman whose first impression matters  --<|
  --:R12|  --&CardName|The Black Knight  --&Event|A grudge  --&Outcome|You will make an enduring enemy  --&Person|Soldier from a defeated army  --<|
  --:R13|  --&CardName|The Bone King  --&Event|News of a death  --&Outcome|Final endings  --&Person|Dying man  --<|
  --:R14|  --&CardName|The Frost Queen  --&Event|Loss of someone powerfuls favor  --&Outcome|Fall from grace  --&Person|Widow  --<|
  --:R15|  --&CardName|The Pale Knight  --&Event|Return of a trouble thought over  --&Outcome|Recurring trouble  --&Person|Thought to be dead  --<|
  --:R16|  --&CardName|The Herald of Sorrows  --&Event|Bad news  --&Outcome|Things will end poorly for someone close  --&Person|Tragic youth  --<|
  --:R17|  --&CardName|The Kings Assassin  --&Event|A betrayal by someone powerful  --&Outcome|Make a powerful enemy  --&Person|Traitor in a position of advantage  --<|
  --:R18|  --&CardName|The Queens Thief  --&Event|Underhanded dealings  --&Outcome|Loss of something valuable  --&Person|Charming rogue  --<|
  --:R19|  --&CardName|The Conqueror  --&Event|A shift in personal power  --&Outcome|Dramatic gain or loss of power  --&Person|Ambitious man  --<|
  --:R20|  --&CardName|The High Priest  --&Event|A test of faith (Religious or otherwise)  --&Outcome|Success or loss depends on the aid of others  --&Person|Of devout or religious order  --<|
  --:R21|  --&CardName|The Witch  --&Event|A string of bad luck  --&Outcome|Something will have to be set right before luck can turn  --&Person|Female practitioner of dark magic  --<|
  --:R22|  --&CardName|The Gypsy  --&Event|Scams and false flattery  --&Outcome|Trust the wrong people, and they will take you for a ride  --&Person|Young and charming  --<|
  --:R23|  --&CardName|The Jester  --&Event|Loss or respect or jokes at your expense  --&Outcome|You will be made a laughingstock  --&Person|Whose reputation has suffered  --<|
  --:R24|  --&CardName|The Virgin  --&Event|Unfamiliar circumstances  --&Outcome|You will be forced to navigate a challenge unprepared  --&Person|Innocent  --<|
  --:R25|  --&CardName|The Whore  --&Event|A financial loss  --&Outcome|May fall prey to excessive spending  --&Person|Ambitious woman  --<|
  --:R26|  --&CardName|The Alchemist  --&Event|Physical or Spiritual transition  --&Outcome|Irreversible personal change  --&Person|Practitioner of strange sciences  --<|
  --:R27|  --&CardName|The Physician  --&Event|Aid from another  --&Outcome|Slow healing physical, mental, or spiritual wounds  --&Person|You already put faith in (Parent, teacher, etc.)  --<|
  --:R28|  --&CardName|The Occultist  --&Event|Painful Knowledge  --&Outcome|Something wicked comes  --&Person|Who should not be here  --<|
  --:R29|  --&CardName|The Hunter  --&Event|Gains through long pursuit  --&Outcome|The chase will yield its prizes  --&Person|On a quest or mission  --<|
  --:R30|  --&CardName|The Bleeding Man  --&Event|Pain  --&Outcome|No matter the outcome, the path will be suffering  --&Person|Victim or persecution or torture  --<|
  --:R31|  --&CardName|The Scarred Man  --&Event|Changed by suffering  --&Outcome|Painful events will have lasting ramifications  --&Person|Carries the physical or mental marks of a great wrong  --<|
  --:R32|  --&CardName|The Judge  --&Event|Decisions  --&Outcome|Positive outcomes only achieved if choices are made with reason, not passion  --&Person|Older man in a position of authority  --<|
  --:R33|  --&CardName|The Jury  --&Event|Judgement  --&Outcome|Outcome determined by others  --&Person|Group of strangers  --<|
  --:R34|  --&CardName|The Headsman  --&Event|The Rule of Law  --&Outcome|Law upheld  --&Person|Lawman  --<|
  --:R35|  --&CardName|The Traveler  --&Event|A journey  --&Outcome|A change of locations  --&Person|From far away  --<|
  --:R36|  --&CardName|The Twins  --&Event|A powerful bond  --&Outcome|Live or die for someone  --&Person|With a powerful spiritual bond to the drawer or two people bonded to each other (identical twins, soul mates, etc.)  --<|
  --:R37|  --&CardName|Sacrifice  --&Event|A willing loss  --&Outcome|Results for others worth personal cost  --&Person|Man willingly suffering  --<|
  --:R38|  --&CardName|Birth  --&Event|Gain that will change everything  --&Outcome|Someone or something will come into your life that will drastically alter it  --&Person|Pregnant woman  --<|
  --:R39|  --&CardName|Death  --&Event|Complete transition  --&Outcome|Irreversible change  --&Person|In mourning  --<|
  --:R40|  --&CardName|The Wedding  --&Event|Unification and bonds  --&Outcome|Formation of loves, friendships, or strong alliances  --&Person|New and close friend or ally  --<|
  --:R41|  --&CardName|The Funeral  --&Event|An ending or conclusion  --&Outcome|Bittersweet parting  --&Person|Who has come to you because of a mutual loss  --<|
  --:R42|  --&CardName|The Tournament  --&Event|An exciting challenge  --&Outcome|A shot at glory  --&Person|Friendly rival  --<|
  --:R43|  --&CardName|Feast  --&Event|Joy and festicity  --&Outcome|Impressive but temporary gains  --&Person|Wealthy and generous man  --<|
  --:R44|  --&CardName|Famine  --&Event|Times of need  --&Outcome|Crushing but temporary losses  --&Person|Miser  --<|
  --:R45|  --&CardName|Reincarnation  --&Event|New beginnings  --&Outcome|The start of a new life  --&Person|Who has undergone a recent transition  --<|
  --:R46|  --&CardName|The Ravens  --&Event|Aftermath of tragedy  --&Outcome|Profiting from loss  --&Person|Opportunist or Profiteer  --<|
  --:R47|  --&CardName|The White Wolf  --&Event|Spiritual awakening  --&Outcome|A personal epiphany  --&Person|Spiritualist  --<|
  --:R48|  --&CardName|The Black Dog  --&Event|Misfortune  --&Outcome|No way to get out unscathed  --&Person|Cursed  --<|
  --:R49|  --&CardName|The Red Stallion  --&Event|An adventure  --&Outcome|A new and exciting experience  --&Person|Bold adventurer  --<|
  --:R50|  --&CardName|The Silver Stag  --&Event|A chase or pursuit  --&Outcome|Chance at an elusive prize  --&Person|Enigmatic stranger  --<|
  --:R51|  --&CardName|The Bull  --&Event|Rapid progress  --&Outcome|Ends achieved through brute force and determination  --&Person|Laborer or someone of similar origins  --<|
  --:R52|  --&CardName|The Goat  --&Event|Overcoming obstacles  --&Outcome|Resilience and tenacity will win the day  --&Person|From harsh circumstances  --<|
  --:R53|  --&CardName|The Cat  --&Event|You will overhear something  --&Outcome|Solutions will come through subtlety and discretion  --&Person|Frequently disregarded or underestimated  --<|
  --:R54|  --&CardName|The Rat  --&Event|Subterfuge and underhanded dealings  --&Outcome|The most clever will win  --&Person|Spy or thief  --<|
  --:R55|  --&CardName|The Two-Headed Serpent  --&Event|Flattery and false promises  --&Outcome|Grave consequences if you trust the wrong person  --&Person|Charming liar  --<|
  --:R56|  --&CardName|The Spider  --&Event|Beware of traps and snares  --&Outcome|Failure unless you spot all the complications  --&Person|Of few words and complex machinations  --<|
  --:R57|  --&CardName|The Mermaid  --&Event|Seduction and risky affairs  --&Outcome|heartbreak and tragic endings  --&Person|Heartsick woman  --<|
  --:R58|  --&CardName|The Manticore  --&Event|Close alliances and co-conspirators  --&Outcome|your misdeeds will bind you to your partners in crime  --&Person|Gang or party  --<|
  --:R59|  --&CardName|The Viper  --&Event|Meddling in places you dont belong  --&Outcome|there week be a cost for getting involved in matters that are not your place  --&Person|Dangerous loner  --<|
  --:R60|  --&CardName|The Leviathan  --&Event|A natural or unavoidable disaster  --&Outcome|outcome determined by circumstances beyond your control  --&Person|Linked to the Void  --<|
  --:R61|  --&CardName|The Scorpion  --&Event|Someone will try and ruin you  --&Outcome|You will be struck at at every turn  --&Person|Has a petty grudge  --<|
  --:R62|  --&CardName|The Wasps  --&Event|Mass hysteria and mob rule  --&Outcome|outcome will be decided by the crowd  --&Person|Group or mob  --<|
  --:R63|  --&CardName|The Bear  --&Event|Guarding that which you love  --&Outcome|Someone or something you care about will rely on you to aid them  --&Person|Protective older person  --<|
  --:R64|  --&CardName|The Sword  --&Event|Strength  --&Outcome|Your strength will determine the outcome  --&Person|Knight or military officer  --<|
  --:R65|  --&CardName|The Spear  --&Event|Protection  --&Outcome|Your ability to protect someone or something will determine the outcome  --&Person|Guard or soldier  --<|
  --:R66|  --&CardName|The Axe  --&Event|You will be the agent of justice  --&Outcome|Your judgement or actions will determine if justice is served  --&Person|Vigilante  --<|
  --:R67|  --&CardName|The Hammer  --&Event|Force  --&Outcome|Outcome will be determined by martial prowess  --&Person|Ruffian or barbarian  --<|
  --:R68|  --&CardName|The Knife  --&Event|Guile  --&Outcome|Outcome will be determined by cunning  --&Person|Courtier or diplomat  --<|
  --:R69|  --&CardName|The Rose  --&Event|Winning fame or favor  --&Outcome|You success will earn you reputation and acclaim  --&Person|Young and beautiful woman  --<|
  --:R70|  --&CardName|The Broken Tower  --&Event|Calamity  --&Outcome|Failure of Endeavors  --&Person|Who has suffered a recent failure.  --<|
  --:R71|  --&CardName|The Bridge  --&Event|Joining together of two unlikely things  --&Outcome|Unexpected alliances  --&Person|Foe turned friend  --<|
  --:R72|  --&CardName|The Gallows Tree  --&Event|Punishment  --&Outcome|Making amends for your actions or words  --&Person|Criminal  --<|
  --:R73|  --&CardName|The Poisoned Cup  --&Event|A gift, reward, or treasure will bring misfortune  --&Outcome|Even an apparent success will reap sorrow  --&Person|Will try to ply you with false generosity  --<|
  --:R74|  --&CardName|The Chalice  --&Event|Joy and reward  --&Outcome|Your endeavors will yield success and great gains  --&Person|Famous  --<|
  --:R75|  --&CardName|The Sea  --&Event|Journey over water  --&Outcome|Cross a great physical distance  --&Person|Fickle woman  --<|
  --:R76|  --&CardName|The Lightning Struck Ship  --&Event|A difficult journey  --&Outcome|A life-or-death struggle  --&Person|Sudden adversary  --<|
  --:R77|  --&CardName|The Desert  --&Event|Loneliness and isolation  --&Outcome|A struggle that must be faced alone  --&Person|Wanderer or hermit  --<|
  --:R78|  --&CardName|The Mountain  --&Event|Test of physical or mental endurance  --&Outcome|Toughness will win the day  --&Person|Unusually large person  --<|
  --:R79|  --&CardName|The Forest  --&Event|Confounding factors and unclear paths  --&Outcome|A confusing journey, easy to lose sight of the purpose  --&Person|Woodsman or ranger  --<|
  --:R80|  --&CardName|The Path  --&Event|Clarity of purpose  --&Outcome|Intent and purpose will be clear or obnvious  --&Person|Tracker or guide  --<|
  --:R81|  --&CardName|The Stairway  --&Event|Opportunities  --&Outcome|Great things if you proceed carefully, a terrible slip and fall if you do not  --&Person|Architect or builder  --<|
  --:R82|  --&CardName|The Rising Sun  --&Event|New beginnings and limitless potential  --&Outcome|Your actions in the immediate future will have long-lasting benefits or consequences  --&Person|Young child  --<|
  --:R83|  --&CardName|The Sun at Zenith  --&Event|Hard work will yield great benefits  --&Outcome|You will sow and reap in equal measure  --&Person|Respected and established in their trade  --<|
  --:R84|  --&CardName|The Setting Sun  --&Event|Rest and peaceful conclusions  --&Outcome|The ending of a job or similar  --&Person|Retired person  --<|
  --:R85|  --&CardName|The New Moon  --&Event|The unknown  --&Outcome|Unexpected event will change everything  --&Person|Blind man  --<|
  --:R86|  --&CardName|The Crescent Moon  --&Event|Half-truths and incomplete predictions  --&Outcome|Unsatisfactory conclusions and unfinished business  --&Person|Restless youth  --<|
  --:R87|  --&CardName|The Full Moon  --&Event|True predictions  --&Outcome|An unfolding of prophecy or fortunes  --&Person|Seer  --<|
  --:R88|  --&CardName|Wind  --&Event|Constant changes and reversals  --&Outcome|No results, good or bad, will endure for long  --&Person|Moody or unstable person  --<|
  --:R89|  --&CardName|Snow  --&Event|Confusion and obfuscation  --&Outcome|You will remain in ignorance or confusion  --&Person|Mute  --<|
  --:R90|  --&CardName|The Star  --&Event|A quest or journey  --&Outcome|the start of a new mission  --&Person|Mentor or guide  --<|
  --:R91|  --&CardName|The Demon  --&Event|Punishment  --&Outcome|All sins punished  --&Person|Torturer  --<|
  --:R92|  --&CardName|The Devil  --&Event|Bargains and deals  --&Outcome|An arrangement twisted against you  --&Person|Drafter of contracts  --<|
  --:R93|  --&CardName|The Fey  --&Event|Mysteries  --&Outcome|Inconclusive or strange endings  --&Person|Mysterious or unknown person  --<|
  --:R94|  --&CardName|The Dragon  --&Event|A life-changing challenge  --&Outcome|Death or glory  --&Person|Powerful adversary  --<|
  --:R95|  --&CardName|Dreams  --&Event|Unlikely adventures or encounters with the uncanny  --&Outcome|The ending will be a far cry from where you began  --&Person|Fae-touched  --<|
  --:R96|  --&CardName|Nightmares  --&Event|Things long-feared will come to pass  --&Outcome|Things will appear far worse before they get better  --&Person|Madman  --<|
  --:R97|  --&CardName|Time  --&Event|Facing the inevitable  --&Outcome|Change that you are powerless to fight  --&Person|Important from your past  --<|
  --:R98|  --&CardName|The Treasure Hoard  --&Event|The prize at the end of the challenge  --&Outcome|Great reward after great challenge or suffering  --&Person|You will have to fight for  --<|
  --:R99|  --&CardName|The DMs Choice  --&Event|Choose something DM  --&Outcome|Choose something DM  --&Person|Choose something DM  --<|
  --:R100|  --&CardName|Something that should not be  --&Event|Make up a card that isnt in the deck.  --&Outcome|Make up a card that isnt in the deck.  --&Person|Make up a card that isnt in the deck.  --<|

  --X|

}}
  • Fortune Teller Script - Link
October 04 (3 years ago)

Edited October 05 (3 years ago)

Set Monster HP (With a Twist)

This is a GM utility to quickly establish HP for all selected NPCs on the page, with a Twist.  That Twist being that it gives you the option to select from several methods (described below) to calculate HP.  It ignores PC tokens and tokens not tied to a character sheet.

This is handy when you want to either randomize monster HP, or even randomize with a greater chance of getting higher or lower HP values.  

Methods:

  • Default - Standard static HP based on NPC_HPFormula (no randomness)
  • Random - Uses the NPC_HPFormula to derive HP
  • Random High (x Rolls) - Will take the highest value of x(2,5, or 10) random rolls.
  • Random Low (x Rolls) - Will take the lowest value of x(2,5, or 10) random rolls. 
  • Adder - A value (+/-) to add to the final result.  Can also be in roll syntax (e.g.; 2d6)
Use:
  1. Select all tokens you wish to establish a new HP
  2. Execute Script
  3. Select a method (Default, Random, Random High 2, Random High 5, Random High 10, Random Low 2, Random Low 5, Random Low 10)
  4. Input an adder (example possible values: 0, 8, -3, 2d6)

The script will then calculate HP for all selected tokens based on the desired method, setting the token's HP accordingly.

The "Random High 5" will randomly execute the npc_hpformula 5 times and keep the highest result.  This should normally producer higher HPs than the default and simple Random method.  

Requirements:

  • Scriptcards 1.4.0+
  • TokenMod

Configuration Item:

  • Token HPField:  Around Line 30 of the code there is a variable HPField, that needs to be set to the field you use for HP in your campaign.  It's current value is bar1_value.  Set to bar3_value if you use bar3 for tracking HP.  
!script {{  
  --/|Script Name : Set Monster HP
  --/|Version     : 1.0
  --/|Requires SC : 1.4.0+
  --/|Author      : Will M.

  --/|Description : Utility function that resets all selected NPC hps based on the HPFormula (with a twist)
  --/|              Twist - It allows for the following HP calcs:
  --/|                Default - Standard static HP based on HPFormula (no randomness)
  --/|                Random - Uses the HPFormula to derive HP
  --/|                Random High (x Rolls) - Will take the highest value of x(2,5, or 10) rolls. 
  --/|                Random Low (x Rolls) - Will take the lowest value of x(2,5, or 10) rolls. 
  --/|
  --/|                Adder - A value (+/-) to add to the final result

  --#title|Set Monster HP
  --#reentrant|SetMonsterHP
  --#titleCardBackground|#932729
  --#whisper|self
  --#oddRowBackground|#FFFFFF
  --#evenRowBackground|#FFFFFF
  --#buttonbackground|#FFFFFF
  --#buttontextcolor|#0905f2
  --#buttonbordercolor|#FFFFFF
  --#bodyFontSize|11px
  --#debug|1

  --/| set to bar2_value or bar3_value if you use one of those two for tracking HP
  --&HPField|bar1_value
  
  --/| Modes 0-Default,1-Random,2-Random (High), 3 Random (Low)
  --&Mode|0
  --&Adder|0
  --&HP_ROLL_COUNT|0

  --&Mode|?{HP Set Mode?|Default,0|Random,1|Random High(2 Rolls),2.2|Random High(5 Rolls),2.5|Random High(10 Rolls),2.10|Random Low(2 Rolls),3.2|Random Low(5 Rolls),3.5|Random Low(10 Rolls),3.10}
  --&Adder|?{Additional Adder|0}  
  --+Adder|[&Adder]
  --?[&Mode] -eq 2.2|[ --&Mode|2 --&HP_ROLL_COUNT|2 --]|
  --?[&Mode] -eq 2.5|[ --&Mode|2 --&HP_ROLL_COUNT|5 --]|
  --?[&Mode] -eq 2.10| [ --&Mode|2 --&HP_ROLL_COUNT|10 --]|
  --?[&Mode] -eq 3.2|[ --&Mode|3 --&HP_ROLL_COUNT|2 --]|
  --?[&Mode] -eq 3.5|[ --&Mode|3 --&HP_ROLL_COUNT|5 --]|
  --?[&Mode] -eq 3.10|[ --&Mode|3 --&HP_ROLL_COUNT|10 --]|

  --=i|0
  
  --/| !token-mod --set bar1|[[@{selected|npc_hpformula}]]
  --/| For each selected Token
  --~Token|getselected
  --+TokenCount|[&TokenCount]
  --+Mode|[&Mode]

  --:MAIN_LOOP_TOP|
  --?[$i.Raw] -eq [&TokenCount]|MAIN_LOOP_EXIT

    --=i|[$i] + 1

    --/| If it is an NPC token associated with a monster sheet then proceed
    --?[*[&Token[$i.Raw]]:npc] -ne 1|MAIN_LOOP_TOP
    --?"[*[&Token[$i.Raw]]:t-represents]" -ninc "-"|MAIN_LOOP_TOP

      --/| Get the npc_hpformula
      --&CharId|[*[&Token[$i.Raw]]:t-represents]
      --&HPFormula|[*[&CharId]:npc_hpformula]

      --/| Based on Mode - determine HP
      --C[&Mode]|0:MODE_DEFAULT|1:MODE_RANDOM|2:MODE_RAND_HIGH|3:MODE_RAND_LOW
        --/|Case 0 - Default
        --:MODE_DEFAULT|
          --=HP|[*[&CharId]:hp^] + [&Adder]
          --^END_CASE|

        --/|Case 1 - Random
        --:MODE_RANDOM|
          --=HP|[&HPFormula] + [&Adder]
          --^END_CASE|

        --/|Case 2 - Random - High
        --:MODE_RAND_HIGH|
          -->HP_RAND_HIGH|
          --^END_CASE|

        --/|Case 3 - Random - Low 
        --:MODE_RAND_LOW|
          -->HP_RAND_LOW|
          --^END_CASE|

      --:END_CASE|
      --+[$i.Raw].|[*[&Token[$i.Raw]]:t-name]: ([&HPFormula]) + [&Adder] [$HP]
      --@token-mod|_set [&HPField]|[$HP.Raw] _ids [&Token[$i.Raw]] _ignore-selected

      --/|Apply Calculated HP

    --/| Next token
    --^MAIN_LOOP_TOP|
  --:MAIN_LOOP_EXIT|

  --+Done!|

  --X|

  --:HP_RAND_HIGH|
    --=HP|-500
    --=j|0
    --:HPRH_LOOP_TOP|
      --?[$j.Raw] -eq [&HP_ROLL_COUNT]|HPRH_LOOP_END
        --=x|[&HPFormula] + [&Adder]
        --+&nbsp;&nbsp;RHigh(x / HP)|[$x] / [$HP]
        --~HP|math;max;[$HP];[$x]
        --=j|[$j] + 1
        --^HPRH_LOOP_TOP|
    --:HPRH_LOOP_END|
  --<|

  --:HP_RAND_LOW|
    --=HP|500
    --=j|0
    --:HPRL_LOOP_TOP|
      --?[$j.Raw] -eq [&HP_ROLL_COUNT]|HPRL_LOOP_END
        --=x|[&HPFormula] + [&Adder]
        --+&nbsp;&nbsp;RLow(x / HP)|[$x] / [$HP]        
        --~HP|math;min;[$HP];[$x]

        --=j|[$j] + 1
        --^HPRL_LOOP_TOP|
    --:HPRL_LOOP_END|

  --<|
}}
  • Set Monster HP (With a Twist) - Link


October 06 (3 years ago)

Edited October 06 (3 years ago)

Manage Token Tooltip (All selected)

Simple GM utility to set, remove, show/hide token tooltips.  

Just recently Roll20 snuck in a new token feature called Tooltips.  The Aaron added ability to update associated fields in version 0.8.72 of his amazing TokenMod utility.  This script uses TokenMod's new functionality to manage tooltips across a group of selected tokens.  

Use:

  1. Select all the tokens you want to manage tooltips on.
  2. Execute the macro

Requirements:

  • Scriptcards 1.4.0+
  • TokenMod 0.8.72 (Currently in Dev and not available on 1-Click)


!script {{  
  --/|Script Name : Set Token Tooltip
  --/|Version     : 1.0
  --/|Requires SC : 1.3.7+, TokenMod 0.8.72+
  --/|Author      : Will M.

  --/|Description : GM Utility for updating ToolTips on one or more tokens.  Provides the ability to:
  --/|              * Add Tooltip - Add text to multiple token tooltips in one action
  --/|              * Clear Tooltip - Remove text from multiple tokens in one action
  --/|              * Show/Hide Tooltip - Toggle the show tooltip flag on all selected tokens

  --#title|Set Token Tooltips
  --#reentrant|SetTokenTT
  --#leftsub|
  --#rightsub|
  --#titlecardbackground|LightGreen
  --#titlefontsize|1.5em
  --#titlefontlineheight|2.0em
  --#titlefontface|Contrail One
  --#bodyfontsize|11px
  --#bodyfontface|Tahoma
  --#oddrowbackground|#00000000
  --#oddrowfontcolor|#000000
  --#evenrowbackground|#00000000
  --#evenrowfontcolor|#000000
  --#buttonbackground|DarkGreen
  --#buttontextcolor|White
  --#buttonbordercolor|#999999
  --#buttonfontsize|10px
  --#buttonfontface|Tahoma
  --#dicefontcolor|#1C6EA4
  --#dicefontsize|3.0em
  --#usehollowdice|0
  --#emotebackground|#f5f5ba
  --#emotestate|visible
  --#tableborderradius| 6px;
  --#tableshadow| 5px 3px 3px 0px #aaa;
  --#bodybackgroundimage| linear-gradient( to bottom, LightGreen, Green, DarkGreen)
  --#timezone|America/Chicago  
  --#debug|1
 
  --#whisper|self
  --#emotetext|
  --#hidecard|0

  --+|[c][rbutton]Add::ADD_TT[/rbutton]&nbsp;&nbsp;[rbutton]Clear::DEL_TT[/rbutton][/c]
  --+|[br]
  --+|[c][rbutton]Show::SHOW_TT[/rbutton]&nbsp;&nbsp;[rbutton]Hide::HIDE_TT;[&TokenId][/rbutton][/c]

  --X|

  --:ADD_TT|
    --#hidecard|1
    --I;Enter Tool-Tip you want to add to selected tokens|q;TT;Add a Tool-tip?
    --&CMD|_set tooltip|"[&TT]" _on show_tooltip
    --^APPLY|

  --:DEL_TT|
    --#hidecard|1
    --&CMD|_set tooltip|
    --^APPLY|

  --:SHOW_TT|
    --#hidecard|1
    --&CMD|_on show_tooltip
    --^APPLY|

  --:HIDE_TT|
    --#hidecard|1
    --&CMD|_off show_tooltip
    --^APPLY|

  --:APPLY|

    --=i|0
    --/| For each selected Token
    --~Token|getselected
  
    --:MAIN_LOOP_TOP|
    --?[$i.Raw] -eq [&TokenCount]|MAIN_LOOP_EXIT
      --=i|[$i] + 1
        --@token-mod|[&CMD] _ids [&Token[$i.Raw]] _ignore-selected
        --/*|token-mod [&CMD] _ids [&Token[$i.Raw]] _ignore-selected
      --^MAIN_LOOP_TOP|
    --:MAIN_LOOP_EXIT|
    --X|
}} 
  • Manage Token Tooltips - Link


Replying to subscribe.

October 13 (3 years ago)
GiGs
Pro
Sheet Author
API Scripter

Replying doesnt auto-subscribe you on these forums - you need to click the Follow link at the top right, and dont need to post to do that.

October 13 (3 years ago)

Edited October 13 (3 years ago)

Hi all, 

Could we combine the management of the tool tip above with this 

https://app.roll20.net/forum/post/10421785/tooltips-can-now-be-added-to-tokens-slash-cards/?pageforid=10423754#post-10423754

Maybe making it an option in the buttons. 

And ideally, instead selecting the tokens, use the tokens present on turn tracker as the selection array? 


Thank you 

October 13 (3 years ago)

Edited October 14 (3 years ago)

I think I understand what you are getting at, but I believe the GM/DM would have to be the one to run the script every round or whenever someone is hit.  I believe there is an event that could be leveraged in Javascript, but that would take a little more work for me as I'm still a hack at JS. 

I could easily write a ScriptCard macro that would:

1. Traverse the list of tokens in the current Turn Order List

2. Apply the math/logic to establish injury level

3. Place that injury level in the Tool Tip and make sure it's being shown

I think a JS solution is more elegant, and I'll take a look at what it would take.  I believe there is a health/aura script I can learn from.  

Lionel V. said:

Hi all, 

Could we combine the management of the tool tip above with this 

https://app.roll20.net/forum/post/10421785/tooltips-can-now-be-added-to-tokens-slash-cards/?pageforid=10423754#post-10423754

Maybe making it an option in the buttons. 

And ideally, instead selecting the tokens, use the tokens present on turn tracker as the selection array? 


Thank you 




October 14 (3 years ago)
Mads
Pro


Will M. said:

I think I understand what you are getting at, but I believe the GM/DM would have to be the one to run the script every round or whenever someone is hit.  I believe there is an event that could be leveraged in Javascript, but that would take a little more work for me as I'm still a hack at JS. 

I could easily write a ScriptCard macro that would:

1. Traverse the list of tokens in the current Turn Order List

2. Apply the math/logic to establish injury level

3. Place that injury level in the Tool Tip and make sure it's being shown

I think a JS solution is more elegant, and I'll take a look at what it would take.  I believe there is a health/aura script I can learn from.  

Lionel V. said:

Hi all, 

Could we combine the management of the tool tip above with this 

https://app.roll20.net/forum/post/10421785/tooltips-can-now-be-added-to-tokens-slash-cards/?pageforid=10423754#post-10423754

Maybe making it an option in the buttons. 

And ideally, instead selecting the tokens, use the tokens present on turn tracker as the selection array? 


Thank you 





I would love to use that script Will

October 15 (3 years ago)

I should have something tomorrow....

I've written the logic to traverse the Turnorder List.  Just need to add the logic to grab the HP, HPMax, Calc the PCT and populate the Tooltip.  


October 15 (3 years ago)

Edited October 15 (3 years ago)

Tooltip Health Indicator

Update: Previous version traversed the Turn Order list which was a bit sluggish.  This new version has an option to traverse NPCs, PCs or all Characters and runs much quicker.  

How it works:

This script when run will do the following: 

  1. Advance the Turn Order (via the !eot command if you have installed Aaron's TurnMarker Script.)
  2. Traverse the list of tokens on the current page filtered by (pcs, npcs or all characters)
  3. Apply the math/logic to establish a textual injury level
  4. Place that injury level in the Tool Tip and make sure it's being shown (Using TokenMod script)

Health Text Logic: 

  • Uninjured = 0% dmg taken
  • Barely Injured = 0-25% dmg taken
  • Injured = 25-50% dmg taken
  • Badly Injured = 50-75% dmg taken
  • Near Death = 75-100% dmg taken
  • Death = 100% dmg taken

There are a couple configuration items to be aware of (Around row 23):

  --#hidecard|1
  --&HealthBar|bar1
  --&TokenType|char
  1. Set #hidecard|0 value to 1 if you don't want the whispered debug text
  2. Set the &HealthBar|bar1 to bar2 or bar3 if you use those for tracking HP.
  3. Set TokenType to char, npc or pc based on 

Tip: Add a "Next" macro button to your macro bar to run this script to execute this script.  

!eot
!script {{

  --/|Script Name : Set-TT-Health
  --/|Version     : 0.3
  --/|Requires SC : 1.4.4, Token-Mod and TurnMarker (By the Aarron)
  --/|Author      : Will M.

  --/|Description : Advances the turn order and sets Token ToolTips to a health indicator
  --/|

  --#title|Set Token Tooltip Health
  --#bodyFontSize|10px
  --#whisper|self
  --#debug|0

  --/| Parameters to configure how script operates
  --/| Set hidecard to 1 to hide debug messages
  --/| Set HealthBar to bar2 or bar3 if you use one of those for tracking HP
  --/| Set TokenType to pc, npc, or char.
  --/|    pc: Will include all tokens controlled by a player
  --/|    npc: Will include tokens represented by a sheet but not controlled by a player  
  --/|    char: Will include tokens being represented by a sheet
  --#hidecard|1
  --&HealthBar|bar1
  --&TokenType|char

  --&TokenIdList|

  --/| Create array of tokens based on TokenType (pc, npc, char), and retrieve the first TokenId
  --~tokencnt|array;pagetokens;PgTokens;@{selected|token_id};[&TokenType]
  --~TokenId|array;getfirst;PgTokens
 
  --/| For each token in the PgTokens array
  --:STARTLOOP|
    --?[&TokenId] -eq ArrayError|ENDLOOP

    --/| Calculate Damage Pct
    --=HP|[*[&TokenId]:t-[&HealthBar]_value]
    --=HPMax|[*[&TokenId]:t-[&HealthBar]_max]
    --=HPPct|[$HP]/[$HPMax]*100

    --/|Determine Damage Text
    --?[$HPPct.Raw] -ge 100|&DmgText;Uninjured
    --?[$HPPct.Raw] -lt 100|&DmgText;Barely Injured
    --?[$HPPct.Raw] -lt 75|&DmgText;Injured
    --?[$HPPct.Raw] -lt 50|&DmgText;Badly Injured
    --?[$HPPct.Raw] -lt 25|&DmgText;Near Death
    --?[$HPPct.Raw] -le 0|&DmgText;Death
    --+[*[&TokenId]:t-name]:|[&DmgText] [$HP]/[$HPMax]
    
    --/|Debug Text
    --+TT| [&CurrTT] [&DmgText]

    --/| Push Damage text into Token Tooltip
    --@token-mod|_on show_tooltip _set tooltip|"[&DmgText]" _ids [&TokenId] _ignore-selected

  --:SKIP|

    --/| Retrieve the next TokenID from the array PgTokens and repeat the loop
    --~TokenId|array;getnext;PgTokens
    --^STARTLOOP|

  --:ENDLOOP|

  --+DONE!!!|

  --x|
}}
October 15 (3 years ago)
Mads
Pro

This is fantastic Will. Many thx

October 15 (3 years ago)


Mads said:

This is fantastic Will. Many thx


You might grab the new version I posted.  It runs much quicker.  However, it is no longer using the TurnOrder list, and instead processing all tokens based on the filter I describe in my post above (pc, npc, char).