Internally AGK represents fonts using images, whereby each character is placed onto an image and can then be utilised by the text commands.
For many situations the usage of the default font will be more than adequate, especially when displaying information on screen to assist with debugging. However, many games may require an extra element of customization that necessitates the use of different looking fonts.
The default font for AGK uses a fixed width, where each character on the grid is set to 16 x 6. This image shows the default font:
Any calls to the command CreateText will result in this font being used automatically e.g.
CreateText ( 1, "HELLO AGK!" )
Will produce this result:
If you wanted to replace the default font and continue to use a fixed width font, you would need to create a new image in a paint package and replicate the default font image using your own font.
Fixed width fonts are useful for certain situations, however, there are limitations such as the size of each character on the grid and this results in them losing some flexiblity.
Many games will require a custom font to be displayed. Here's an example that might be more suited to a game:
AGK allows you to take an image like this and utilise it within the font system. This is handled by calling the command SetTextFontImage. This command has two parameters with the first being the ID number of the text and the second being the ID number of the image. The code that follows demonstrates creating a text entity, then loading an image and applying this image to the text:
CreateText ( 1, "HELLO AGK!" ) LoadImage ( 1, "custom.png" ) SetTextFontImage ( 1, 1 )
Here's the result:
Another point to consider when using custom fonts is that it's necessary to supply a text file that defines the relationship between characters and their location on the image. The name of this text file must match that of the image name along with the string "subimages" e.g.
Here's an extract showing how this file should be laid out:
This line matches the ASCII code for the letter A, which is 65 to coordinates 76, 126 on the image and tells us that the letter A is 25 pixels wide and 42 pixels high.
This process needs to continue for all characters your custom image utilises. It may be, for example, that your custom font image comprised of numbers alone, so your file may look like this:
The above text tells us that number 0 (ASCII code 48) is positioned at 0, 0 on our image and has dimensions of 20 x 20. Number 1 (ASCII code 49) is positioned at 20, 0 on our image and has dimensions of 20 x 20. Number 2 (ASCII code 50) is positioned at 40, 0 on our image and has dimensions of 20 x 20.
Our final program demonstrates the use of a custom font image:
backdrop = CreateSprite ( LoadImage ( "background4.jpg" ) ) SetSpriteSize ( backdrop, 100, 100 )
CreateText ( 1, "HELLO AGK!" ) LoadImage ( 1, "custom.png" ) SetTextFontImage ( 1, 1 )
do Sync ( ) loop
As you can see AGK provides plenty of flexibility when it comes to fonts.