aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--screen.c149
1 files changed, 113 insertions, 36 deletions
diff --git a/screen.c b/screen.c
index 940f98b9d..ea5cc3625 100644
--- a/screen.c
+++ b/screen.c
@@ -35,13 +35,18 @@
#include "screen_search.h"
#include "screen_utils.h"
-#ifdef ENABLE_KEYDEF_SCREEN
-extern screen_functions_t *get_screen_keydef(void);
-#endif
+#define ENABLE_MP_FLAGS_DISPLAY
+#undef ENABLE_STATUS_LINE_CLOCK
+
+#define DEFAULT_CROSSFADE_TIME 10
#define STATUS_MESSAGE_TIMEOUT 3
#define STATUS_LINE_MAX_SIZE 512
+#ifdef ENABLE_KEYDEF_SCREEN
+extern screen_functions_t *get_screen_keydef(void);
+#endif
+
static screen_t *screen = NULL;
static screen_functions_t *mode_fn = NULL;
@@ -86,7 +91,7 @@ switch_screen_mode(screen_mode_t new_mode, mpd_client_t *c)
}
static void
-paint_top_window(char *header, int volume, int clear)
+paint_top_window(char *header, mpd_client_t *c, int clear)
{
static int prev_volume = -1;
static int prev_header_len = -1;
@@ -104,7 +109,7 @@ paint_top_window(char *header, int volume, int clear)
wclrtoeol(w);
}
- if(prev_volume!=volume || clear)
+ if(prev_volume!=c->status->volume || clear)
{
char buf[12];
@@ -129,33 +134,44 @@ paint_top_window(char *header, int volume, int clear)
wattroff(w, A_BOLD);
waddstr(w, ":Browse");
}
- if( volume==MPD_STATUS_NO_VOLUME )
+ if( c->status->volume==MPD_STATUS_NO_VOLUME )
{
snprintf(buf, 12, "Volume n/a ");
}
else
{
- snprintf(buf, 12, "Volume %3d%%", volume);
+ snprintf(buf, 12, "Volume %3d%%", c->status->volume);
}
mvwaddstr(w, 0, screen->top_window.cols-12, buf);
-#if 1
- if( options.enable_colors )
- wattron(w, LINE_COLORS);
- mvwhline(w, 1, 0, ACS_HLINE, screen->top_window.cols);
- if( options.enable_colors )
- wattroff(w, LINE_COLORS);
-#else
if( options.enable_colors )
wattron(w, LINE_COLORS);
+#ifdef ENABLE_MP_FLAGS_DISPLAY
+ {
+ char buf[4];
+
+ buf[0] = 0;
+ if( c->status->repeat )
+ strcat(buf, "r");
+ if( c->status->random )
+ strcat(buf, "z");
+ if( c->status->crossfade )
+ strcat(buf, "x");
+
+ mvwhline(w, 1, 0, ACS_HLINE, screen->top_window.cols);
+ if( buf[0] )
+ {
+ wmove(w,1,screen->top_window.cols-strlen(buf)-3);
+ waddch(w, '[');
+ wattron(w, A_BOLD);
+ waddstr(w, buf);
+ wattroff(w, A_BOLD);
+ waddch(w, ']');
+ }
+ }
+#else
mvwhline(w, 1, 0, ACS_HLINE, screen->top_window.cols);
- wmove(w,1,screen->top_window.cols-6);
- waddstr(w, "[rzx]");
-
- if( options.enable_colors )
- wattroff(w, LINE_COLORS);
-
#endif
wnoutrefresh(w);
@@ -167,6 +183,7 @@ paint_progress_window(mpd_client_t *c)
{
double p;
int width;
+ int elapsedTime = c->status->elapsedTime;
if( c->status==NULL || IS_STOPPED(c->status->state) )
{
@@ -176,7 +193,10 @@ paint_progress_window(mpd_client_t *c)
return;
}
- p = ((double) c->status->elapsedTime) / ((double) c->status->totalTime);
+ if( c->seek_song_id == c->song_id )
+ elapsedTime = c->seek_target_time;
+
+ p = ((double) elapsedTime) / ((double) c->status->totalTime);
width = (int) (p * (double) screen->progress_window.cols);
mvwhline(screen->progress_window.w,
@@ -245,15 +265,15 @@ paint_status_window(mpd_client_t *c)
mvwaddstr(w, 0, x, screen->buf);
}
-#if 0
+#ifdef ENABLE_STATUS_LINE_CLOCK
else if( c->status->state == MPD_STATUS_STATE_STOP )
{
time_t timep;
- x = screen->status_window.cols - strlen(screen->buf);
-
+
+ /* Note: setlocale(LC_TIME,"") should be used first */
time(&timep);
- //strftime(screen->buf, screen->buf_size, "%X ", localtime(&timep));
- strftime(screen->buf, screen->buf_size, "%R ", localtime(&timep));
+ strftime(screen->buf, screen->buf_size, "%X ", localtime(&timep));
+ x = screen->status_window.cols - strlen(screen->buf) ;
mvwaddstr(w, 0, x, screen->buf);
}
#endif
@@ -388,6 +408,7 @@ screen_init(void)
screen->buf_size = screen->cols;
screen->findbuf = NULL;
screen->painted = 0;
+ screen->start_timestamp = time(NULL);
screen->input_timestamp = time(NULL);
screen->last_cmd = CMD_NONE;
@@ -476,9 +497,9 @@ screen_paint(mpd_client_t *c)
{
/* paint the title/header window */
if( mode_fn && mode_fn->get_title )
- paint_top_window(mode_fn->get_title(), c->status->volume, 1);
+ paint_top_window(mode_fn->get_title(), c, 1);
else
- paint_top_window("", c->status->volume, 1);
+ paint_top_window("", c, 1);
/* paint the main window */
if( mode_fn && mode_fn->paint )
@@ -500,6 +521,7 @@ screen_update(mpd_client_t *c)
static int repeat = -1;
static int random = -1;
static int crossfade = -1;
+ static int welcome = 1;
list_window_t *lw = NULL;
if( !screen->painted )
@@ -526,13 +548,16 @@ screen_update(mpd_client_t *c)
crossfade = c->status->crossfade;
/* update title/header window */
- if( screen->last_cmd==CMD_NONE &&
- time(NULL)-screen->input_timestamp <= SCREEN_WELCOME_TIME)
- paint_top_window("", c->status->volume, 0);
+ if( welcome && screen->last_cmd==CMD_NONE &&
+ time(NULL)-screen->start_timestamp <= SCREEN_WELCOME_TIME)
+ paint_top_window("", c, 0);
else if( mode_fn && mode_fn->get_title )
- paint_top_window(mode_fn->get_title(), c->status->volume, 0);
+ {
+ paint_top_window(mode_fn->get_title(), c, 0);
+ welcome = 0;
+ }
else
- paint_top_window("", c->status->volume, 0);
+ paint_top_window("", c, 0);
/* update the main window */
if( mode_fn && mode_fn->paint )
@@ -558,6 +583,23 @@ screen_update(mpd_client_t *c)
doupdate();
}
+void
+screen_idle(mpd_client_t *c)
+{
+ if( c->seek_song_id == c->song_id &&
+ (screen->last_cmd == CMD_SEEK_FORWARD ||
+ screen->last_cmd == CMD_SEEK_BACKWARD) )
+ {
+ mpd_sendSeekCommand(c->connection,
+ c->seek_song_id,
+ c->seek_target_time);
+ mpd_finishCommand(c->connection);
+ }
+
+ screen->last_cmd = CMD_NONE;
+ c->seek_song_id = -1;
+}
+
void
screen_cmd(mpd_client_t *c, command_t cmd)
{
@@ -584,20 +626,47 @@ screen_cmd(mpd_client_t *c, command_t cmd)
mpd_sendStopCommand(c->connection);
mpd_finishCommand(c->connection);
break;
+ case CMD_SEEK_FORWARD:
+ if( !IS_STOPPED(c->status->state) )
+ {
+ if( c->seek_song_id != c->song_id )
+ {
+ c->seek_song_id = c->song_id;
+ c->seek_target_time = c->status->elapsedTime;
+ }
+ c->seek_target_time++;
+ if( c->seek_target_time < c->status->totalTime )
+ break;
+ c->seek_target_time=0;
+ }
+ /* fall through... */
case CMD_TRACK_NEXT:
- if( IS_PLAYING(c->status->state) )
+ if( !IS_STOPPED(c->status->state) )
{
mpd_sendNextCommand(c->connection);
mpd_finishCommand(c->connection);
}
break;
+ case CMD_SEEK_BACKWARD:
+ if( !IS_STOPPED(c->status->state) )
+ {
+ if( c->seek_song_id != c->song_id )
+ {
+ c->seek_song_id = c->song_id;
+ c->seek_target_time = c->status->elapsedTime;
+ }
+ c->seek_target_time--;
+ if( c->seek_target_time < 0 )
+ c->seek_target_time=0;
+ }
+ break;
case CMD_TRACK_PREVIOUS:
- if( IS_PLAYING(c->status->state) )
+ if( !IS_STOPPED(c->status->state) )
{
mpd_sendPrevCommand(c->connection);
mpd_finishCommand(c->connection);
}
- break;
+ break;
case CMD_SHUFFLE:
mpd_sendShuffleCommand(c->connection);
mpd_finishCommand(c->connection);
@@ -619,6 +688,14 @@ screen_cmd(mpd_client_t *c, command_t cmd)
mpd_sendRandomCommand(c->connection, n);
mpd_finishCommand(c->connection);
break;
+ case CMD_CROSSFADE:
+ if( c->status->crossfade )
+ n = 0;
+ else
+ n = DEFAULT_CROSSFADE_TIME;
+ mpd_sendCrossfadeCommand(c->connection, n);
+ mpd_finishCommand(c->connection);
+ break;
case CMD_VOLUME_UP:
if( c->status->volume!=MPD_STATUS_NO_VOLUME && c->status->volume<100 )
{