mirror of
https://github.com/MarioSpore/Grinch-AP.git
synced 2025-10-21 20:21:32 -06:00
Add a more direct random-sprite-on-event yaml option
This commit is contained in:
22
Mystery.py
22
Mystery.py
@@ -481,8 +481,30 @@ def roll_settings(weights):
|
|||||||
|
|
||||||
if 'rom' in weights:
|
if 'rom' in weights:
|
||||||
romweights = weights['rom']
|
romweights = weights['rom']
|
||||||
|
|
||||||
ret.sprite_pool = romweights['sprite_pool'] if 'sprite_pool' in romweights else []
|
ret.sprite_pool = romweights['sprite_pool'] if 'sprite_pool' in romweights else []
|
||||||
ret.sprite = get_choice('sprite', romweights, "Link")
|
ret.sprite = get_choice('sprite', romweights, "Link")
|
||||||
|
if 'random_sprite_on_event' in romweights:
|
||||||
|
randomoneventweights = romweights['random_sprite_on_event']
|
||||||
|
if get_choice('enabled', randomoneventweights, False):
|
||||||
|
ret.sprite = 'randomon'
|
||||||
|
ret.sprite += '-hit' if get_choice('on_hit', randomoneventweights, True) else ''
|
||||||
|
ret.sprite += '-enter' if get_choice('on_enter', randomoneventweights, False) else ''
|
||||||
|
ret.sprite += '-exit' if get_choice('on_exit', randomoneventweights, False) else ''
|
||||||
|
ret.sprite += '-slash' if get_choice('on_slash', randomoneventweights, False) else ''
|
||||||
|
ret.sprite += '-item' if get_choice('on_item', randomoneventweights, False) else ''
|
||||||
|
ret.sprite += '-bonk' if get_choice('on_bonk', randomoneventweights, False) else ''
|
||||||
|
ret.sprite = 'randomonall' if get_choice('on_everything', randomoneventweights, False) else ret.sprite
|
||||||
|
ret.sprite = 'randomonnone' if ret.sprite == 'randomon' else ret.sprite
|
||||||
|
|
||||||
|
if (not ret.sprite_pool or get_choice('use_weighted_sprite_pool', randomoneventweights, False)) \
|
||||||
|
and 'sprite' in romweights: # Use sprite as a weighted sprite pool, if a sprite pool is not already defined.
|
||||||
|
for key, value in romweights['sprite']:
|
||||||
|
if key.startswith('random'):
|
||||||
|
ret.sprite_pool += ['random'] * int(value)
|
||||||
|
else:
|
||||||
|
ret.sprite_pool += [key] * int(value)
|
||||||
|
|
||||||
ret.disablemusic = get_choice('disablemusic', romweights, False)
|
ret.disablemusic = get_choice('disablemusic', romweights, False)
|
||||||
ret.quickswap = get_choice('quickswap', romweights, True)
|
ret.quickswap = get_choice('quickswap', romweights, True)
|
||||||
ret.fastmenu = get_choice('menuspeed', romweights, "normal")
|
ret.fastmenu = get_choice('menuspeed', romweights, "normal")
|
||||||
|
@@ -286,7 +286,7 @@ door_shuffle: # Only available if the host uses the doors branch, it is ignored
|
|||||||
intensity: # Only available if the host uses the doors branch, it is ignored otherwise
|
intensity: # Only available if the host uses the doors branch, it is ignored otherwise
|
||||||
1: 50 # Shuffles normal doors and spiral staircases
|
1: 50 # Shuffles normal doors and spiral staircases
|
||||||
2: 0 # And shuffles open edges and straight staircases
|
2: 0 # And shuffles open edges and straight staircases
|
||||||
3: 0 # (Coming soon) And shuffles dungeon lobbies
|
3: 0 # And shuffles dungeon lobbies
|
||||||
random: 0 # Picks one of those at random
|
random: 0 # Picks one of those at random
|
||||||
experimental: # Only available if the host uses the doors branch, it is ignored otherwise
|
experimental: # Only available if the host uses the doors branch, it is ignored otherwise
|
||||||
on: 0 # Enables experimental features. Currently, this is just the dungeon keys in chest counter.
|
on: 0 # Enables experimental features. Currently, this is just the dungeon keys in chest counter.
|
||||||
@@ -295,6 +295,34 @@ debug: # Only available if the host uses the doors branch, it is ignored otherwi
|
|||||||
on: 0 # Enables debugging features. Currently, these are the Item collection counter. (overwrites total triforce pieces) and Castle Gate closed indicator.
|
on: 0 # Enables debugging features. Currently, these are the Item collection counter. (overwrites total triforce pieces) and Castle Gate closed indicator.
|
||||||
off: 50
|
off: 50
|
||||||
rom:
|
rom:
|
||||||
|
random_sprite_on_event: # An alternative to specifying randomonhit / randomonexit / etc... in sprite down below.
|
||||||
|
enabled: # If enabled, sprite down below is ignored completely, (although it may become the sprite pool)
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_hit: # Random sprite on hit. Being hit by things that cause 0 damage still counts.
|
||||||
|
on: 1
|
||||||
|
off: 0
|
||||||
|
on_enter: # Random sprite on underworld entry. Note that entering hobo counts.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_exit: # Random sprite on underworld exit. Exiting hobo does not count.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_slash: # Random sprite on sword slash. Note, it still counts if you attempt to slash while swordless.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_item: # Random sprite on getting an item. Anything that causes you to hold an item above your head counts.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_bonk: # Random sprite on bonk.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
on_everything: # Random sprite on ALL currently implemented events, even if not documented at present time.
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
|
use_weighted_sprite_pool: # Always on if no sprite_pool exists, otherwise it controls whether to use sprite as a weighted sprite pool
|
||||||
|
on: 0
|
||||||
|
off: 1
|
||||||
#sprite_pool: # When specified, limits the pool of sprites used for randomon-event to the specified pool. Uncomment to use this.
|
#sprite_pool: # When specified, limits the pool of sprites used for randomon-event to the specified pool. Uncomment to use this.
|
||||||
# - link
|
# - link
|
||||||
# - pride link
|
# - pride link
|
||||||
|
Reference in New Issue
Block a user