summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Gordon <rockbox@jdgordon.info>2009-10-28 06:44:37 +0000
committerJonathan Gordon <rockbox@jdgordon.info>2009-10-28 06:44:37 +0000
commitbee59000324bfd74a38d6d652dae62fc61b3b344 (patch)
tree1f210c42661e3f2bc3de3d0e73e0e2c635b43611
parenta30f25ddd422c3bf39a6c9964b25c3a7b01676b3 (diff)
downloadrockbox-bee59000324bfd74a38d6d652dae62fc61b3b344.zip
rockbox-bee59000324bfd74a38d6d652dae62fc61b3b344.tar.gz
rockbox-bee59000324bfd74a38d6d652dae62fc61b3b344.tar.bz2
rockbox-bee59000324bfd74a38d6d652dae62fc61b3b344.tar.xz
Allow the x and y pixel values of viewports to be a negative number..
%V|-50|0|-|..... will position that viewport 50 pixels from the right of the display at the top. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23378 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/gui/viewport.c6
-rw-r--r--apps/misc.c10
-rw-r--r--wps/classic_statusbar.sbs2
3 files changed, 15 insertions, 3 deletions
diff --git a/apps/gui/viewport.c b/apps/gui/viewport.c
index f39a299..9bf0e80 100644
--- a/apps/gui/viewport.c
+++ b/apps/gui/viewport.c
@@ -445,7 +445,11 @@ const char* viewport_parse_viewport(struct viewport *vp,
/* X and Y *must* be set */
if (!LIST_VALUE_PARSED(set, PL_X) || !LIST_VALUE_PARSED(set, PL_Y))
return NULL;
-
+ /* check for negative values */
+ if (vp->x < 0)
+ vp->x += screens[screen].lcdwidth;
+ if (vp->y < 0)
+ vp->y += screens[screen].lcdheight;
/* fix defaults */
if (!LIST_VALUE_PARSED(set, PL_WIDTH))
vp->width = screens[screen].lcdwidth - vp->x;
diff --git a/apps/misc.c b/apps/misc.c
index 5af57fe..6be9f8f 100644
--- a/apps/misc.c
+++ b/apps/misc.c
@@ -945,7 +945,7 @@ const char* parse_list(const char *fmt, uint32_t *set_vals,
const char* p = str, *f = fmt;
const char** s;
int* d;
- bool set;
+ bool set, is_negative;
int i=0;
va_start(ap, str);
@@ -973,7 +973,13 @@ const char* parse_list(const char *fmt, uint32_t *set_vals,
break;
case 'd': /* int */
+ is_negative = false;
d = va_arg(ap, int*);
+ if (*p == '-' && isdigit(*(p+1)))
+ {
+ is_negative = true;
+ p++;
+ }
if (!isdigit(*p))
{
if (!set_vals || *p != '-')
@@ -987,6 +993,8 @@ const char* parse_list(const char *fmt, uint32_t *set_vals,
while (isdigit(*p))
*d = (*d * 10) + (*p++ - '0');
set = true;
+ if (is_negative)
+ *d *= -1;
}
break;
diff --git a/wps/classic_statusbar.sbs b/wps/classic_statusbar.sbs
index 23e6e14..22fa9e5 100644
--- a/wps/classic_statusbar.sbs
+++ b/wps/classic_statusbar.sbs
@@ -35,5 +35,5 @@
# Clock on RTC able targets, and disk access
-%V|140|0|-|8|0|-|-| # The 140 is (LCD_WIDTH-(6 letters * 6 pixels))
+%V|-36|0|-|8|0|-|-| # align on the right with room for 6 SYSFONT digits
%?ca<%?St|time format|<%cH|%cI>:%cM|--:-->%?lh<*|>