summaryrefslogtreecommitdiffhomepage
path: root/games
diff options
context:
space:
mode:
authorraysan5 <[email protected]>2018-02-17 21:23:45 +0100
committerraysan5 <[email protected]>2018-02-17 21:23:45 +0100
commit50fc4f7164fad37a7c4e542475ccb93d0f4b05ca (patch)
tree8b153c75096d6765777ccfcc6de4f11f47ec1a1d /games
parent769cf23e53af8629e7e3ec395e198296a42b8e45 (diff)
downloadraylib-50fc4f7164fad37a7c4e542475ccb93d0f4b05ca.tar.gz
raylib-50fc4f7164fad37a7c4e542475ccb93d0f4b05ca.zip
Reviewed transmission mission game
Support string replacing to generate newspaper headline ISSUE: UTF8 characters not supported when drawing to Image
Diffstat (limited to 'games')
-rw-r--r--games/transmission/resources/fonts/Lora-BoldItalic.ttfbin232472 -> 0 bytes
-rw-r--r--games/transmission/resources/fonts/mom_typewritter.ttf (renamed from games/transmission/resources/fonts/fontTitle.ttf)bin125972 -> 125972 bytes
-rw-r--r--games/transmission/resources/missions.txt6
-rw-r--r--games/transmission/screens/screen_ending.c132
-rw-r--r--games/transmission/screens/screen_title.c2
5 files changed, 88 insertions, 52 deletions
diff --git a/games/transmission/resources/fonts/Lora-BoldItalic.ttf b/games/transmission/resources/fonts/Lora-BoldItalic.ttf
deleted file mode 100644
index 19b03226..00000000
--- a/games/transmission/resources/fonts/Lora-BoldItalic.ttf
+++ /dev/null
Binary files differ
diff --git a/games/transmission/resources/fonts/fontTitle.ttf b/games/transmission/resources/fonts/mom_typewritter.ttf
index 13f5dc7d..13f5dc7d 100644
--- a/games/transmission/resources/fonts/fontTitle.ttf
+++ b/games/transmission/resources/fonts/mom_typewritter.ttf
Binary files differ
diff --git a/games/transmission/resources/missions.txt b/games/transmission/resources/missions.txt
index 346e54e4..63569608 100644
--- a/games/transmission/resources/missions.txt
+++ b/games/transmission/resources/missions.txt
@@ -1,4 +1,4 @@
-# Total missions
+# Total missions
# NOTE: Missions follow the order of this file
t 4
# -----------------------------------------------------------------
@@ -10,7 +10,7 @@ k oviparo
#
# Message to be coded
# NOTE: Sensible words must be noted using @
-m El @presidente es visto en un @hotel acompañado de su @amante .
+m El @presidente es visto en un @hotel acompañado de su @amante.
#
# Solution to mission
# NOTE: Provide the correct solution nums, according to above words
@@ -26,7 +26,7 @@ k roedor
#
# Message to be coded
# NOTE: Sensible words must be noted using @
-m Un @ovni ha sido detectado en el @cielo del @pais . Preparaos para el ataque de un @alien .
+m Un @ovni ha sido detectado en el @cielo del @pais . Preparaos para el ataque de un @alien.
#
# NOTE: Provide the correct solution nums, according to above words
# WARNING: Always provide 8 values, use -1 for not used ones
diff --git a/games/transmission/screens/screen_ending.c b/games/transmission/screens/screen_ending.c
index e1fd6156..d9ed4696 100644
--- a/games/transmission/screens/screen_ending.c
+++ b/games/transmission/screens/screen_ending.c
@@ -29,7 +29,7 @@
#include <string.h>
#include <stdlib.h>
-#define MAX_TITLE_CHAR 128
+#define MAX_TITLE_CHAR 256
#define MAX_SUBTITLE_CHAR 256
//----------------------------------------------------------------------------------
@@ -66,7 +66,12 @@ static int state = 0;
static Mission *missions = NULL;
-static bool showResults = false;
+static char headline[MAX_TITLE_CHAR] = "\0";
+
+SpriteFont fontNews;
+
+// String (const char *) replacement function
+static char *StringReplace(char *orig, char *rep, char *with);
//----------------------------------------------------------------------------------
// Ending Screen Functions Definition
@@ -84,60 +89,43 @@ void InitEndingScreen(void)
texBackground = LoadTexture("resources/textures/ending_background.png");
texVignette = LoadTexture("resources/textures/message_vignette.png");
-
fxNews = LoadSound("resources/audio/fx_batman.ogg");
- // TODO: Check game results!
missions = LoadMissions("resources/missions.txt");
int wordsCount = missions[currentMission].wordsCount;
- TraceLog(LOG_WARNING, "Words count %i", wordsCount);
-
- char title[MAX_TITLE_CHAR] = "\0";
- //char subtitle[MAX_SUBTITLE_CHAR] = "\0";
-
- char *ptrTitle = title;
- int len = 0;
+
+ strcpy(headline, missions[currentMission].msg); // Base headline
+ int len = strlen(headline);
+ // Remove @ from headline
+ // TODO: Also remove additional spaces
+ for (int i = 0; i < len; i++)
+ {
+ if (headline[i] == '@') headline[i] = ' ';
+ }
+
for (int i = 0; i < wordsCount; i++)
{
- if (messageWords[i].id == missions[currentMission].sols[i])
+ if (messageWords[i].id != missions[currentMission].sols[i])
{
- len = strlen(messageWords[i].text);
- strncpy(ptrTitle, messageWords[i].text, len);
- ptrTitle += len;
+ // WARNING: It fails if the last sentence word has a '.' after space
+ char *title = StringReplace(headline, messageWords[i].text, codingWords[messageWords[i].id]);
- // title[len] = ' ';
- // len++;
- // ptrTitle++;
- }
- else
- {
- TraceLog(LOG_WARNING, "Coding word: %s", codingWords[messageWords[i].id]);
- len = strlen(codingWords[messageWords[i].id]);
- TraceLog(LOG_WARNING, "Lenght: %i", len);
- strncpy(ptrTitle, codingWords[messageWords[i].id], len);
- ptrTitle += len;
+ strcpy(headline, title); // Base headline updated
- // title[len] = ' ';
- // len++;
- // ptrTitle++;
+ free(title);
}
}
- ptrTitle = '\0';
-
- //TraceLog(LOG_WARNING, "Titular: %s", title);
+ TraceLog(LOG_WARNING, "Titular: %s", headline);
// Generate newspaper with title and subtitle
Image imNewspaper = LoadImage("resources/textures/ending_newspaper.png");
- SpriteFont fontNews = LoadSpriteFontEx("resources/fonts/Lora-Bold.ttf", 82, 250, 0);
- ImageDrawTextEx(&imNewspaper, (Vector2){ 50, 220 }, fontNews, "FRACASO EN LA GGJ18!", fontNews.baseSize, 0, DARKGRAY);
+ fontNews = LoadSpriteFontEx("resources/fonts/Lora-Bold.ttf", 32, 250, 0);
+ ImageDrawTextEx(&imNewspaper, (Vector2){ 50, 220 }, fontNews, headline, fontNews.baseSize, 0, DARKGRAY);
- // TODO: Draw subtitle message
- //ImageDrawTextEx(&imNewspaper, (Vector2){ 50, 210 }, fontNews, "SUBE LA ESCALERA!", fontNews.baseSize, 0, DARKGRAY);
-
texNewspaper = LoadTextureFromImage(imNewspaper);
- UnloadSpriteFont(fontNews);
+ //UnloadSpriteFont(fontNews);
UnloadImage(imNewspaper);
}
@@ -167,8 +155,6 @@ void UpdateEndingScreen(void)
if (currentMission >= totalMissions) finishScreen = 2;
else finishScreen = 1;
}
-
- if (IsKeyPressed(KEY_SPACE)) showResults = !showResults;
}
// Ending Screen Draw logic
@@ -181,16 +167,15 @@ void DrawEndingScreen(void)
(Vector2){ (float)texNewspaper.width*scale/2, (float)texNewspaper.height*scale/2 }, rotation, WHITE);
DrawTextureEx(texVignette, (Vector2){ 0, 0 }, 0.0f, 2.0f, WHITE);
+
+ // Draw debug information
+ DrawTextEx(fontNews, headline, (Vector2){ 10, 10 }, fontNews.baseSize, 0, RAYWHITE);
- if (showResults)
+ for (int i = 0; i < missions[currentMission].wordsCount; i++)
{
- for (int i = 0; i < missions[currentMission].wordsCount; i++)
- {
- if (messageWords[i].id == missions[currentMission].sols[i]) DrawText(messageWords[i].text, 10, 10 + 30*i, 20, GREEN);
- else DrawText(codingWords[messageWords[i].id], 10, 10 + 30*i, 20, RED);
- }
+ DrawText(codingWords[messageWords[i].id], 10, 60 + 30*i, 20, (messageWords[i].id == missions[currentMission].sols[i]) ? GREEN : RED);
}
-
+
if (state == 1) DrawButton("continuar");
}
@@ -209,4 +194,55 @@ void UnloadEndingScreen(void)
int FinishEndingScreen(void)
{
return finishScreen;
-} \ No newline at end of file
+}
+
+// String (const char *) replacement function
+// NOTE: Internally allocated memory must be freed by the user (if return != NULL)
+// https://stackoverflow.com/questions/779875/what-is-the-function-to-replace-string-in-c
+static char *StringReplace(char *orig, char *rep, char *with)
+{
+ char *result; // the return string
+ char *ins; // the next insert point
+ char *tmp; // varies
+ int len_rep; // length of rep (the string to remove)
+ int len_with; // length of with (the string to replace rep with)
+ int len_front; // distance between rep and end of last rep
+ int count; // number of replacements
+
+ // Sanity checks and initialization
+ if (!orig || !rep) return NULL;
+
+ len_rep = strlen(rep);
+ if (len_rep == 0) return NULL; // Empty rep causes infinite loop during count
+
+ if (!with) with = ""; // Replace with nothing if not provided
+ len_with = strlen(with);
+
+ // Count the number of replacements needed
+ ins = orig;
+ for (count = 0; tmp = strstr(ins, rep); ++count)
+ {
+ ins = tmp + len_rep;
+ }
+
+ tmp = result = malloc(strlen(orig) + (len_with - len_rep)*count + 1);
+
+ if (!result) return NULL; // Memory could not be allocated
+
+ // First time through the loop, all the variable are set correctly from here on,
+ // tmp points to the end of the result string
+ // ins points to the next occurrence of rep in orig
+ // orig points to the remainder of orig after "end of rep"
+ while (count--)
+ {
+ ins = strstr(orig, rep);
+ len_front = ins - orig;
+ tmp = strncpy(tmp, orig, len_front) + len_front;
+ tmp = strcpy(tmp, with) + len_with;
+ orig += len_front + len_rep; // move to next "end of rep"
+ }
+
+ strcpy(tmp, orig);
+
+ return result;
+}
diff --git a/games/transmission/screens/screen_title.c b/games/transmission/screens/screen_title.c
index dc062069..a5ad0a84 100644
--- a/games/transmission/screens/screen_title.c
+++ b/games/transmission/screens/screen_title.c
@@ -71,7 +71,7 @@ void InitTitleScreen(void)
texBackground = LoadTexture("resources/textures/title_background.png");
fxTyping = LoadSound("resources/audio/fx_typing.ogg");
- fontTitle = LoadSpriteFontEx("resources/fonts/fontTitle.ttf", 96, 0, 0);
+ fontTitle = LoadSpriteFontEx("resources/fonts/mom_typewritter.ttf", 96, 0, 0);
titleSize = 44;
transmissionPosition = (Vector2){519, 221};