improved configurability of tape date and time display positions
authorHolger Schemel <info@artsoft.org>
Mon, 2 Feb 2015 23:44:29 +0000 (00:44 +0100)
committerHolger Schemel <info@artsoft.org>
Mon, 2 Feb 2015 23:44:29 +0000 (00:44 +0100)
build-scripts/create_element_defs.pl
src/conf_gfx.c
src/conf_var.c
src/libgame/system.h
src/tape.c
src/tape.h

index af4b2bdffd8977fdedf25415eb2b7fbc61bf6110..8c097551a790a5c1f643d1640c5edb958c2d96d6 100755 (executable)
@@ -2395,6 +2395,7 @@ sub print_image_config_vars
            $var =~ s/^(game\.panel\..*)\.tile_size$/$1.size/;
            $var =~ s/^(request\.button\..*)\.tile_size$/$1.size/;
            $var =~ s/\.digits$/.size/;
+           $var =~ s/\.2nd_xoffset$/.xoffset2/;
            $var =~ s/\.element$/.id/;
            $var =~ s/\.draw_order$/.sort_priority/;
 
index d44155d35614805168bc98664644e35380694467..96ff7825da2219bf8aedc4ddb73c64822cb1cf16 100644 (file)
@@ -7097,14 +7097,77 @@ struct ConfigInfo image_config[] =
   { "tape.text.date.align",                    "left"                  },
   { "tape.text.date.valign",                   "top"                   },
   { "tape.text.date.digits",                   "-1"                    },
+  { "tape.text.date.xoffset",                  "27"                    },
+  { "tape.text.date.2nd_xoffset",              "64"                    },
   { "tape.text.date.font",                     "font.tape_recorder"    },
+  { "tape.text.date.draw_masked",              "false"                 },
+
+  { "tape.text.date_yyyy.x",                   "-1"                    },
+  { "tape.text.date_yyyy.y",                   "-1"                    },
+  { "tape.text.date_yyyy.align",               "left"                  },
+  { "tape.text.date_yyyy.valign",              "top"                   },
+  { "tape.text.date_yyyy.digits",              "2"                     },
+  { "tape.text.date_yyyy.font",                        "font.tape_recorder"    },
+  { "tape.text.date_yyyy.draw_masked",         "true"                  },
+  { "tape.text.date_yy.x",                     "-1"                    },
+  { "tape.text.date_yy.y",                     "-1"                    },
+  { "tape.text.date_yy.align",                 "left"                  },
+  { "tape.text.date_yy.valign",                        "top"                   },
+  { "tape.text.date_yy.digits",                        "2"                     },
+  { "tape.text.date_yy.font",                  "font.tape_recorder"    },
+  { "tape.text.date_yy.draw_masked",           "true"                  },
+  { "tape.text.date_mmm.x",                    "-1"                    },
+  { "tape.text.date_mmm.y",                    "-1"                    },
+  { "tape.text.date_mmm.align",                        "left"                  },
+  { "tape.text.date_mmm.valign",               "top"                   },
+  { "tape.text.date_mmm.digits",               "2"                     },
+  { "tape.text.date_mmm.font",                 "font.tape_recorder"    },
+  { "tape.text.date_mmm.draw_masked",          "true"                  },
+  { "tape.text.date_mm.x",                     "-1"                    },
+  { "tape.text.date_mm.y",                     "-1"                    },
+  { "tape.text.date_mm.align",                 "left"                  },
+  { "tape.text.date_mm.valign",                        "top"                   },
+  { "tape.text.date_mm.digits",                        "2"                     },
+  { "tape.text.date_mm.font",                  "font.tape_recorder"    },
+  { "tape.text.date_mm.draw_masked",           "true"                  },
+  { "tape.text.date_dd.x",                     "-1"                    },
+  { "tape.text.date_dd.y",                     "-1"                    },
+  { "tape.text.date_dd.align",                 "left"                  },
+  { "tape.text.date_dd.valign",                        "top"                   },
+  { "tape.text.date_dd.digits",                        "2"                     },
+  { "tape.text.date_dd.font",                  "font.tape_recorder"    },
+  { "tape.text.date_dd.draw_masked",           "true"                  },
 
   { "tape.text.time.x",                                "44"                    },
   { "tape.text.time.y",                                "55"                    },
   { "tape.text.time.align",                    "left"                  },
   { "tape.text.time.valign",                   "top"                   },
   { "tape.text.time.digits",                   "-1"                    },
