SpeechBubble is a script module for Adventure Game Studio (AGS). It requires AGS v3.4.0 or higher.
This module allows you to display conversation text in comic book-style speech bubbles. The appearance of the speech bubbles can be extensively customized.
THIS MODULE IS UNFINISHED. SOME FEATURES ARE NOT YET IMPLEMENTED, AND OTHERS MAY CHANGE BEFORE THE FINAL RELEASE.
To use, you call Character.SayBubble(). For example:
player.SayBubble("This line will be said in a speech bubble");
You can also use Character.SayAtBubble()
to position the bubble elsewhere on screen, and Character.SayBackgroundBubble()
for non-blocking speech. Character.ThinkBubble()
IS NOT YET IMPLEMENTED.
To configure the appearance of the speech bubbles, you set the SpeechBubble properties. This is usually best done in GlobalScript game_start()
. For example:
function game_start()
{
SpeechBubble.BorderColor = Game.GetColorFromRGB(0,128,0);
SpeechBubble.BackgroundColor = Game.GetColorFromRGB(128,255,128);
SpeechBubble.BackgroundTransparency = 33;
SpeechBubble.PaddingTop = 5;
SpeechBubble.PaddingBottom = 5;
SpeechBubble.PaddingLeft = 15;
SpeechBubble.PaddingRight = 15;
// Other code
}
See the declaration below for the full list and explanation of the properties.
The module relies on built-in AGS settings as far as possible. In particular, it uses these settings to customize the appearance and behavior of the speech bubbles:
Character.SpeechColor
Game.SpeechFont
Game.TextReadingSpeed
Speech.SkipStyle
Speech.VoiceMode
Note that to get text-based lip sync to work, you need to provide an invisible font, and set the SpeechBubble.InvisibleFont
property accordingly. You may download one here:
http://www.angelfire.com/pr/pgpf/if.html
Finally, the module (usually) calls Character.Say()
to render speech animation and play voice clips. If you are already using some custom Say module (e.g. TotalLipSync), you may want to call a custom Say() function instead. To do this, simply change the function call in SB_sayImpl()
at the top of SpeechBubble.asc.
Development of this module was funded by AGS forum member bx83, who agreed to make the code open-source. Thanks!
This code is offered under the MIT License: https://opensource.org/licenses/MIT
It is also licensed under a Creative Commons Attribution 4.0 International License: https://creativecommons.org/licenses/by/4.0/