diff options
author | Martin Hammerschmid <linux@home.pages.at> | 2002-08-31 12:19:51 +0200 |
---|---|---|
committer | Martin Hammerschmid <linux@home.pages.at> | 2002-08-31 12:19:51 +0200 |
commit | ca0ae4567ef652252372fba01327dd23d9d1b8b0 (patch) | |
tree | 92be82098f5f74328dc22ff6d253f47081dc3173 | |
parent | 2a3f6ddb352317d0f23624ca24fb8240d1cb5026 (diff) | |
download | vdr-plugin-lcdproc-0.0.3.tar.gz vdr-plugin-lcdproc-0.0.3.tar.bz2 |
Version 0.0.3v0.0.3release/v0.0.3
-rw-r--r-- | lcd.c | 73 | ||||
-rw-r--r-- | lcd.h | 4 | ||||
-rw-r--r-- | lcdproc.c | 10 |
3 files changed, 74 insertions, 13 deletions
@@ -32,7 +32,7 @@ cLcd::cLcd() { int i,j; - connected=false; ThreadStateData.showvolume=false; sock=wid=hgt=cellwid=cellhgt=0; + connected=false; ThreadStateData.showvolume=false; ThreadStateData.newscroll=false; sock=wid=hgt=cellwid=cellhgt=0; replayDvbApi=NULL; primaryDvbApi=NULL; for (i=0;i<LCDMAXSTATES;i++) for (j=0;j<4;j++) { @@ -132,6 +132,13 @@ void cLcd::SetMain( unsigned int n, const char *string) { char line3[wid+1]; if (string != NULL) { + cLcd::Copy(ThreadStateData.lcdfullbuffer[n],string,LCDMAXFULLSTRING-3); + int i = strlen(ThreadStateData.lcdfullbuffer[n]); + ThreadStateData.lcdfullbuffer[n][i++]=' '; + ThreadStateData.lcdfullbuffer[n][i++]='*'; + ThreadStateData.lcdfullbuffer[n][i++]=' '; + ThreadStateData.lcdfullbuffer[n][i]='\0'; + ThreadStateData.newscroll=true; cLcd::Copy(StringBuffer,string,2*wid); cLcd::Split(StringBuffer,line2,line3); } @@ -314,6 +321,7 @@ void cLcd::SetRunning( bool nownext, const char *string1, const char *string2, c (string3==NULL || string3[0]=='\0')?"":"|", (string3==NULL || string3[0]=='\0')?" ":string3); cLcd::Copy(line1,line,2*wid); + if (nownext) { cLcd::Split(line1,ThreadStateData.lcdbuffer[LCDMISC][2],ThreadStateData.lcdbuffer[LCDMISC][3]); ThreadStateData.lcddirty[LCDMISC][2]=true; ThreadStateData.lcddirty[LCDMISC][3]=true; @@ -323,6 +331,14 @@ void cLcd::SetRunning( bool nownext, const char *string1, const char *string2, c ThreadStateData.lcddirty[LCDTITLE][2]=true; ThreadStateData.lcddirty[LCDTITLE][3]=true; EndMutualExclusion(); cLcd::SetBuffer(LCDMISC,ThreadStateData.lcdbuffer[LCDTITLE][2],ThreadStateData.lcdbuffer[LCDTITLE][3],NULL,NULL); + + cLcd::Copy(ThreadStateData.lcdfullbuffer[LCDTITLE],line,LCDMAXFULLSTRING-3); + int i = strlen(ThreadStateData.lcdfullbuffer[LCDTITLE]); + ThreadStateData.lcdfullbuffer[LCDTITLE][i++]=' '; + ThreadStateData.lcdfullbuffer[LCDTITLE][i++]='*'; + ThreadStateData.lcdfullbuffer[LCDTITLE][i++]=' '; + ThreadStateData.lcdfullbuffer[LCDTITLE][i]='\0'; + ThreadStateData.newscroll=true; } } @@ -503,8 +519,8 @@ void cLcd::GetTimeDateStat( char *string, unsigned int OutStateData[] ) { #define VolumeKeep 1500000 // us void cLcd::Action(void) { // LCD output thread - unsigned int i,j, barx=1, bary=1, barl=0; - int Current=0, Total=1; + unsigned int i,j, barx=1, bary=1, barl=0, ScrollState=0, ScrollLine=1; + int Current=0, Total=1, scrollpos=0,scrollspeed=3,scrollcnt=0, scrollwait=10, scrollwaitcnt=10; struct timeval now, voltime; char workstring[256]; cLcd::ThreadStates PrevState=Menu; @@ -546,7 +562,8 @@ void cLcd::Action(void) { // LCD output thread if ( (!isempty(PresentTitle)) && (!isempty(PresentSubtitle)) ) SetRunning(false,Present->GetTimeString(),PresentTitle,PresentSubtitle); else if (!isempty(PresentTitle)) SetRunning(false,Present->GetTimeString(),PresentTitle); - } + } else + SetRunning(false,"No EPG info available.\0", NULL); // XXX tr !!! if ((Present = Schedule->GetFollowingEvent()) != NULL) nextLcdUpdate=(Present->GetTime()<nextLcdUpdate)?Present->GetTime():nextLcdUpdate; } @@ -564,19 +581,59 @@ void cLcd::Action(void) { // LCD output thread replayDvbApi->GetIndex(Current, Total, false); sprintf(tempbuffer,IndexToHMSF(Total)); SetProgress(IndexToHMSF(Current),tempbuffer, (100 * Current) / Total); - } + } + + // copy BeginMutualExclusion(); // all data needed for output are copied here memcpy(&OutStateData,&ThreadStateData, sizeof (cLcd::StateData)); - ThreadStateData.showvolume=false; + ThreadStateData.showvolume=false; + if (ThreadStateData.newscroll) { scrollpos=0; scrollwaitcnt=scrollwait; ThreadStateData.newscroll=false; } for (i=0;i<LCDMAXSTATES;i++) for (j=0;j<4;j++) { ThreadStateData.lcddirty[i][j]=false; Lcddirty[i][j]= Lcddirty[i][j] || OutStateData.lcddirty[i][j]; } EndMutualExclusion(); + + // scroller + if ( (OutStateData.State==PrevState) && ( PrevState == Replay || PrevState == Menu || PrevState == Title ) ) { + switch (PrevState) { + case Replay: + ScrollState=LCDREPLAY; ScrollLine=1; + break; + case Menu: + ScrollState=LCDMENU; ScrollLine=1; + break; + case Title: + ScrollState=LCDTITLE; ScrollLine=2; + break; + default: + break; + } + + if ( ( strlen(OutStateData.lcdfullbuffer[ScrollState]) > (2*wid+3) ) + && !(scrollcnt=(scrollcnt+1)%scrollspeed) ) { + if ( (scrollpos) || (scrollwaitcnt-- < 1) ) { + scrollpos=(scrollpos+1)%strlen(OutStateData.lcdfullbuffer[ScrollState]); + if ( scrollpos==1 ) scrollwaitcnt=scrollwait; + for (i=0; i<wid; i++) { + OutStateData.lcdbuffer[ScrollState][ScrollLine][i]= + OutStateData.lcdfullbuffer[ScrollState][(scrollpos+i)%strlen(OutStateData.lcdfullbuffer[ScrollState])]; + } + OutStateData.lcdbuffer[ScrollState][ScrollLine][wid]='\0'; + for (i=0; i<wid; i++) { + OutStateData.lcdbuffer[ScrollState][ScrollLine+1][i]= + OutStateData.lcdfullbuffer[ScrollState][(scrollpos+wid+i)%strlen(OutStateData.lcdfullbuffer[ScrollState])]; + } + OutStateData.lcdbuffer[ScrollState][ScrollLine+1][wid]='\0'; + Lcddirty[ScrollState][ScrollLine]=Lcddirty[ScrollState][ScrollLine+1]=true; + } + } + } + // volume if (OutStateData.showvolume) gettimeofday(&voltime,NULL); @@ -596,7 +653,7 @@ void cLcd::Action(void) { // LCD output thread switch (OutStateData.State) { case Menu: // display menu = 0 - LineMode=1; + LineMode=1; if (!volume) { OutStateData.barx=1; OutStateData.bary=1; OutStateData.barl=0; } if (PrevState != Menu) for (i=0;i<4;i++) Lcddirty[LCDMENU][i]=true; for (i=0;i<4;i++) if (Lcddirty[LCDMENU][i]) { cLcd::Write(i+1,OutStateData.lcdbuffer[LCDMENU][i]); @@ -625,7 +682,7 @@ void cLcd::Action(void) { // LCD output thread cLcd::GetTimeDateStat(workstring,OutStateData.CardStat); cLcd::Write(1,workstring); } - if (PrevState != Replay) for (i=1;i<4;i++) Lcddirty[LCDREPLAY][i]=true; + if (PrevState != Replay) { scrollpos=0; for (i=1;i<4;i++) Lcddirty[LCDREPLAY][i]=true; } for (i=1;i<4;i++) if (Lcddirty[LCDREPLAY][i]) { cLcd::Write(i+1,OutStateData.lcdbuffer[LCDREPLAY][i]); Lcddirty[LCDREPLAY][i]=false; @@ -12,6 +12,7 @@ #define LCDMAXSTATEBUF 5 #define LCDMAXWID 40 #define LCDMAXCARDS 4 +#define LCDMAXFULLSTRING 1024 class cLcd : public cThread { public: @@ -22,7 +23,8 @@ class cLcd : public cThread { int LastStateP,LineMode; struct StateData { char lcdbuffer[LCDMAXSTATES][4][LCDMAXWID+1]; - bool lcddirty[LCDMAXSTATES][4], muted, showvolume; + char lcdfullbuffer[LCDMAXSTATES][LCDMAXFULLSTRING]; + bool lcddirty[LCDMAXSTATES][4], muted, showvolume, newscroll; ThreadStates State; unsigned int barx, bary, barl, volume; unsigned int CardStat[LCDMAXCARDS]; @@ -1,5 +1,5 @@ /* - * status.c: A plugin for the Video Disk Recorder + * lcdproc.c: A plugin for the Video Disk Recorder * * See the README file for copyright information and how to reach the author. * @@ -13,7 +13,7 @@ #include <vdr/recording.h> #include "lcd.h" -static const char *VERSION = "0.0.2"; +static const char *VERSION = "0.0.3"; static const char *MAINMENUENTRY = NULL; #ifdef LCD_hd44780 static const char *DESCRIPTION = "LCDproc using hd44780 output-mapping"; @@ -58,7 +58,8 @@ void cLcdFeed::ChannelSwitch(const cDevice *Device, int ChannelNumber) syslog(LOG_INFO, "lcdproc: cLcdFeed::ChannelSwitch %d %d", Device->CardIndex(), ChannelNumber); if (ChannelNumber) { LCDproc->SetLine(1,2," "); - LCDproc->SetLine(1,3," "); + LCDproc->SetLine(1,3," "); + LCDproc->SetRunning(false,"No EPG info available.\0", NULL); // XXX tr !!! switched = true; } else switched = false; if (Device) LCDproc->SetPrimaryDevice( (cDevice *) Device ); @@ -183,6 +184,7 @@ void cLcdFeed::OsdProgramme(time_t PresentTime, const char *PresentTitle, const if ( (!isempty(PresentTitle)) && (!isempty(PresentSubtitle)) ) LCDproc->SetRunning(false,buffer,PresentTitle,PresentSubtitle); else if (!isempty(PresentTitle)) LCDproc->SetRunning(false,buffer,PresentTitle); + else LCDproc->SetRunning(false,"No EPG info available.\0", NULL); // XXX tr !!! strftime(buffer, sizeof(buffer), "%R", localtime_r(&FollowingTime, &tm_r)); @@ -192,7 +194,7 @@ void cLcdFeed::OsdProgramme(time_t PresentTime, const char *PresentTitle, const if ( (!isempty(FollowingTitle)) && (!isempty(FollowingSubtitle)) ) LCDproc->SetRunning(true,buffer,FollowingTitle,FollowingSubtitle); else if (!isempty(FollowingTitle)) LCDproc->SetRunning(true,buffer,FollowingTitle); - + else LCDproc->SetRunning(true,"No EPG info available.\0", NULL); // XXX tr !!! } // --- |