home · contact · privacy
Made vertical scroll hint more informative.
authorChristian Heller <c.heller@plomlompom.de>
Thu, 6 Jun 2013 10:56:37 +0000 (12:56 +0200)
committerChristian Heller <c.heller@plomlompom.de>
Thu, 6 Jun 2013 10:56:37 +0000 (12:56 +0200)
draw_wins.c
draw_wins.h
windows.c
windows.h

index 8603d961bbae1a098d6d8ada22baf8368b9b5cd4..a7da818611b13397730d2a6b845a115491943708 100644 (file)
@@ -99,7 +99,7 @@ void draw_info_win (struct Win * win) {
   snprintf(text, 100, "Turn: %d", count);
   draw_with_linebreaks(win, text, 0); }
 
-void draw_scroll_hint (struct Win * win, uint16_t y, uint32_t more_lines, char dir) {
+void draw_horizontal_scroll_hint (struct Win * win, uint16_t y, uint32_t more_lines, char dir) {
 // Draw scroll hint line in win at row y, announce more_lines more lines in direction dir.
   uint16_t x, offset;
   char phrase[] = "more lines";
@@ -130,10 +130,10 @@ void draw_keys_win (struct Win * win) {
   attr_t attri;
   for (y = 0; y <= world->keyswindata->max && y < win->height; y++) {
     if (0 == y && offset > 0) {
-      draw_scroll_hint (win, y, offset + 1, '^');
+      draw_horizontal_scroll_hint (win, y, offset + 1, '^');
       continue; }
     else if (win->height == y + 1 && 0 < world->keyswindata->max - (win->height + offset - 1)) {
-      draw_scroll_hint (win, y, world->keyswindata->max - (offset + win->height) + 2, 'v');
+      draw_horizontal_scroll_hint (win, y, world->keyswindata->max - (offset + win->height) + 2, 'v');
       continue; }
     attri = 0;
     if (y == world->keyswindata->select - offset) {
index 4ed3c24cf9c6319c2bb0f0ac7a1fd38169ab7774..20b567670445b9749e25224467b7e025e2bb2443 100644 (file)
@@ -3,5 +3,5 @@ void draw_text_from_bottom (struct Win *, char *);
 void draw_log_win (struct Win *);
 void draw_map_win (struct Win *);
 void draw_info_win (struct Win *);
-void draw_scroll_hint (struct Win *, uint16_t, uint32_t, char);
+void draw_horizontal_scroll_hint (struct Win *, uint16_t, uint32_t, char);
 void draw_keys_win (struct Win *);
index 461a98ee7e8234801e504efe2b1fdb732757b99c..47c1a44b9d1f8950b286f23a4ad2d0f0f1f34c1e 100644 (file)
--- a/windows.c
+++ b/windows.c
@@ -171,6 +171,23 @@ void draw_windows (struct Win * win) {
   if (0 != win->next) {
     draw_windows (win->next); } }
 
+void draw_vertical_scroll_hint (struct WinMeta * win_meta, uint16_t x, uint32_t more_cols, char dir) {
+// Draw scroll hint line in win at col x of pad display, announce more_cols more columns in direction dir.
+  uint16_t y, offset;
+  offset = 0;
+  char phrase[] = "more columns";
+  char * scrolldesc = malloc((3 * sizeof(char)) + strlen(phrase) + 10); // 10 = max chars for uint32_t string
+  sprintf(scrolldesc, " %d %s ", more_cols, phrase);
+  offset = 1;
+  if (win_meta->height > (strlen(scrolldesc) + 1))
+    offset = (win_meta->height - strlen(scrolldesc)) / 2;
+  for (y = 0; y < win_meta->height; y++)
+    if (y >= offset && y < strlen(scrolldesc) + offset)
+      mvwaddch(win_meta->pad, y, x, scrolldesc[y - offset] | A_REVERSE);
+    else
+      mvwaddch(win_meta->pad, y, x, dir | A_REVERSE);
+  free(scrolldesc); }
+
 void draw_all_windows (struct WinMeta * win_meta) {
 // Draw pad with all windows and their borders, plus scrolling hints.
   erase();
@@ -194,11 +211,11 @@ void draw_all_windows (struct WinMeta * win_meta) {
     free(all_corners);
     uint16_t y;
     if (win_meta->pad_offset > 0)
-      for (y = 0; y < win_meta->height; y++)
-        mvwaddch(win_meta->pad, y, win_meta->pad_offset, '<' | A_REVERSE);
+        draw_vertical_scroll_hint(win_meta, win_meta->pad_offset, win_meta->pad_offset + 1, '<');
     if (win_meta->pad_offset + win_meta->width < getmaxx(win_meta->pad) - 1)
       for (y = 0; y < win_meta->height; y++)
-        mvwaddch(win_meta->pad, y, win_meta->pad_offset + win_meta->width - 1, '>' | A_REVERSE);
+        draw_vertical_scroll_hint(win_meta, win_meta->pad_offset + win_meta->width - 1,
+                                  getmaxx(win_meta->pad) - (win_meta->pad_offset + win_meta->width + 1), '>');
     pnoutrefresh(win_meta->pad, 0, win_meta->pad_offset, 0, 0, win_meta->height, win_meta->width - 1); }
   doupdate(); }
 
index 904cc9f13a2981618551045ea060e38acbbd1911..522f26f37b882dd0eba3049327768930287e89ac 100644 (file)
--- a/windows.h
+++ b/windows.h
@@ -39,6 +39,7 @@ void destroy_window (struct Win *);
 void draw_windows (struct Win *);
 void draw_windows_borders (struct Win *, struct Win *, struct Corners *, uint16_t);
 void draw_window_borders (struct Win *, char);
+void draw_vertical_scroll_hint (struct WinMeta *, uint16_t, uint32_t, char);
 void draw_all_windows (struct WinMeta *);
 void resize_active_window (struct WinMeta *, uint16_t, uint16_t);
 void cycle_active_window (struct WinMeta *, char);