+  { "tape.text.time.xoffset",                  "27"                    },
   { "tape.text.time.font",                     "font.tape_recorder"    },
+  { "tape.text.time.draw_masked",              "false"                 },
+
+  { "tape.text.time_hh.x",                     "-1"                    },
+  { "tape.text.time_hh.y",                     "-1"                    },
+  { "tape.text.time_hh.align",                 "left"                  },
+  { "tape.text.time_hh.valign",                        "top"                   },
+  { "tape.text.time_hh.digits",                        "2"                     },
+  { "tape.text.time_hh.font",                  "font.tape_recorder"    },
+  { "tape.text.time_hh.draw_masked",           "true"                  },
+  { "tape.text.time_mm.x",                     "-1"                    },
+  { "tape.text.time_mm.y",                     "-1"                    },
+  { "tape.text.time_mm.align",                 "left"                  },
+  { "tape.text.time_mm.valign",                        "top"                   },
+  { "tape.text.time_mm.digits",                        "2"                     },
+  { "tape.text.time_mm.font",                  "font.tape_recorder"    },
+  { "tape.text.time_mm.draw_masked",           "true"                  },
+  { "tape.text.time_ss.x",                     "-1"                    },
+  { "tape.text.time_ss.y",                     "-1"                    },
+  { "tape.text.time_ss.align",                 "left"                  },
+  { "tape.text.time_ss.valign",                        "top"                   },
+  { "tape.text.time_ss.digits",                        "2"                     },
+  { "tape.text.time_ss.font",                  "font.tape_recorder"    },
+  { "tape.text.time_ss.draw_masked",           "true"                  },
 
   { "tape.show_game_buttons",                  "false"                 },
 
index 965b53483a8f9dc837830e473daba7a04bc04282..4e06b2d24e052c69353f13a9ce2a9d8cd85e28f3 100644 (file)
@@ -6062,10 +6062,162 @@ struct TokenIntPtrInfo image_config_vars[] =
     "tape.text.date.digits",
     &tape.text.date.size
   },
+  {
+    "tape.text.date.xoffset",
+    &tape.text.date.xoffset
+  },
+  {
+    "tape.text.date.2nd_xoffset",
+    &tape.text.date.xoffset2
+  },
   {
     "tape.text.date.font",
     &tape.text.date.font
   },
