-
Notifications
You must be signed in to change notification settings - Fork 685
The Deco Framework for Backgrounds
Version 0.11.7 introduced the image tag-based decoration framework, which allows for an image tag to automatically be hidden/shown in different locations depending on the current background.
This guide is written for custom background creators, and does not do a deep dive into the technical aspects of the framework. See Usage to skip over background explanations.
This is an object representation of a decoration that corresponds to an image tag.
It's primary purpose is to allow for additional data to be associated with a decoration, like ex_props
for example.
Generally, you will not need to construct these objects.
Stores attributes that would be passed into renpy.show
. Similar to curried functions.
This should only be used with MASImageTagDecoration
objects
You will likely need to construct these objects to determine positioning for a decoration. The constructor takes the same parameters as renpy.show, excluding name.
Ties image tags (MASImageTagDecoration
objects) with MASAdvancedDecoFrame
objects for specific backgrounds.
Every image tag-based decoration must have one of these for the deco framework to consider the tag as a decoration.
Generally, you will not need to construct these objects.
When we want to show a decoration, we request the system to show a decoration via the show tag function. This sets up a decoration to be shown if the decoration has an entry in its MASImageTagDecoDefinition
for the current background. However, the actual image is only shown when the background changes or a scene change occurs, which allows for the image to dissolve into the picture neatly.
The system handles both hiding and showing decorations automatically based on the MASImageTagDecoDefinition
objects. If a decoration does not have a mapping to a MASAdvancedDecoFrame
object in its MASImageTagDecoDefinition
, the decoration is hidden. Otherwise, MASAdvancedDecoFrame
objects allow for decorations to be shown in other locations in different backgrounds.
You will need to look at each decoration image and determine if the image can be shown at all for their background. If it can, they will need to specify a MASAdvancedDecoFrame
object (or use the existing one) to determine the best position for the background. Future development will expand on this, see below
For a list of current decoration objects, see (link)
You will need to write a line for each decoration object that should be allowed on your background. This should be placed after the code that creates the background object.
There are 2 APIs that can be used here:
Params:
-
tag
- (REQUIRED) image tag of the decoration object to register with -
bg_id
- (REQUIRED) ID of the background object to register (this should be your background's ID) -
adv_deco_frame
- (REQUIRED)MASAdvancedDecoFrame
object to use when showing this decoration on your background
Use this function when the decoration object can be shown on your background but in a location other than the default.
Here is an example that registers the Christmas tree to your background using a zorder of 7. (The default is 6)
MASImageTagDecoDefinition.register_img(
"mas_d25_tree",
"your_custom_background_id",
MASAdvancedDecoFrame(zorder=7)
)
Params:
-
tag
- (REQUIRED) image tag of the deoration object to register with -
bg_id_src
- (REQUIRED) ID of the background object to copyMASAdvancedDecoFrame
from -
bg_id_dest
- (REQUIRED) ID of the background object to register (this should be your background's ID)
Use this function if the decoration object can be shown on your background in the same position as it is shown on another background. For example, if the default location of a decoration is fine for your background, then you would pass store.mas_background.MBG_DEF
here.
Here is an example that registers the Christmas tree to your background using the default position.
MASImageTagDecoDefinition.register_img_same(
"mas_d25_tree",
store.mas_background.MBG_DEF,
"your_custom_background_id"
)
And that's it! Once you've registered the images, the Deco framework should take care of the rest.
Future development will allow for showing a specific image tag instead of the decoration's image tag when on a certain background. This is so you can use a completely different decoration image if it works for your background. Until then, you can create new decoration objects using the register APIs and instead use background prog points to hide/show your decoration objects on exit/entry.
To test how these look/default positioning, use the show deco API with show_now
as True.
NOTE: all composite images probably won't work on other backgrounds. Our apologizes.
- coming soon
-
mas_o31_deco
- baked composite image consisting of pumpkins/cobwebs/candle.
-
mas_d25_banners
- wreath and stocking composite. -
mas_d25_garlands
- green thing that I guess are called garlands -
mas_d25_gifts
- gifts that go under the Christmas tree -
mas_d25_lights
- the lights that go around the room -
mas_d25_tree
- the Christmas tree
Params:
-
tag
- (REQUIRED) image tag of the decoration to show -
show_now
- [optional] pass True to show a decoration immediately, False will wait until next background change or scene change.
This is the primary way to show a decoration. show_now
is only recommended in testing, as it will not dissolve images into the picture.
Params:
-
tag
- (REQUIRED) image tag of the decoration to hide -
hide_now
- [optional] pass True to hide a decoration immediately, False will wait until next background change or scene change.
This is the primary way to hide a decoration. hide_now
is only recommended in testing, as it will not dissolve images from the picture.
Params:
-
tag
- (REQUIRED) image tag of the decoration to check is visible
RETURNS
True if the deco is visible, False if not
This does not mean that the decoration is actually visible in the picture. This checks if the decoration is set to be shown, but given the system behavior, the actual decoration may not be visible to the user.