+  {
+    "tape.text.date.draw_masked",
+    &tape.text.date.draw_masked
+  },
+  {
+    "tape.text.date_yyyy.x",
+    &tape.text.date_yyyy.x
+  },
+  {
+    "tape.text.date_yyyy.y",
+    &tape.text.date_yyyy.y
+  },
+  {
+    "tape.text.date_yyyy.align",
+    &tape.text.date_yyyy.align
+  },
+  {
+    "tape.text.date_yyyy.valign",
+    &tape.text.date_yyyy.valign
+  },
+  {
+    "tape.text.date_yyyy.digits",
+    &tape.text.date_yyyy.size
+  },
+  {
+    "tape.text.date_yyyy.font",
+    &tape.text.date_yyyy.font
+  },
+  {
+    "tape.text.date_yyyy.draw_masked",
+    &tape.text.date_yyyy.draw_masked
+  },
+  {
+    "tape.text.date_yy.x",
+    &tape.text.date_yy.x
+  },
+  {
+    "tape.text.date_yy.y",
+    &tape.text.date_yy.y
+  },
+  {
+    "tape.text.date_yy.align",
+    &tape.text.date_yy.align
+  },
+  {
+    "tape.text.date_yy.valign",
+    &tape.text.date_yy.valign
+  },
+  {
+    "tape.text.date_yy.digits",
+    &tape.text.date_yy.size
+  },
+  {
+    "tape.text.date_yy.font",
+    &tape.text.date_yy.font
+  },
+  {
+    "tape.text.date_yy.draw_masked",
+    &tape.text.date_yy.draw_masked
+  },
+  {
+    "tape.text.date_mmm.x",
+    &tape.text.date_mmm.x
+  },
+  {
+    "tape.text.date_mmm.y",
+    &tape.text.date_mmm.y
+  },
+  {
+    "tape.text.date_mmm.align",
+    &tape.text.date_mmm.align
+  },
+  {
+    "tape.text.date_mmm.valign",
+    &tape.text.date_mmm.valign
+  },
+  {
+    "tape.text.date_mmm.digits",
+    &tape.text.date_mmm.size
+  },
+  {
+    "tape.text.date_mmm.font",
+    &tape.text.date_mmm.font
+  },
+  {
+    "tape.text.date_mmm.draw_masked",
+    &tape.text.date_mmm.draw_masked
+  },
+  {
+    "tape.text.date_mm.x",
+    &tape.text.date_mm.x
+  },
+  {
+    "tape.text.date_mm.y",
+    &tape.text.date_mm.y
+  },
+  {
+    "tape.text.date_mm.align",
+    &tape.text.date_mm.align
+  },
+  {
+    "tape.text.date_mm.valign",
+    &tape.text.date_mm.valign
+  },
+  {
+    "tape.text.date_mm.digits",
+    &tape.text.date_mm.size
+  },
+  {
+    "tape.text.date_mm.font",
+    &tape.text.date_mm.font
+  },
+  {
+    "tape.text.date_mm.draw_masked",
+    &tape.text.date_mm.draw_masked
+  },
+  {
+    "tape.text.date_dd.x",
+    &tape.text.date_dd.x
+  },
+  {
+    "tape.text.date_dd.y",
+    &tape.text.date_dd.y
+  },
+  {
+    "tape.text.date_dd.align",
+    &tape.text.date_dd.align
+  },
+  {
+    "tape.text.date_dd.valign",
+    &tape.text.date_dd.valign
+  },
+  {
+    "tape.text.date_dd.digits",
+    &tape.text.date_dd.size
+  },
+  {
+    "tape.text.date_dd.font",
+    &tape.text.date_dd.font
+  },
+  {
+    "tape.text.date_dd.draw_masked",
+    &tape.text.date_dd.draw_masked
+  },
   {
     "tape.text.time.x",
     &tape.text.time.x
@@ -6086,10 +6238,102 @@ struct TokenIntPtrInfo image_config_vars[] =
     "tape.text.time.digits",
     &tape.text.time.size
   },
+  {
+    "tape.text.time.xoffset",
+    &tape.text.time.xoffset
+  },
   {
     "tape.text.time.font",
     &tape.text.time.font
   },
+  {
+    "tape.text.time.draw_masked",
+    &tape.text.time.draw_masked
+  },
+  {
+    "tape.text.time_hh.x",
+    &tape.text.time_hh.x
+  },
+  {
+    "tape.text.time_hh.y",
+    &tape.text.time_hh.y
+  },
+  {
+    "tape.text.time_hh.align",
+    &tape.text.time_hh.align
+  },
+  {
+    "tape.text.time_hh.valign",
+    &tape.text.time_hh.valign
+  },
+  {
+    "tape.text.time_hh.digits",
+    &tape.text.time_hh.size
+  },
+  {
+    "tape.text.time_hh.font",
+    &tape.text.time_hh.font
+  },
+  {
+    "tape.text.time_hh.draw_masked",
+    &tape.text.time_hh.draw_masked
+  },
+  {
+    "tape.text.time_mm.x",
+    &tape.text.time_mm.x
+  },
+  {
+    "tape.text.time_mm.y",
+    &tape.text.time_mm.y
+  },
+  {
+    "tape.text.time_mm.align",
+    &tape.text.time_mm.align
+  },
+  {
+    "tape.text.time_mm.valign",
+    &tape.text.time_mm.valign
+  },
+  {
+    "tape.text.time_mm.digits",
+    &tape.text.time_mm.size
+  },
+  {
+    "tape.text.time_mm.font",
+    &tape.text.time_mm.font
+  },
+  {
+    "tape.text.time_mm.draw_masked",
+    &tape.text.time_mm.draw_masked
+  },
+  {
+    "tape.text.time_ss.x",
+    &tape.text.time_ss.x
+  },
+  {
+    "tape.text.time_ss.y",
+    &tape.text.time_ss.y
+  },
+  {
+    "tape.text.time_ss.align",
+    &tape.text.time_ss.align
+  },
+  {
+    "tape.text.time_ss.valign",
+    &tape.text.time_ss.valign
+  },
+  {
+    "tape.text.time_ss.digits",
+    &tape.text.time_ss.size
+  },
+  {
+    "tape.text.time_ss.font",
+    &tape.text.time_ss.font
+  },
+  {
+    "tape.text.time_ss.draw_masked",
+    &tape.text.time_ss.draw_masked
+  },
   {
     "tape.show_game_buttons",
     &tape.show_game_buttons
index f7259356ee8eb5932f8d76d43605975a4eccaf59..d5027aecd803aedaa1543eb07bebe01fb748d927 100644 (file)
@@ -1204,13 +1204,15 @@ struct DoorPartPosInfo
 struct TextPosInfo
 {
   int x, y;
+  int xoffset;                 /* special case for tape date and time */
+  int xoffset2;                        /* special case for tape date */
   int width, height;
   int align, valign;
-  int size;
+  int size;                    /* also used for suffix ".digits" */
   int font, font_alt;
   boolean draw_masked;
   boolean draw_player;         /* special case for network player buttons */
-  int sort_priority;
+  int sort_priority;           /* also used for suffix ".draw_order" */
   int id;
 };
 
index fb36f1e28806046a69c6b1dfe1a1cfc6c9ff6bec..9de9839b5f2608b77108f742418df5229e31f11d 100644 (file)
@@ -294,12 +294,16 @@ void DrawVideoDisplay(unsigned int state, unsigned int value)
   {
     struct TextPosInfo *pos = &tape.text.date;
     int tag = value % 100;
-    int monat = (value/100) % 100;
-    int jahr = (value/10000);
-
-    DrawText(VX + pos->x,      VY + pos->y, int2str(tag, 2),   pos->font);
-    DrawText(VX + pos->x + 27, VY + pos->y, monatsname[monat], pos->font);
-    DrawText(VX + pos->x + 64, VY + pos->y, int2str(jahr, 2),  pos->font);
+    int monat = (value / 100) % 100;
+    int jahr = (value / 10000);
+    int xpos1 = VX + pos->x;
+    int xpos2 = VX + pos->x + pos->xoffset;
+    int xpos3 = VX + pos->x + pos->xoffset2;
+    int ypos  = VY + pos->y;
+
+    DrawText(xpos1, ypos, int2str(tag, 2),   pos->font);
+    DrawText(xpos2, ypos, monatsname[monat], pos->font);
+    DrawText(xpos3, ypos, int2str(jahr, 2),  pos->font);
   }
 
   if (state & VIDEO_STATE_TIME_ON)
@@ -307,9 +311,12 @@ void DrawVideoDisplay(unsigned int state, unsigned int value)
     struct TextPosInfo *pos = &tape.text.time;
     int min = value / 60;
     int sec = value % 60;
+    int xpos1 = VX + pos->x;
+    int xpos2 = VX + pos->x + pos->xoffset;
+    int ypos  = VY + pos->y;
 
-    DrawText(VX + pos->x,      VY + pos->y, int2str(min, 2), pos->font);
-    DrawText(VX + pos->x + 27, VY + pos->y, int2str(sec, 2), pos->font);
+    DrawText(xpos1, ypos, int2str(min, 2), pos->font);
+    DrawText(xpos2, ypos, int2str(sec, 2), pos->font);
   }
 
   redraw_mask |= REDRAW_DOOR_2;
index 0e6d11d880404fb244a792bc8c1bd6a98c7153d5..d1b60330484758f17e7e3b680c03a9070132007b 100644 (file)
@@ -133,7 +133,16 @@ struct TapeLabelInfo
 struct TapeTextInfo
 {
   struct TextPosInfo date;
+  struct TextPosInfo date_yyyy;
+  struct TextPosInfo date_yy;
+  struct TextPosInfo date_mmm;
+  struct TextPosInfo date_mm;
+  struct TextPosInfo date_dd;
+
   struct TextPosInfo time;
+  struct TextPosInfo time_hh;
+  struct TextPosInfo time_mm;
+  struct TextPosInfo time_ss;
 };
 
 struct TapeInfo