mirror of
				https://projects.vdr-developer.org/git/vdr-plugin-tvguide.git
				synced 2023-10-05 13:01:48 +00:00 
			
		
		
		
	Compare commits
	
		
			23 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 240cbe87e0 | ||
|  | ee68d2eb2f | ||
|  | eb3a4113be | ||
|  | 7ec89bf12b | ||
|  | f653594c4a | ||
|  | 8129d116fb | ||
|  | 874f5cd9d5 | ||
|  | 9044e092f8 | ||
|  | b96f800240 | ||
|  | 5d9ed1439a | ||
|  | 66a0c15aea | ||
|  | 8db88c2556 | ||
|  | 509b64d78f | ||
|  | 15b7074b4e | ||
|  | 3fee6ab13f | ||
|  | ffd3e2c79f | ||
|  | c77f74321f | ||
|  | efe06b8e98 | ||
|  | 6540e21444 | ||
|  | 2e4a43133e | ||
|  | bcf2ce757c | ||
|  | 263a734a0d | ||
|  | 7300fdf91c | 
							
								
								
									
										33
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -232,3 +232,36 @@ Version 1.2.14 | ||||
| - Diplay the current TimeBase throughout the whole timeline | ||||
| - Can switch off and optimize diplay time in epggrid "displayMode == Vertical" | ||||
| - Fixed a error while changing a Theme | ||||
|  | ||||
| Version 1.2.15 | ||||
|  | ||||
| - Workaround for HWAccelerated OSD | ||||
|  | ||||
| Version 1.2.16 | ||||
|  | ||||
| - Fixed a timer changed message | ||||
| - Extend keys kFastRew, kFastFwd, kPrev, kNext for TimeJump | ||||
|   (if you use the numeric keys for "Jump to specific channel", | ||||
|   you can now use the keys kFastRew, kFastFwd, kPrev, kNext for TimeJump. | ||||
|   Note: if you use the permashift-plugin then the key kFastRew doesnt work for TimeJump) | ||||
| - Fixed a possible deadlook in cEPGView::cEPGView | ||||
| - Refactor Timeline | ||||
| - Refactor CutText in horizontal epgview | ||||
| - Optimize display "REC" sign in epgview | ||||
| - Separate "displayTime" for horizontal and vertical view | ||||
| - RecMenu "Timer Timeline" displays now sorted active timer | ||||
|  | ||||
| Version 1.2.17 | ||||
|  | ||||
| - Final fix for utf8 CutText | ||||
| - Fixed a remote timer problem | ||||
| - Add episode to manual timer | ||||
|  | ||||
| Version 1.3.0 | ||||
|  | ||||
| - last version with <VDR-2.3.1 compatibility | ||||
| - Fixed a possible seqfault in DisplayTimerConflict | ||||
| - Show numTimersToday in timeline | ||||
| - Fixed stopIndex in cRecMenu::JumpBegin | ||||
| - Fixed horizontal alignment in timeline | ||||
| - Fixed messages in DisplayTimerConflict | ||||
|   | ||||
| @@ -130,9 +130,11 @@ int cChannelEpg::getY() { | ||||
|     return geoManager.statusHeaderHeight +  geoManager.timeLineHeight + num*geoManager.rowHeight; | ||||
| } | ||||
|  | ||||
| cGridElement *cChannelEpg::getActive() { | ||||
| cGridElement *cChannelEpg::getActive(bool last) { | ||||
|     cTimeManager t; | ||||
|     t.Now(); | ||||
|     if (last) | ||||
|         return grids.Last(); | ||||
|     for (cGridElement *grid = grids.First(); grid; grid = grids.Next(grid)) { | ||||
|         if (grid->Match(t.Get())) | ||||
|             return grid; | ||||
|   | ||||
| @@ -42,7 +42,7 @@ public: | ||||
|     int Stop()  { return timeManager->GetEnd(); }; | ||||
|     const char* Name() { return channel->Name(); }; | ||||
|     const cChannel *getChannel() {return channel;} | ||||
|     cGridElement *getActive(); | ||||
|     cGridElement *getActive(bool last = false); | ||||
|     cGridElement *getNext(cGridElement *activeGrid); | ||||
|     cGridElement *getPrev(cGridElement *activeGrid); | ||||
|     cGridElement *getNeighbor(cGridElement *activeGrid); | ||||
|   | ||||
							
								
								
									
										12
									
								
								config.c
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								config.c
									
									
									
									
									
								
							| @@ -2,6 +2,7 @@ | ||||
| #include "config.h" | ||||
|  | ||||
| cTVGuideConfig::cTVGuideConfig() { | ||||
|     useHWAccel = false; | ||||
|     debugImageLoading = 0; | ||||
|     showMainMenuEntry = 1; | ||||
|     replaceOriginalSchedule = 0; | ||||
| @@ -9,8 +10,8 @@ cTVGuideConfig::cTVGuideConfig() { | ||||
|     showTimeInGrid = 1; | ||||
|     channelCols = 5; | ||||
|     channelRows = 10; | ||||
|     displayTime = 160; | ||||
|     displayHorizontalTime = 160; | ||||
|     displayTime = 180; | ||||
|     displayHorizontalTime = 180; | ||||
|     displayStatusHeader = 1; | ||||
|     displayChannelGroups = 1; | ||||
|     displayTimeBase = 1; | ||||
| @@ -27,10 +28,13 @@ cTVGuideConfig::cTVGuideConfig() { | ||||
|     footerHeightPercent = 7; | ||||
|     stepMinutes = 30; | ||||
|     bigStepHours = 3; | ||||
|     bigStepHoursHorizontal = 3; | ||||
|     hugeStepHours = 24; | ||||
|     hugeStepHoursHorizontal = 24; | ||||
|     channelJumpMode = eNumJump; | ||||
|     jumpChannels = 0; | ||||
|     blueKeyMode = 2; | ||||
|     addSubtitleToTimer = 1; | ||||
|     closeOnSwitch = 1; | ||||
|     numkeyMode = 0; | ||||
|     useRemoteTimers = 0; | ||||
| @@ -243,6 +247,7 @@ cString cTVGuideConfig::checkSlashAtEnd(std::string path) { | ||||
| bool cTVGuideConfig::SetupParse(const char *Name, const char *Value) { | ||||
|     if      (strcmp(Name, "timeFormat") == 0)               timeFormat = atoi(Value); | ||||
|     else if (strcmp(Name, "debugImageLoading") == 0)        debugImageLoading = atoi(Value); | ||||
|     else if (strcmp(Name, "useHWAccel") == 0)               useHWAccel = atoi(Value); | ||||
|     else if (strcmp(Name, "showMainMenuEntry") == 0)        showMainMenuEntry = atoi(Value); | ||||
|     else if (strcmp(Name, "replaceOriginalSchedule") == 0)  replaceOriginalSchedule = atoi(Value); | ||||
|     else if (strcmp(Name, "useNopacityTheme") == 0)         useNopacityTheme = atoi(Value);    | ||||
| @@ -267,7 +272,9 @@ bool cTVGuideConfig::SetupParse(const char *Name, const char *Value) { | ||||
|     else if (strcmp(Name, "logoWidthRatio") == 0)           logoWidthRatio = atoi(Value); | ||||
|     else if (strcmp(Name, "logoHeightRatio") == 0)          logoHeightRatio = atoi(Value); | ||||
|     else if (strcmp(Name, "bigStepHours") == 0)             bigStepHours = atoi(Value); | ||||
|     else if (strcmp(Name, "bigStepHoursHorizontal") == 0)   bigStepHoursHorizontal = atoi(Value); | ||||
|     else if (strcmp(Name, "hugeStepHours") == 0)            hugeStepHours = atoi(Value); | ||||
|     else if (strcmp(Name, "hugeStepHoursHorizontal") == 0)  hugeStepHoursHorizontal = atoi(Value); | ||||
|     else if (strcmp(Name, "channelJumpMode") == 0)          channelJumpMode = atoi(Value); | ||||
|     else if (strcmp(Name, "blueKeyMode") == 0)              blueKeyMode = atoi(Value); | ||||
|     else if (strcmp(Name, "numkeyMode") == 0)               numkeyMode = atoi(Value); | ||||
| @@ -289,6 +296,7 @@ bool cTVGuideConfig::SetupParse(const char *Name, const char *Value) { | ||||
|     else if (strcmp(Name, "footerHeightPercent") == 0)      footerHeightPercent = atoi(Value); | ||||
|     else if (strcmp(Name, "instRecFolderMode") == 0)        instRecFolderMode = atoi(Value); | ||||
|     else if (strcmp(Name, "instRecFixedFolder") == 0)       instRecFixedFolder = Value; | ||||
|     else if (strcmp(Name, "addSubtitleToTimer") == 0)       addSubtitleToTimer = atoi(Value); | ||||
|     else if (strcmp(Name, "favWhatsOnNow") == 0)            favWhatsOnNow = atoi(Value); | ||||
|     else if (strcmp(Name, "favWhatsOnNext") == 0)           favWhatsOnNext = atoi(Value); | ||||
|     else if (strcmp(Name, "favUseTime1") == 0)              favUseTime1 = atoi(Value); | ||||
|   | ||||
							
								
								
									
										12
									
								
								config.h
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								config.h
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ | ||||
| #include "fontmanager.h" | ||||
| #include "imagecache.h" | ||||
|  | ||||
| enum { | ||||
| enum eTimeFormat { | ||||
|     e12Hours, | ||||
|     e24Hours | ||||
| }; | ||||
| @@ -43,12 +43,19 @@ enum eInstRecFolderMode { | ||||
|     eFolderFixed | ||||
| }; | ||||
|  | ||||
| typedef enum { | ||||
|     addSubtitleNever = 0, | ||||
|     addSubtitleSmart, | ||||
|     addSubtitleAlways | ||||
| } addSubtitleToTimerMode; | ||||
|  | ||||
| class cTVGuideConfig { | ||||
|     private: | ||||
|         cString checkSlashAtEnd(std::string path); | ||||
|     public: | ||||
|         cTVGuideConfig(); | ||||
|         ~cTVGuideConfig(); | ||||
|         int useHWAccel; | ||||
|         int debugImageLoading; | ||||
|         int showMainMenuEntry; | ||||
|         int replaceOriginalSchedule; | ||||
| @@ -75,10 +82,13 @@ class cTVGuideConfig { | ||||
|         int footerHeightPercent; | ||||
|         int stepMinutes; | ||||
|         int bigStepHours; | ||||
|         int bigStepHoursHorizontal; | ||||
|         int hugeStepHours; | ||||
|         int hugeStepHoursHorizontal; | ||||
|         int channelJumpMode; | ||||
|         int jumpChannels; | ||||
|         int blueKeyMode; | ||||
|         int addSubtitleToTimer; | ||||
|         int closeOnSwitch; | ||||
|         int numkeyMode; | ||||
|         int useRemoteTimers; | ||||
|   | ||||
							
								
								
									
										25
									
								
								epggrid.c
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								epggrid.c
									
									
									
									
									
								
							| @@ -131,12 +131,7 @@ void cEpgGrid::drawText() { | ||||
|             } | ||||
|         } | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         if (Width() / geoManager.minutePixel < 10) { | ||||
|             int titleY = (geoManager.rowHeight - fontManager.FontGridHorizontal->Height()) / 2; | ||||
|             pixmap->DrawText(cPoint(borderWidth - 2, titleY), "...", colorText, colorTextBack, fontManager.FontGridHorizontal); | ||||
|             return; | ||||
|         } | ||||
|         cString strTitle = CutText(event->Title(), viewportHeight, fontManager.FontGridHorizontal).c_str(); | ||||
|         cString strTitle = CutText(event->Title(), viewportHeight - borderWidth, fontManager.FontGridHorizontal).c_str(); | ||||
|         int titleY = 0; | ||||
|         if (config.showTimeInGrid) { // mit Zeitangabe im Grid | ||||
|             pixmap->DrawText(cPoint(borderWidth, borderWidth), *timeString, colorText, colorTextBack, fontManager.FontGridHorizontalSmall); | ||||
| @@ -174,13 +169,17 @@ void cEpgGrid::drawText() { | ||||
|  | ||||
| void cEpgGrid::drawIcon(cString iconText, tColor color) { | ||||
|  | ||||
|     const cFont *font = (config.displayMode == eVertical) | ||||
|                         ?fontManager.FontGrid | ||||
|                         :fontManager.FontGridHorizontalSmall; | ||||
|     int textWidth = font->Width(*iconText)+2*borderWidth; | ||||
|     int textHeight = font->Height()+10; | ||||
|     pixmap->DrawRectangle( cRect(Width() - textWidth - borderWidth, Height() - textHeight - borderWidth, textWidth, textHeight), color); | ||||
|     pixmap->DrawText(cPoint(Width() - textWidth, Height() - textHeight - borderWidth/2), *iconText, theme.Color(clrFont), color, font); | ||||
|     const cFont *font = (config.displayMode == eVertical) ? fontManager.FontGrid : fontManager.FontGridHorizontalSmall; | ||||
|     int textWidth = font->Width(*iconText) + 2 * borderWidth; | ||||
|     int textHeight = font->Height() + 10; | ||||
|     if ((config.displayMode == eHorizontal) && ((Width() - 2 * textWidth) < 0)) | ||||
|         pixmap->DrawEllipse( cRect(Width() - textHeight / 2 - borderWidth, Height() - textHeight - borderWidth, textHeight / 2, textHeight / 2), color); | ||||
|     else if ((config.displayMode == eVertical) && ((Height() - 2 * textHeight) < 0)) | ||||
|         pixmap->DrawEllipse( cRect(Width() - textHeight / 2 - borderWidth, borderWidth, textHeight / 2, textHeight / 2), color); | ||||
|     else { | ||||
|         pixmap->DrawEllipse( cRect(Width() - textWidth - borderWidth, Height() - textHeight - borderWidth, textWidth, textHeight), color); | ||||
|         pixmap->DrawText(cPoint(Width() - textWidth, Height() - textHeight - borderWidth / 2), *iconText, theme.Color(clrFont), clrTransparent, font); | ||||
|     } | ||||
| } | ||||
|  | ||||
| cString cEpgGrid::getTimeString(void) { | ||||
|   | ||||
| @@ -35,7 +35,7 @@ bool cGeometryManager::SetGeometry(int osdWidth, int osdHeight, bool force) { | ||||
|     if (config.displayMode == eVertical) { | ||||
|         colWidth = (osdWidth - timeLineWidth) / config.channelCols; | ||||
|         rowHeight = 0; | ||||
|         minutePixel = (osdHeight - statusHeaderHeight - channelGroupsHeight - channelHeaderHeight - footerHeight) / config.displayTime; | ||||
|         minutePixel = (double)(osdHeight - statusHeaderHeight - channelGroupsHeight - channelHeaderHeight - footerHeight) / (double)config.displayTime; | ||||
|         channelLogoWidth = colWidth; | ||||
|         channelLogoHeight = channelHeaderHeight; | ||||
|         logoWidth = channelLogoWidth / 2 - 15; | ||||
| @@ -49,7 +49,7 @@ bool cGeometryManager::SetGeometry(int osdWidth, int osdHeight, bool force) { | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         colWidth = 0; | ||||
|         rowHeight = (osdHeight - statusHeaderHeight - timeLineHeight - footerHeight) / config.channelRows; | ||||
|         minutePixel = (osdWidth - channelHeaderWidth - channelGroupsWidth) / config.displayHorizontalTime; | ||||
|         minutePixel = (double)(osdWidth - channelHeaderWidth - channelGroupsWidth) / (double)config.displayHorizontalTime; | ||||
|         channelLogoWidth = channelHeaderWidth; | ||||
|         channelLogoHeight = rowHeight; | ||||
|         logoWidth = channelLogoHeight * config.logoWidthRatio / config.logoHeightRatio; | ||||
|   | ||||
| @@ -24,7 +24,7 @@ public: | ||||
|     //Content | ||||
|     int colWidth; | ||||
|     int rowHeight; | ||||
|     int minutePixel; | ||||
|     double minutePixel; | ||||
|     int channelLogoWidth; | ||||
|     int channelLogoHeight; | ||||
|     //Timeline | ||||
|   | ||||
							
								
								
									
										35
									
								
								po/ca_ES.po
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								po/ca_ES.po
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: vdr-tvguide 0.0.1\n" | ||||
| "Report-Msgid-Bugs-To: <see README>\n" | ||||
| "POT-Creation-Date: 2019-04-22 14:34+0200\n" | ||||
| "POT-Creation-Date: 2020-02-17 14:30+0100\n" | ||||
| "PO-Revision-Date: 2013-09-21 17:49+0200\n" | ||||
| "Last-Translator: My friend <Sampep> Thanks David <Gabychan> <gbonich@gmail.com>\n" | ||||
| "Language-Team: \n" | ||||
| @@ -57,6 +57,9 @@ msgstr "" | ||||
| msgid "images" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "tvguide: RemoteTimerModifications failed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "root video folder" | ||||
| msgstr "Directori principal per a vídeo" | ||||
|  | ||||
| @@ -99,12 +102,6 @@ msgstr "" | ||||
| msgid "recordings done" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Instant Record" | ||||
| msgstr "Enregistra a l'instant" | ||||
|  | ||||
| @@ -144,6 +141,9 @@ msgstr "Cerca a les gravacions" | ||||
| msgid "Set Folder for" | ||||
| msgstr "Programa carpeta per" | ||||
|  | ||||
| msgid "Timer changed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Timer created" | ||||
| msgstr "Temporitzador creat" | ||||
|  | ||||
| @@ -567,6 +567,12 @@ msgstr "No s'han trobat gravacions per" | ||||
| msgid "No Favorites available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "whole term must appear" | ||||
| msgstr "expressió completa" | ||||
|  | ||||
| @@ -675,6 +681,9 @@ msgstr "si existeix" | ||||
| msgid "always" | ||||
| msgstr "sempre" | ||||
|  | ||||
| msgid "Use workaround for HWAccelerated OSD" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show Main Menu Entry" | ||||
| msgstr "Mostra entrada del menú principal" | ||||
|  | ||||
| @@ -882,15 +891,27 @@ msgstr "" | ||||
| msgid "Use fixed folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "smart" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Instant recording:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder for instant Recordings" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Add episode to manual timers" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use Remotetimers" | ||||
| msgstr "Utilitza temporitzadors remots" | ||||
|  | ||||
| msgid "Favorites:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Limit channels in favorites" | ||||
| msgstr "" | ||||
|  | ||||
|   | ||||
							
								
								
									
										35
									
								
								po/de_DE.po
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								po/de_DE.po
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: vdr-tvguide 0.0.1\n" | ||||
| "Report-Msgid-Bugs-To: <see README>\n" | ||||
| "POT-Creation-Date: 2019-04-22 14:34+0200\n" | ||||
| "POT-Creation-Date: 2020-02-17 14:30+0100\n" | ||||
| "PO-Revision-Date: 2012-08-25 17:49+0200\n" | ||||
| "Last-Translator: Horst\n" | ||||
| "Language-Team: \n" | ||||
| @@ -54,6 +54,9 @@ msgstr "Favoriten" | ||||
| msgid "images" | ||||
| msgstr "Bilder" | ||||
|  | ||||
| msgid "tvguide: RemoteTimerModifications failed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "root video folder" | ||||
| msgstr "Video Hauptverzeichnis" | ||||
|  | ||||
| @@ -96,12 +99,6 @@ msgstr "aktive Timer" | ||||
| msgid "recordings done" | ||||
| msgstr "erledigte Aufnahmen" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "Was läuft jetzt?" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "Was läuft als nächstes?" | ||||
|  | ||||
| msgid "Instant Record" | ||||
| msgstr "Aufnahme" | ||||
|  | ||||
| @@ -141,6 +138,9 @@ msgstr "In Aufnahmen suchen" | ||||
| msgid "Set Folder for" | ||||
| msgstr "Verzeichnis festlegen für" | ||||
|  | ||||
| msgid "Timer changed" | ||||
| msgstr "Timer geändert" | ||||
|  | ||||
| msgid "Timer created" | ||||
| msgstr "Timer angelegt" | ||||
|  | ||||
| @@ -564,6 +564,12 @@ msgstr "Keine Aufnahmen gefunden für" | ||||
| msgid "No Favorites available" | ||||
| msgstr "Keine Favoriten verfügbar" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "Was läuft jetzt?" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "Was läuft als nächstes?" | ||||
|  | ||||
| msgid "whole term must appear" | ||||
| msgstr "vollständiger Ausdruck" | ||||
|  | ||||
| @@ -672,6 +678,9 @@ msgstr "falls vorhanden" | ||||
| msgid "always" | ||||
| msgstr "immer" | ||||
|  | ||||
| msgid "Use workaround for HWAccelerated OSD" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show Main Menu Entry" | ||||
| msgstr "Hauptmenüeintrag anzeigen" | ||||
|  | ||||
| @@ -879,15 +888,27 @@ msgstr "Verzeichnis aus Liste auswählen" | ||||
| msgid "Use fixed folder" | ||||
| msgstr "Festes Verzeichnis benutzen" | ||||
|  | ||||
| msgid "smart" | ||||
| msgstr "intelligent" | ||||
|  | ||||
| msgid "Instant recording:" | ||||
| msgstr "Sofortaufnahmen:" | ||||
|  | ||||
| msgid "Folder for instant Recordings" | ||||
| msgstr "Verzeichnis für Sofortaufnahmen" | ||||
|  | ||||
| msgid "Folder" | ||||
| msgstr "Verzeichnis" | ||||
|  | ||||
| msgid "Add episode to manual timers" | ||||
| msgstr "Untertitel in manuellen Timern" | ||||
|  | ||||
| msgid "Use Remotetimers" | ||||
| msgstr "RemoteTimers benutzen" | ||||
|  | ||||
| msgid "Favorites:" | ||||
| msgstr "Favoriten:" | ||||
|  | ||||
| msgid "Limit channels in favorites" | ||||
| msgstr "Kanäle in Favoriten beschränken" | ||||
|  | ||||
|   | ||||
							
								
								
									
										35
									
								
								po/it_IT.po
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								po/it_IT.po
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: vdr-tvguide 0.0.1\n" | ||||
| "Report-Msgid-Bugs-To: <see README>\n" | ||||
| "POT-Creation-Date: 2019-04-22 14:34+0200\n" | ||||
| "POT-Creation-Date: 2020-02-17 14:30+0100\n" | ||||
| "PO-Revision-Date: 2012-08-25 17:49+0200\n" | ||||
| "Last-Translator: fiveten_59\n" | ||||
| "Language-Team: \n" | ||||
| @@ -54,6 +54,9 @@ msgstr "Favoriti" | ||||
| msgid "images" | ||||
| msgstr "Immagini" | ||||
|  | ||||
| msgid "tvguide: RemoteTimerModifications failed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "root video folder" | ||||
| msgstr "cartella video di root" | ||||
|  | ||||
| @@ -96,12 +99,6 @@ msgstr "Timers attivi" | ||||
| msgid "recordings done" | ||||
| msgstr "registrazione eseguita" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "Was läuft jetzt?" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "Was läuft als nächstes?" | ||||
|  | ||||
| msgid "Instant Record" | ||||
| msgstr "Registrazione immediata" | ||||
|  | ||||
| @@ -141,6 +138,9 @@ msgstr "Cerca nelle registrazioni" | ||||
| msgid "Set Folder for" | ||||
| msgstr "Crea cartella per" | ||||
|  | ||||
| msgid "Timer changed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Timer created" | ||||
| msgstr "Timer creato" | ||||
|  | ||||
| @@ -564,6 +564,12 @@ msgstr "Nessuna registrazione trovata per" | ||||
| msgid "No Favorites available" | ||||
| msgstr "Nessun Favoriti disponibile" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "Was läuft jetzt?" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "Was läuft als nächstes?" | ||||
|  | ||||
| msgid "whole term must appear" | ||||
| msgstr "vollständiger Ausdruck" | ||||
|  | ||||
| @@ -672,6 +678,9 @@ msgstr "se esiste" | ||||
| msgid "always" | ||||
| msgstr "sempre" | ||||
|  | ||||
| msgid "Use workaround for HWAccelerated OSD" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show Main Menu Entry" | ||||
| msgstr "Hauptmenüeintrag anzeigen" | ||||
|  | ||||
| @@ -879,15 +888,27 @@ msgstr "Scegli dall'elenco cartelle" | ||||
| msgid "Use fixed folder" | ||||
| msgstr "Usa cartella fissa" | ||||
|  | ||||
| msgid "smart" | ||||
| msgstr "intelligente" | ||||
|  | ||||
| msgid "Instant recording:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder for instant Recordings" | ||||
| msgstr "Cartella per la registrazione immediata" | ||||
|  | ||||
| msgid "Folder" | ||||
| msgstr "Cartella" | ||||
|  | ||||
| msgid "Add episode to manual timers" | ||||
| msgstr "Aggiungi episodi ai timer manuali" | ||||
|  | ||||
| msgid "Use Remotetimers" | ||||
| msgstr "Usa Remotetimers" | ||||
|  | ||||
| msgid "Favorites:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Limit channels in favorites" | ||||
| msgstr "Limite dei canali nei favoriti" | ||||
|  | ||||
|   | ||||
							
								
								
									
										35
									
								
								po/ru_RU.po
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								po/ru_RU.po
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: vdr-tvguide 1.0.0\n" | ||||
| "Report-Msgid-Bugs-To: <see README>\n" | ||||
| "POT-Creation-Date: 2019-04-22 14:34+0200\n" | ||||
| "POT-Creation-Date: 2020-02-17 14:30+0100\n" | ||||
| "PO-Revision-Date: 2013-09-25 17:49+0400\n" | ||||
| "Last-Translator: AmiD, ilya\n" | ||||
| "Language-Team: Russia-Cherepovets(wm.amid@gmail.com)\n" | ||||
| @@ -54,6 +54,9 @@ msgstr "" | ||||
| msgid "images" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "tvguide: RemoteTimerModifications failed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "root video folder" | ||||
| msgstr "Главная видео директория" | ||||
|  | ||||
| @@ -96,12 +99,6 @@ msgstr "" | ||||
| msgid "recordings done" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Instant Record" | ||||
| msgstr "Записать" | ||||
|  | ||||
| @@ -141,6 +138,9 @@ msgstr "Искать в записях" | ||||
| msgid "Set Folder for" | ||||
| msgstr "Укажите каталог для" | ||||
|  | ||||
| msgid "Timer changed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Timer created" | ||||
| msgstr "Таймер создан" | ||||
|  | ||||
| @@ -564,6 +564,12 @@ msgstr "Не найдено записей:" | ||||
| msgid "No Favorites available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "whole term must appear" | ||||
| msgstr "фраза" | ||||
|  | ||||
| @@ -672,6 +678,9 @@ msgstr "если существует" | ||||
| msgid "always" | ||||
| msgstr "всегда" | ||||
|  | ||||
| msgid "Use workaround for HWAccelerated OSD" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show Main Menu Entry" | ||||
| msgstr "Показывать пункт в главном меню" | ||||
|  | ||||
| @@ -879,15 +888,27 @@ msgstr "" | ||||
| msgid "Use fixed folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "smart" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Instant recording:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder for instant Recordings" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Add episode to manual timers" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Use Remotetimers" | ||||
| msgstr "RemoteTimers benutzen" | ||||
|  | ||||
| msgid "Favorites:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Limit channels in favorites" | ||||
| msgstr "" | ||||
|  | ||||
|   | ||||
							
								
								
									
										35
									
								
								po/sk_SK.po
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								po/sk_SK.po
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: vdr-tvguide 1.1.0\n" | ||||
| "Report-Msgid-Bugs-To: <see README>\n" | ||||
| "POT-Creation-Date: 2019-04-22 14:34+0200\n" | ||||
| "POT-Creation-Date: 2020-02-17 14:30+0100\n" | ||||
| "PO-Revision-Date: 2013-09-15 00:12+0100\n" | ||||
| "Last-Translator: Milan Hrala <hrala.milan@gmail.com>\n" | ||||
| "Language-Team: \n" | ||||
| @@ -54,6 +54,9 @@ msgstr "" | ||||
| msgid "images" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "tvguide: RemoteTimerModifications failed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "root video folder" | ||||
| msgstr "Hlavn<76> video adres<65>r" | ||||
|  | ||||
| @@ -96,12 +99,6 @@ msgstr "" | ||||
| msgid "recordings done" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Instant Record" | ||||
| msgstr "Okam<61>ite nahra<72>" | ||||
|  | ||||
| @@ -141,6 +138,9 @@ msgstr "Vyh | ||||
| msgid "Set Folder for" | ||||
| msgstr "Nastavi<76> adres<65>r pre" | ||||
|  | ||||
| msgid "Timer changed" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Timer created" | ||||
| msgstr "Pl<50>n vytvoren<65>" | ||||
|  | ||||
| @@ -564,6 +564,12 @@ msgstr "Nena | ||||
| msgid "No Favorites available" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on now" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "What's on next" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "whole term must appear" | ||||
| msgstr "kompletn<74> v<>raz" | ||||
|  | ||||
| @@ -672,6 +678,9 @@ msgstr "ak s | ||||
| msgid "always" | ||||
| msgstr "v<>dy" | ||||
|  | ||||
| msgid "Use workaround for HWAccelerated OSD" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Show Main Menu Entry" | ||||
| msgstr "Zobrazi<7A> v hlavnom menu" | ||||
|  | ||||
| @@ -879,15 +888,27 @@ msgstr "" | ||||
| msgid "Use fixed folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "smart" | ||||
| msgstr "chytr<74>" | ||||
|  | ||||
| msgid "Instant recording:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder for instant Recordings" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Folder" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Add episode to manual timers" | ||||
| msgstr "Prida<64> epiz<69>dy do ru<72>n<EFBFBD>ho <20>asova<76>a" | ||||
|  | ||||
| msgid "Use Remotetimers" | ||||
| msgstr "Pou<6F>i<EFBFBD> vzdialen<65> pl<70>nova<76>" | ||||
|  | ||||
| msgid "Favorites:" | ||||
| msgstr "" | ||||
|  | ||||
| msgid "Limit channels in favorites" | ||||
| msgstr "" | ||||
|  | ||||
|   | ||||
							
								
								
									
										98
									
								
								recmanager.c
									
									
									
									
									
								
							
							
						
						
									
										98
									
								
								recmanager.c
									
									
									
									
									
								
							| @@ -96,10 +96,11 @@ cTimer *cRecManager::createTimer(const cEvent *event, std::string path) { | ||||
| cTimer *cRecManager::createLocalTimer(const cEvent *event, std::string path) { | ||||
|     cTimer *timer = new cTimer(event); | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     if (Setup.SVDRPPeering && *Setup.SVDRPDefaultHost) | ||||
|         ((cTimer*)timer)->SetRemote(Setup.SVDRPDefaultHost); | ||||
|     LOCK_TIMERS_WRITE; | ||||
|     cTimers* timers = Timers; | ||||
|     timers->SetExplicitModify(); | ||||
|     if (Setup.SVDRPPeering && *Setup.SVDRPDefaultHost) | ||||
|         timer->SetRemote(Setup.SVDRPDefaultHost); | ||||
| #else | ||||
|     cTimers* timers = &Timers; | ||||
| #endif | ||||
| @@ -115,12 +116,21 @@ cTimer *cRecManager::createLocalTimer(const cEvent *event, std::string path) { | ||||
|         timer = t; | ||||
|         isyslog("timer %s reactivated", *t->ToDescr()); | ||||
|     } else { | ||||
|         SetTimerPath(timer, event, path); | ||||
|         timers->Add(timer); | ||||
|         timers->SetModified(); | ||||
| #if VDRVERSNUM >= 20301 | ||||
|         if (!HandleRemoteTimerModifications(timer)) { | ||||
|            timers->Del(timer); | ||||
|            esyslog(tr("tvguide: RemoteTimerModifications failed")); | ||||
|         } else { | ||||
|            isyslog("timer %s added (active)", *timer->ToDescr()); | ||||
|         } | ||||
|     SetTimerPath(timer, event, path); | ||||
|     timers->SetModified(); | ||||
|     return timer; | ||||
| #else | ||||
|         isyslog("timer %s added (active)", *timer->ToDescr()); | ||||
| #endif | ||||
|     } | ||||
|     return timers->GetTimer(timer); | ||||
| } | ||||
|  | ||||
| cTimer *cRecManager::createRemoteTimer(const cEvent *event, std::string path) { | ||||
| @@ -165,31 +175,29 @@ void cRecManager::SetTimerPath(cTimer *timer, const cEvent *event, std::string p | ||||
|         return; | ||||
|     } | ||||
|     //Set choosen path | ||||
|     bool addSubtitle = false; | ||||
|     if (!isempty(event->ShortText())) { // add subtitle if present | ||||
|         addSubtitle = (config.addSubtitleToTimer != addSubtitleNever); | ||||
|         if (config.addSubtitleToTimer == addSubtitleSmart) | ||||
|             if (event->Duration() > 80 * 60) | ||||
|                 addSubtitle = false; | ||||
|     } | ||||
|     cString newFileName; | ||||
|     if (path.size() > 0) { | ||||
|         std::replace(path.begin(), path.end(), '/', '~'); | ||||
|         if (addSubtitle) | ||||
|            newFileName = cString::sprintf("%s~%s~%s", path.c_str(), event->Title(), event->ShortText()); | ||||
|         else | ||||
|            newFileName = cString::sprintf("%s~%s", path.c_str(), timer->File()); | ||||
|     } else { | ||||
|         if (addSubtitle) | ||||
|            newFileName = cString::sprintf("%s~%s", event->Title(), event->ShortText()); | ||||
|         else | ||||
|            newFileName = event->Title(); | ||||
|     } | ||||
|     timer->SetFile(*newFileName); | ||||
| } | ||||
|  | ||||
| void cRecManager::DeleteTimer(int timerID) { | ||||
|     const cTimer *t; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     { | ||||
|     LOCK_TIMERS_READ; | ||||
|     t = Timers->Get(timerID); | ||||
|     } | ||||
| #else | ||||
|     t = Timers.Get(timerID); | ||||
| #endif | ||||
|     if (!t) | ||||
|         return; | ||||
|     DeleteTimer(t); | ||||
| } | ||||
|  | ||||
| void cRecManager::DeleteTimer(const cEvent *event) { | ||||
|     if (!event) | ||||
|         return; | ||||
| @@ -219,6 +227,12 @@ void cRecManager::DeleteTimer(const cTimer *timer) { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     LOCK_TIMERS_WRITE; | ||||
|     cTimers* timers = Timers; | ||||
|     if (timer && timer->Remote() && !timer->Recording()) { | ||||
|        if (HandleRemoteTimerModifications(NULL, (cTimer*)timer)) { | ||||
|           timers->Del((cTimer*)timer); | ||||
|        } | ||||
|        timers->SetModified(); | ||||
|     } | ||||
|     cTimer* t = timers->GetTimer(timer); | ||||
| #else | ||||
|     cTimers* timers = &Timers; | ||||
| @@ -253,24 +267,34 @@ void cRecManager::DeleteRemoteTimer(const cEvent *event) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cRecManager::SaveTimer(const cTimer *t, cTimer newTimerSettings) { | ||||
| void cRecManager::SaveTimer(const cTimer *t, cTimer *newTimerSettings) { | ||||
|     if (!t) | ||||
|         return; | ||||
|  | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     LOCK_TIMERS_WRITE; | ||||
|     cTimer *timer = Timers->GetTimer(t); | ||||
|     cTimers* timers = Timers; | ||||
|     timers->SetExplicitModify(); | ||||
|     if (t && t->Remote()) { | ||||
|        if (!HandleRemoteTimerModifications(newTimerSettings, (cTimer *)t)) { | ||||
|           esyslog(tr("tvguide: RemoteTimerModifications failed")); | ||||
|        } | ||||
|     } | ||||
|     cTimer *timer = timers->GetTimer(t); | ||||
| #else | ||||
|     cTimer *timer = Timers.GetTimer((cTimer*)t); | ||||
|     cTimers* timers = &Timers; | ||||
|     cTimer *timer = timers->GetTimer((cTimer *)t); | ||||
| #endif | ||||
|  | ||||
|     bool active = newTimerSettings.HasFlags(tfActive); | ||||
|     int prio = newTimerSettings.Priority(); | ||||
|     int lifetime = newTimerSettings.Lifetime(); | ||||
|     time_t day = newTimerSettings.Day(); | ||||
|     int start = newTimerSettings.Start(); | ||||
|     int stop = newTimerSettings.Stop(); | ||||
|     std::string fileName = newTimerSettings.File(); | ||||
|     if (!timer) { | ||||
|        return; | ||||
|     } | ||||
|     bool active = newTimerSettings->HasFlags(tfActive); | ||||
|     int prio = newTimerSettings->Priority(); | ||||
|     int lifetime = newTimerSettings->Lifetime(); | ||||
|     time_t day = newTimerSettings->Day(); | ||||
|     int start = newTimerSettings->Start(); | ||||
|     int stop = newTimerSettings->Stop(); | ||||
|     std::string fileName = newTimerSettings->File(); | ||||
|  | ||||
|     timer->SetDay(day); | ||||
|     timer->SetStart(start); | ||||
| @@ -279,10 +303,10 @@ void cRecManager::SaveTimer(const cTimer *t, cTimer newTimerSettings) { | ||||
|     timer->SetLifetime(lifetime); | ||||
|     timer->SetFile(fileName.c_str()); | ||||
|  | ||||
|     if (timer->HasFlags(tfActive) && !active) | ||||
|         timer->ClrFlags(tfActive); | ||||
|     else if (!timer->HasFlags(tfActive) && active) | ||||
|     if (active) | ||||
|        timer->SetFlags(tfActive); | ||||
|     else | ||||
|        timer->ClrFlags(tfActive); | ||||
|  | ||||
| #if VDRVERSNUM < 20300 | ||||
|     timer->SetEventFromSchedule(); | ||||
| @@ -294,11 +318,7 @@ void cRecManager::SaveTimer(const cTimer *t, cTimer newTimerSettings) { | ||||
|             rt.timer = NULL; | ||||
|         RefreshRemoteTimers(); | ||||
|     } else { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|         Timers->SetModified(); | ||||
| #else | ||||
|         Timers.SetModified(); | ||||
| #endif | ||||
|         timers->SetModified(); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -34,11 +34,10 @@ public: | ||||
|     cTimer *createRemoteTimer(const cEvent *event, std::string path); | ||||
|     void SetTimerPath(cTimer *timer, const cEvent *event, std::string path); | ||||
|     void DeleteTimer(const cTimer *timer); | ||||
|     void DeleteTimer(int timerID); | ||||
|     void DeleteTimer(const cEvent *event); | ||||
|     void DeleteLocalTimer(const cEvent *event); | ||||
|     void DeleteRemoteTimer(const cEvent *event); | ||||
|     void SaveTimer(const cTimer *timer, cTimer newTimerSettings); | ||||
|     void SaveTimer(const cTimer *timer, cTimer *newTimerSettings); | ||||
|     bool IsRecorded(const cEvent *event); | ||||
|     cTVGuideTimerConflicts *CheckTimerConflict(void); | ||||
|     void CreateSeriesTimer(cTimer *seriesTimer); | ||||
|   | ||||
| @@ -441,7 +441,7 @@ void cRecMenu::JumpBegin(void) { | ||||
|             CreatePixmap(); | ||||
|         Arrange(false); | ||||
|         startIndex = 0; | ||||
|         stopIndex = numItems - 1; | ||||
|         stopIndex = currentItem; | ||||
|         cRecMenuItem *first = menuItems.front(); | ||||
|         first->setActive(); | ||||
|         first->setBackground(); | ||||
| @@ -589,10 +589,14 @@ void cRecMenu::UpdateActiveMenuItem(void) { | ||||
|  | ||||
|  | ||||
| void cRecMenu::DrawScrollBar(void) { | ||||
|     if (!pixmapScrollBar) | ||||
|        return; | ||||
|     pixmapScrollBar->Fill(theme.Color(clrBorder)); | ||||
|     pixmapScrollBar->DrawRectangle(cRect(2,2,pixmapScrollBar->ViewPort().Width()-4, pixmapScrollBar->ViewPort().Height() - 4), theme.Color(clrBackground)); | ||||
|      | ||||
|     int totalNumItems = GetTotalNumMenuItems(); | ||||
|     if (!totalNumItems) | ||||
|        return; | ||||
|     if (imgScrollBar == NULL) { | ||||
|         int scrollBarImgHeight = (pixmapScrollBar->ViewPort().Height() - 8) * numItems / totalNumItems; | ||||
|         imgScrollBar = createScrollbar(pixmapScrollBar->ViewPort().Width()-8, scrollBarImgHeight, theme.Color(clrHighlight), theme.Color(clrHighlightBlending)); | ||||
|   | ||||
| @@ -1548,6 +1548,7 @@ cRecMenuItemTimer::cRecMenuItemTimer(const cTimer *timer, | ||||
|     this->overlapStop = overlapStop; | ||||
|     this->active = active; | ||||
|     height = 3 * font->Height(); | ||||
|     pixmapStatus = NULL; | ||||
|     pixmapIcons = NULL; | ||||
| } | ||||
|  | ||||
| @@ -1585,6 +1586,8 @@ void cRecMenuItemTimer::Show(void) { | ||||
| } | ||||
|  | ||||
| void cRecMenuItemTimer::Draw(void) { | ||||
|     if (!timer) | ||||
|        return; | ||||
|     const cChannel *channel = timer->Channel(); | ||||
|     int channelTransponder = 0; | ||||
|     cString channelName = ""; | ||||
| @@ -1740,8 +1743,13 @@ cRecMenuItemTimerConflictHeader::~cRecMenuItemTimerConflictHeader(void) { | ||||
| } | ||||
|  | ||||
| void cRecMenuItemTimerConflictHeader::SetPixmaps(void) { | ||||
|     if (!pixmap) { | ||||
|        pixmap = osdManager.requestPixmap(4, cRect(x, y, width, height)); | ||||
|        pixmapStatus = osdManager.requestPixmap(5, cRect(x, y, width, height)); | ||||
|     } else { | ||||
|        pixmap->SetViewPort(cRect(x, y, width, height)); | ||||
|        pixmapStatus->SetViewPort(cRect(x, y, width, height)); | ||||
|     } | ||||
|     pixmapStatus->Fill(clrTransparent); | ||||
| } | ||||
|  | ||||
| @@ -2304,13 +2312,14 @@ void cRecMenuItemRecording::Show(void) { | ||||
| } | ||||
|  | ||||
| // --- cRecMenuItemTimelineHeader  ------------------------------------------------------- | ||||
| cRecMenuItemTimelineHeader::cRecMenuItemTimelineHeader(time_t day, std::vector<cTVGuideTimerConflict*> conflictsToday) { | ||||
| cRecMenuItemTimelineHeader::cRecMenuItemTimelineHeader(time_t day, int numTimersToday, std::vector<cTVGuideTimerConflict*> conflictsToday) { | ||||
|     conflicts = conflictsToday; | ||||
|     pixmapTimeline = NULL; | ||||
|     pixmapTimerInfo = NULL; | ||||
|     pixmapTimerConflicts = NULL; | ||||
|     timer = NULL; | ||||
|     this->day = day; | ||||
|     this->numTimersToday = numTimersToday; | ||||
|     selectable = false; | ||||
|     active = false; | ||||
|     height = 5 * font->Height(); | ||||
| @@ -2359,7 +2368,7 @@ void cRecMenuItemTimelineHeader::Draw(void) { | ||||
|     } | ||||
|     DrawTimerConflicts(); | ||||
|     pixmap->Fill(clrTransparent); | ||||
|     cString headerText = tr("Timers for"); | ||||
|     cString headerText = cString::sprintf("%i %s", numTimersToday, tr("Timers for")); | ||||
|     cString dateText = DateString(day); | ||||
|     cString header = cString::sprintf("%s: %s", *headerText, *dateText); | ||||
|     int xText = (width - fontLarge->Width(*header)) / 2; | ||||
| @@ -2421,7 +2430,7 @@ void cRecMenuItemTimelineHeader::DrawTimeline(void) { | ||||
|     pixmapTimeline->Fill(clrTransparent); | ||||
|     width5Mins = (float)width * 5.0 / 24.0 / 60.0; | ||||
|     int widthHour = 12 * width5Mins; | ||||
|     x0 = (width - 24*widthHour)/2; | ||||
|     x0 = (width - (24 * widthHour)) / 2; | ||||
|     int barHeight = fontSmall->Height(); | ||||
|     int y = height - barHeight; | ||||
|     tColor col1 = theme.Color(clrTimeline1); | ||||
| @@ -2526,7 +2535,8 @@ void cRecMenuItemTimelineTimer::SetPixmaps(void) { | ||||
|              | ||||
|     } | ||||
|     width5Mins = (float)width * 5.0 / 24.0 / 60.0; | ||||
|     x0 = (width - 24*12*width5Mins)/2; | ||||
|     int widthHour = 12 * width5Mins; | ||||
|     x0 = (width - (24 * widthHour)) / 2; | ||||
| } | ||||
|  | ||||
| void cRecMenuItemTimelineTimer::Draw(void) { | ||||
|   | ||||
| @@ -573,19 +573,21 @@ private: | ||||
|     cPixmap *pixmapTimeline; | ||||
|     cPixmap *pixmapTimerInfo; | ||||
|     cPixmap *pixmapTimerConflicts; | ||||
|     int width5Mins; | ||||
|     float width5Mins; | ||||
|     int x0; | ||||
|     int numTimersToday; | ||||
|     bool timelineDrawn; | ||||
|     void DrawTimeline(void); | ||||
|     void DrawTimerConflicts(void); | ||||
|     void DrawCurrentTimer(void); | ||||
| public: | ||||
|     cRecMenuItemTimelineHeader(time_t day, std::vector<cTVGuideTimerConflict*> conflictsToday); | ||||
|     cRecMenuItemTimelineHeader(time_t day, int numTimersToday, std::vector<cTVGuideTimerConflict*> conflictsToday); | ||||
|     virtual ~cRecMenuItemTimelineHeader(void); | ||||
|     void SetDay(time_t day) { this->day = day; }; | ||||
|     void SetPixmaps(void); | ||||
|     void SetCurrentTimer(const cTimer *timer) { this->timer = timer; }; | ||||
|     void UnsetCurrentTimer(void) { timer = NULL; }; | ||||
|     void SetNumTimersToday(int numTimersToday) { this->numTimersToday = numTimersToday; }; | ||||
|     void RefreshTimerDisplay(void); | ||||
|     void Hide(void); | ||||
|     void Show(void);  | ||||
| @@ -601,7 +603,7 @@ private: | ||||
|     cPixmap *pixmapTimerConflicts; | ||||
|     cRecMenuItemTimelineHeader *header; | ||||
|     int x0; | ||||
|     int width5Mins; | ||||
|     float width5Mins; | ||||
|     time_t start; | ||||
|     time_t stop; | ||||
|     void DrawBackground(void); | ||||
|   | ||||
							
								
								
									
										86
									
								
								recmenus.c
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								recmenus.c
									
									
									
									
									
								
							| @@ -103,7 +103,7 @@ std::string cRecMenuAskFolder::GetFolder(void) { | ||||
| } | ||||
|  | ||||
| // --- cRecMenuConfirmTimer  --------------------------------------------------------- | ||||
| cRecMenuConfirmTimer::cRecMenuConfirmTimer(const cEvent *event) { | ||||
| cRecMenuConfirmTimer::cRecMenuConfirmTimer(const cEvent *event, bool timerChanged) { | ||||
|     SetWidthPercent(50); | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     LOCK_CHANNELS_READ; | ||||
| @@ -111,7 +111,6 @@ cRecMenuConfirmTimer::cRecMenuConfirmTimer(const cEvent *event) { | ||||
| #else | ||||
|     const cString channelName = Channels.GetByChannelID(event->ChannelID())->Name(); | ||||
| #endif | ||||
|     cString message; | ||||
|     bool eventHasTimer = false; | ||||
|     if (config.useRemoteTimers && pRemoteTimers) { | ||||
|         RemoteTimers_GetMatch_v1_0 rtMatch; | ||||
| @@ -123,11 +122,9 @@ cRecMenuConfirmTimer::cRecMenuConfirmTimer(const cEvent *event) { | ||||
|     } else { | ||||
|         eventHasTimer = event->HasTimer(); | ||||
|     } | ||||
|     if (eventHasTimer) { | ||||
|         message = tr("Timer created"); | ||||
|     } else { | ||||
|         message = tr("Timer NOT created"); | ||||
|     } | ||||
|     const cString message = (eventHasTimer) ? (timerChanged) ? tr("Timer changed") | ||||
|                                                              : tr("Timer created") | ||||
|                                             : tr("Timer NOT created"); | ||||
|     cString text = cString::sprintf("%s\n%s\n%s %s - %s\n%s",  | ||||
|                                     *message,  | ||||
|                                     *channelName, | ||||
| @@ -197,8 +194,9 @@ cRecMenuAskDeleteTimer::cRecMenuAskDeleteTimer(const cEvent *event) { | ||||
|  | ||||
| // --- cRecMenuTimerConflicts  --------------------------------------------------------- | ||||
| cRecMenuTimerConflicts::cRecMenuTimerConflicts(cTVGuideTimerConflicts *conflicts) { | ||||
|     int numConflicts = conflicts->NumConflicts(); | ||||
|     SetWidthPercent(50); | ||||
|  | ||||
|     int numConflicts = (conflicts) ? conflicts->NumConflicts() : 0; | ||||
|     cString text; | ||||
|     if (numConflicts == 1) { | ||||
|         text = cString::sprintf("%s %s %s", tr("One"), tr("Timer Conflict"), tr("detected")); | ||||
| @@ -233,19 +231,21 @@ int cRecMenuTimerConflicts::GetTimerConflict(void) { | ||||
| } | ||||
|  | ||||
| // --- cRecMenuTimerConflict  --------------------------------------------------------- | ||||
| cRecMenuTimerConflict::cRecMenuTimerConflict(cTVGuideTimerConflict *conflict) { | ||||
| cRecMenuTimerConflict::cRecMenuTimerConflict(cTVGuideTimerConflict *conflict, eRecMenuState nextAction) { | ||||
|     SetWidthPercent(95); | ||||
|     this->conflict = conflict; | ||||
|     totalNumMenuItems = (int)conflict->timerIDs.size(); | ||||
|  | ||||
|     SetHeader(new cRecMenuItemTimerConflictHeader(conflict->timeStart, | ||||
|                                                   conflict->timeStop, | ||||
|                                                   conflict->overlapStart, | ||||
|                                                   conflict->overlapStop)); | ||||
|     SetFooter(new cRecMenuItemButton(tr("Ignore Conflict"), rmsIgnoreTimerConflict, false, true)); | ||||
|     SetFooter(new cRecMenuItemButton(tr("Ignore Conflict"), nextAction, false, true)); | ||||
|     int i=0; | ||||
|     for(std::vector<int>::iterator it = conflict->timerIDs.begin(); it != conflict->timerIDs.end(); it++) { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|         LOCK_TIMERS_READ; | ||||
|         const cTimer *timer = Timers->Get(*it); | ||||
|         const cTimer *timer = Timers->GetById(*it + 1); | ||||
| #else | ||||
|         const cTimer *timer = Timers.Get(*it); | ||||
| #endif | ||||
| @@ -271,7 +271,7 @@ cRecMenuTimerConflict::cRecMenuTimerConflict(cTVGuideTimerConflict *conflict) { | ||||
| } | ||||
|      | ||||
| cRecMenuItem *cRecMenuTimerConflict::GetMenuItem(int number) {  | ||||
|     if ((number >= 0) && (number < (int)conflict->timerIDs.size())) { | ||||
|     if ((number >= 0) && (number < totalNumMenuItems)) { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|         LOCK_TIMERS_READ; | ||||
|         const cTimer *timer = Timers->Get(conflict->timerIDs[number]); | ||||
| @@ -294,7 +294,7 @@ cRecMenuItem *cRecMenuTimerConflict::GetMenuItem(int number) { | ||||
| } | ||||
|  | ||||
| int cRecMenuTimerConflict::GetTotalNumMenuItems(void) { | ||||
|     return conflict->timerIDs.size();  | ||||
|     return totalNumMenuItems;  | ||||
| } | ||||
|  | ||||
| int cRecMenuTimerConflict::GetTimerConflictIndex(void) { | ||||
| @@ -470,17 +470,17 @@ const cTimer *cRecMenuEditTimer::GetOriginalTimer(void) { | ||||
|     return originalTimer; | ||||
| } | ||||
|  | ||||
| cTimer cRecMenuEditTimer::GetTimer(void) { | ||||
|     cTimer t; | ||||
| cTimer *cRecMenuEditTimer::GetTimer(void) { | ||||
|     cTimer *t = (cTimer *)originalTimer; | ||||
|     if (timerActive) | ||||
|         t.SetFlags(tfActive); | ||||
|         t->SetFlags(tfActive); | ||||
|     else  | ||||
|         t.SetFlags(tfNone); | ||||
|     t.SetDay(day); | ||||
|     t.SetStart(start); | ||||
|     t.SetStop(stop); | ||||
|     t.SetPriority(prio); | ||||
|     t.SetLifetime(lifetime); | ||||
|         t->ClrFlags(tfActive); | ||||
|     t->SetDay(day); | ||||
|     t->SetStart(start); | ||||
|     t->SetStop(stop); | ||||
|     t->SetPriority(prio); | ||||
|     t->SetLifetime(lifetime); | ||||
|     std::string newFolder(folder); | ||||
|     std::string newFile = originalTimer->File(); | ||||
|     size_t found = newFile.find_last_of('~'); | ||||
| @@ -495,7 +495,7 @@ cTimer cRecMenuEditTimer::GetTimer(void) { | ||||
|             newFile = *cString::sprintf("%s~%s", newFolder.c_str(), newFile.c_str()); | ||||
|     } | ||||
|     std::replace(newFile.begin(), newFile.end(), '/', '~'); | ||||
|     t.SetFile(newFile.c_str()); | ||||
|     t->SetFile(newFile.c_str()); | ||||
|     return t; | ||||
| } | ||||
|  | ||||
| @@ -1413,8 +1413,8 @@ cRecMenuTimeline::cRecMenuTimeline(cTVGuideTimerConflicts *timerConflicts) { | ||||
|     SetStartStop(); | ||||
|     conflictsToday = timerConflicts->GetConflictsBetween(timeStart, timeStop); | ||||
|     GetTimersForDay(); | ||||
|     SetWidthPercent(95); | ||||
|     header = new cRecMenuItemTimelineHeader(timeStart, conflictsToday); | ||||
|     SetWidthPercent(90); | ||||
|     header = new cRecMenuItemTimelineHeader(timeStart, numTimersToday, conflictsToday); | ||||
|     SetHeader(header); | ||||
|     cRecMenuItem *footer = new cRecMenuItemButton(tr("Close"), rmsClose, false, true); | ||||
|     SetFooter(footer); | ||||
| @@ -1434,26 +1434,40 @@ void cRecMenuTimeline::GetTimersForDay(void) { | ||||
|     timersToday.clear(); | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     LOCK_TIMERS_READ; | ||||
| //    const cTimers* timers = Timers; | ||||
|     for (const cTimer *t = Timers->First(); t; t = Timers->Next(t)) { | ||||
|     const cTimers* timers = Timers; | ||||
|     cSortedTimers SortedTimers(timers); | ||||
|     int i = 0; | ||||
|     while (i < SortedTimers.Size()) { | ||||
|         const cTimer *t = SortedTimers[i]; | ||||
|         if (((t->StartTime() > timeStart) && (t->StartTime() <= timeStop)) || ((t->StopTime() > timeStart) && (t->StopTime() <= timeStop))) { | ||||
|             if (t->HasFlags(tfActive)) | ||||
|                 timersToday.push_back(t); | ||||
|         } | ||||
|         i++; | ||||
|     } | ||||
| #else | ||||
|     for (const cTimer *t = Timers.First(); t; t = Timers.Next(t)) { | ||||
| #endif | ||||
|         if (((t->StartTime() > timeStart) && (t->StartTime() <= timeStop)) || ((t->StopTime() > timeStart) && (t->StopTime() <= timeStop))) { | ||||
|             timersToday.push_back(t); | ||||
|         } | ||||
|     } | ||||
| #endif | ||||
|     numTimersToday = timersToday.size(); | ||||
| } | ||||
|  | ||||
| void cRecMenuTimeline::SetTimers(void) { | ||||
|     ClearMenu(); | ||||
|     GetTimersForDay(); | ||||
|     conflictsToday = timerConflicts->GetConflictsBetween(timeStart, timeStop); | ||||
|     header->UnsetCurrentTimer(); | ||||
|     header->SetDay(timeStart); | ||||
|     header->RefreshTimerDisplay(); | ||||
|     header->SetNumTimersToday(numTimersToday); | ||||
|     if (numTimersToday == 0) { | ||||
|         AddMenuItem(new cRecMenuItemTimelineTimer(NULL, 0, 0, conflictsToday, header, false)); | ||||
|         header->UnsetCurrentTimer(); | ||||
|         footer->setActive(); | ||||
|     } else { | ||||
|         for (int i=0; i<numTimersToday; i++) { | ||||
|         for (int i = 0; i<numTimersToday; i++) { | ||||
|             cRecMenuItemTimelineTimer *item = new cRecMenuItemTimelineTimer(timersToday[i], timeStart, timeStop, conflictsToday, header, false); | ||||
|             if (i==0) | ||||
|                 item->setActive(); | ||||
| @@ -1472,12 +1486,6 @@ void cRecMenuTimeline::PrevDay(void) { | ||||
|         return; | ||||
|     timeStart -= 3600*24; | ||||
|     timeStop -= 3600*24; | ||||
|     conflictsToday = timerConflicts->GetConflictsBetween(timeStart, timeStop); | ||||
|     SetWidthPercent(95); | ||||
|     header->SetDay(timeStart); | ||||
|     header->UnsetCurrentTimer(); | ||||
|     header->RefreshTimerDisplay(); | ||||
|     GetTimersForDay(); | ||||
|     SetTimers(); | ||||
|     Display(); | ||||
| } | ||||
| @@ -1485,12 +1493,6 @@ void cRecMenuTimeline::PrevDay(void) { | ||||
| void cRecMenuTimeline::NextDay(void) { | ||||
|     timeStart += 3600*24; | ||||
|     timeStop += 3600*24; | ||||
|     conflictsToday = timerConflicts->GetConflictsBetween(timeStart, timeStop); | ||||
|     SetWidthPercent(95); | ||||
|     header->SetDay(timeStart); | ||||
|     header->UnsetCurrentTimer(); | ||||
|     header->RefreshTimerDisplay(); | ||||
|     GetTimersForDay(); | ||||
|     SetTimers(); | ||||
|     Display(); | ||||
| } | ||||
|   | ||||
| @@ -47,7 +47,7 @@ public: | ||||
| // --- cRecMenuConfirmTimer  --------------------------------------------------------- | ||||
| class cRecMenuConfirmTimer: public cRecMenu { | ||||
| public: | ||||
|     cRecMenuConfirmTimer(const cEvent *event); | ||||
|     cRecMenuConfirmTimer(const cEvent *event, bool timerChanged = false); | ||||
|     virtual ~cRecMenuConfirmTimer(void) {}; | ||||
| }; | ||||
|  | ||||
| @@ -77,11 +77,12 @@ public: | ||||
| class cRecMenuTimerConflict: public cRecMenu { | ||||
| private: | ||||
|     cTVGuideTimerConflict *conflict; | ||||
|     int totalNumMenuItems; | ||||
| public: | ||||
|     cRecMenuTimerConflict(cTVGuideTimerConflict *conflict); | ||||
|     cRecMenuTimerConflict(cTVGuideTimerConflict *conflict, eRecMenuState nextAction = rmsClose); | ||||
|     virtual ~cRecMenuTimerConflict(void) {}; | ||||
|     cRecMenuItem *GetMenuItem(int number); | ||||
|     int GetTotalNumMenuItems(void); | ||||
|     virtual ~cRecMenuTimerConflict(void) {}; | ||||
|     int GetTimerConflictIndex(void); | ||||
| }; | ||||
|  | ||||
| @@ -136,7 +137,7 @@ public: | ||||
|     cRecMenuEditTimer(const cTimer *timer, eRecMenuState nextState); | ||||
|     const cTimer *GetOriginalTimer(void); | ||||
|     virtual ~cRecMenuEditTimer(void) {}; | ||||
|     cTimer GetTimer(void); | ||||
|     cTimer *GetTimer(void); | ||||
| }; | ||||
|  | ||||
| /****************************************************************************************** | ||||
|   | ||||
| @@ -93,16 +93,18 @@ void cRecMenuView::DisplaySearchTimerList(void) { | ||||
| } | ||||
|  | ||||
| bool cRecMenuView::DisplayTimerConflict(const cTimer *timer) { | ||||
|     int timerID = 0; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|     LOCK_TIMERS_READ; | ||||
|     for (const cTimer *t = Timers->First(); t; t = Timers->Next(t)) { | ||||
|         if (t == timer) | ||||
|             return DisplayTimerConflict(timer->Id() - 1); | ||||
| #else | ||||
|     int timerID = 0; | ||||
|     for (const cTimer *t = Timers.First(); t; t = Timers.Next(t)) { | ||||
| #endif | ||||
|         if (t == timer) | ||||
|             return DisplayTimerConflict(timerID); | ||||
|         timerID++; | ||||
| #endif | ||||
|     } | ||||
|     return false; | ||||
| } | ||||
| @@ -119,7 +121,7 @@ bool cRecMenuView::DisplayTimerConflict(int timerID) { | ||||
|         cTVGuideTimerConflict *conflict = timerConflicts->GetCurrentConflict(); | ||||
|         if (!conflict) | ||||
|             return false; | ||||
|         activeMenu = new cRecMenuTimerConflict(conflict); | ||||
|         activeMenu = new cRecMenuTimerConflict(conflict, rmsIgnoreTimerConflict); | ||||
|         activeMenu->Display(); | ||||
|         return true; | ||||
|     } | ||||
| @@ -206,7 +208,7 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|         case rmsSaveTimer: { | ||||
|             //caller: cRecMenuEditTimer | ||||
|             //save timer for active event | ||||
|             cTimer timerModified; | ||||
|             cTimer *timerModified; | ||||
|             const cTimer *originalTimer; | ||||
|             if (cRecMenuEditTimer *menu = dynamic_cast<cRecMenuEditTimer*>(activeMenu)) { | ||||
|                 timerModified = menu->GetTimer(); | ||||
| @@ -229,12 +231,12 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             if (cRecMenuTimerConflict *menu = dynamic_cast<cRecMenuTimerConflict*>(activeMenu)) { | ||||
|                 timerIndex = menu->GetTimerConflictIndex(); | ||||
|             } else break; | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex); | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex) + 1; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|             LOCK_TIMERS_READ; | ||||
|             const cTimer *t = Timers->Get(timerID); | ||||
|             const cTimer *t = Timers->GetById(timerID); | ||||
| #else | ||||
|             cTimer *t = Timers.Get(timerID); | ||||
|             const cTimer *t = Timers.Get(timerID); | ||||
| #endif | ||||
|             if (t) { | ||||
|                 const cEvent *ev = t->Event(); | ||||
| @@ -250,11 +252,24 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             if (cRecMenuTimerConflict *menu = dynamic_cast<cRecMenuTimerConflict*>(activeMenu)) { | ||||
|                 timerIndex = menu->GetTimerConflictIndex(); | ||||
|             } else break; | ||||
|             const cTimers* timers; | ||||
|             const cEvent *event; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex) + 1; | ||||
|             { | ||||
|             LOCK_TIMERS_READ; | ||||
|             timers = Timers; | ||||
|             } | ||||
|             event = timers->GetById(timerID)->Event(); | ||||
| #else | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex); | ||||
|             recManager->DeleteTimer(timerID); | ||||
|             timers = &Timers; | ||||
|             event = timers->Get(timerID)->Event(); | ||||
| #endif | ||||
|             recManager->DeleteTimer(event); // (timerID); | ||||
|             delete activeMenu; | ||||
|             if (!DisplayTimerConflict(timerID)) { | ||||
|                 activeMenu = new cRecMenuConfirmTimer(event); | ||||
|                 activeMenu = new cRecMenuConfirmDeleteTimer(event); | ||||
|                 activeMenu->Display(); | ||||
|             } | ||||
|             break; } | ||||
| @@ -265,10 +280,10 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             if (cRecMenuTimerConflict *menu = dynamic_cast<cRecMenuTimerConflict*>(activeMenu)) { | ||||
|                 timerIndex = menu->GetTimerConflictIndex(); | ||||
|             } else break; | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex); | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerIndex) + 1; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|             LOCK_TIMERS_READ; | ||||
|             const cTimer *timer = Timers->Get(timerID); | ||||
|             const cTimer *timer = Timers->GetById(timerID); | ||||
| #else | ||||
|             const cTimer *timer = Timers.Get(timerID); | ||||
| #endif | ||||
| @@ -281,7 +296,7 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|         case rmsSaveTimerConflictMenu: { | ||||
|             //caller: cRecMenuEditTimer | ||||
|             //save timer from current timer conflict | ||||
|             cTimer timerModified; | ||||
|             cTimer *timerModified; | ||||
|             const cTimer *originalTimer; | ||||
|             if (cRecMenuEditTimer *menu = dynamic_cast<cRecMenuEditTimer*>(activeMenu)) { | ||||
|                 timerModified = menu->GetTimer(); | ||||
| @@ -290,7 +305,7 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             recManager->SaveTimer(originalTimer, timerModified); | ||||
|             delete activeMenu; | ||||
|             if (!DisplayTimerConflict(originalTimer)) { | ||||
|                 activeMenu = new cRecMenuConfirmTimer(event); | ||||
|                 activeMenu = new cRecMenuConfirmTimer(originalTimer->Event(), true); | ||||
|                 activeMenu->Display(); | ||||
|             } | ||||
|             break; } | ||||
| @@ -639,7 +654,7 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             } else break; | ||||
|             timerConflicts->SetCurrentConflict(timerConflict); | ||||
|             delete activeMenu; | ||||
|             activeMenu = new cRecMenuTimerConflict(timerConflicts->GetCurrentConflict()); | ||||
|             activeMenu = new cRecMenuTimerConflict(timerConflicts->GetCurrentConflict(), rmsTimerConflicts); | ||||
|             activeMenu->Display(); | ||||
|             break; } | ||||
|         case rmsSearchRerunsTimerConflictMenu: { | ||||
| @@ -651,10 +666,10 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             if (cRecMenuTimerConflict *menu = dynamic_cast<cRecMenuTimerConflict*>(activeMenu)) { | ||||
|                 timerConflict = menu->GetTimerConflictIndex(); | ||||
|             } else break; | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerConflict); | ||||
|             int timerID = timerConflicts->GetCurrentConflictTimerID(timerConflict) + 1; | ||||
| #if VDRVERSNUM >= 20301 | ||||
|             LOCK_TIMERS_READ; | ||||
|             const cTimer *timer = Timers->Get(timerID); | ||||
|             const cTimer *timer = Timers->GetById(timerID); | ||||
| #else | ||||
|             cTimer *timer = Timers.Get(timerID); | ||||
| #endif | ||||
| @@ -740,7 +755,7 @@ eOSState cRecMenuView::StateMachine(eRecMenuState nextState) { | ||||
|             } | ||||
|             break;} | ||||
|         case rmsTimelineTimerSave: { | ||||
|             cTimer timerModified; | ||||
|             cTimer *timerModified; | ||||
|             const cTimer *originalTimer; | ||||
|             if (cRecMenuEditTimer *menu = dynamic_cast<cRecMenuEditTimer*>(activeMenu)) { | ||||
|                 timerModified = menu->GetTimer(); | ||||
|   | ||||
							
								
								
									
										17
									
								
								setup.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								setup.c
									
									
									
									
									
								
							| @@ -60,6 +60,7 @@ void cTvguideSetup::Store(void) { | ||||
|     SetupStore("debugImageLoading", config.debugImageLoading); | ||||
|     SetupStore("useNopacityTheme", config.useNopacityTheme); | ||||
|     SetupStore("themeIndex", config.themeIndex); | ||||
|     SetupStore("useHWAccel", config.useHWAccel); | ||||
|     SetupStore("showMainMenuEntry", config.showMainMenuEntry); | ||||
|     SetupStore("replaceOriginalSchedule", config.replaceOriginalSchedule); | ||||
|     SetupStore("displayMode", config.displayMode); | ||||
| @@ -79,7 +80,9 @@ void cTvguideSetup::Store(void) { | ||||
|     SetupStore("displayTime", config.displayTime); | ||||
|     SetupStore("displayHorizontalTime", config.displayHorizontalTime); | ||||
|     SetupStore("bigStepHours", config.bigStepHours); | ||||
|     SetupStore("bigStepHoursHorizontal", config.bigStepHoursHorizontal); | ||||
|     SetupStore("hugeStepHours", config.hugeStepHours); | ||||
|     SetupStore("hugeStepHoursHorizontal", config.hugeStepHoursHorizontal); | ||||
|     SetupStore("channelJumpMode", config.channelJumpMode); | ||||
|     SetupStore("blueKeyMode", config.blueKeyMode); | ||||
|     SetupStore("numkeyMode", config.numkeyMode); | ||||
| @@ -105,6 +108,7 @@ void cTvguideSetup::Store(void) { | ||||
|     SetupStore("footerHeightPercent", config.footerHeightPercent); | ||||
|     SetupStore("instRecFolderMode", config.instRecFolderMode); | ||||
|     SetupStore("instRecFixedFolder", config.instRecFixedFolder.c_str()); | ||||
|     SetupStore("AddSubtitleToTimerMode", config.addSubtitleToTimer); | ||||
|     SetupStore("favWhatsOnNow", config.favWhatsOnNow); | ||||
|     SetupStore("favWhatsOnNext", config.favWhatsOnNext); | ||||
|     SetupStore("favUseTime1", config.favUseTime1); | ||||
| @@ -203,6 +207,7 @@ cMenuSetupGeneral::cMenuSetupGeneral(cTVGuideConfig* data)  : cMenuSetupSubMenu( | ||||
| void cMenuSetupGeneral::Set(void) { | ||||
|     int currentItem = Current(); | ||||
|     Clear(); | ||||
|     Add(new cMenuEditBoolItem(tr("Use workaround for HWAccelerated OSD"), &tmpConfig->useHWAccel)); | ||||
|     Add(new cMenuEditBoolItem(tr("Show Main Menu Entry"), &tmpConfig->showMainMenuEntry)); | ||||
|     Add(new cMenuEditBoolItem(tr("Replace VDR Schedules Menu"), &tmpConfig->replaceOriginalSchedule)); | ||||
|     Add(new cMenuEditBoolItem(tr("Use appropriate nOpacity Theme"), &tmpConfig->useNopacityTheme)); | ||||
| @@ -222,8 +227,13 @@ void cMenuSetupGeneral::Set(void) { | ||||
|     Add(new cMenuEditBoolItem(tr("Close TVGuide after channel switch"), &tmpConfig->closeOnSwitch)); | ||||
|     Add(new cMenuEditStraItem(tr("Functionality of numeric Keys"), &tmpConfig->numkeyMode, 2,  numMode)); | ||||
|     Add(new cMenuEditBoolItem(tr("Hide last Channel Group"), &tmpConfig->hideLastGroup)); | ||||
|     if (tmpConfig->displayMode == eVertical) { | ||||
|         Add(new cMenuEditIntItem(tr("Big Step (Keys 1 / 3) in hours"), &tmpConfig->bigStepHours, 1, 12)); | ||||
|         Add(new cMenuEditIntItem(tr("Huge Step (Keys 4 / 6) in hours"), &tmpConfig->hugeStepHours, 13, 48)); | ||||
|     } else if (tmpConfig->displayMode == eHorizontal) { | ||||
|         Add(new cMenuEditIntItem(tr("Big Step (Keys 1 / 3) in hours"), &tmpConfig->bigStepHoursHorizontal, 1, 12)); | ||||
|         Add(new cMenuEditIntItem(tr("Huge Step (Keys 4 / 6) in hours"), &tmpConfig->hugeStepHoursHorizontal, 13, 48)); | ||||
|     } | ||||
|     Add(new cMenuEditStraItem(tr("Time Format (12h/24h)"), &tmpConfig->timeFormat, 2,  timeFormatItems)); | ||||
|     Add(new cMenuEditIntItem(tr("EPG Window Text Scrolling Speed"), &tmpConfig->detailedViewScrollStep, 1, 30)); | ||||
|     Add(new cMenuEditBoolItem(tr("Display Reruns in detailed EPG View"), &tmpConfig->displayRerunsDetailEPGView)); | ||||
| @@ -401,6 +411,9 @@ cMenuSetupFavorites::cMenuSetupFavorites(cTVGuideConfig* data)  : cMenuSetupSubM | ||||
|     recFolderMode[1] = tr("Select from folder list"); | ||||
|     recFolderMode[2] = tr("Use fixed folder"); | ||||
|     strn0cpy(fixedFolder, data->instRecFixedFolder.c_str(), sizeof(fixedFolder)); | ||||
|     addSubtitleMode[0] = tr("never"); | ||||
|     addSubtitleMode[1] = tr("smart"); | ||||
|     addSubtitleMode[2] = tr("always"); | ||||
|     switchModeItems[0] = (tr("switch")); | ||||
|     switchModeItems[1] = (tr("announce only")); | ||||
|     switchModeItems[2] = (tr("ask for switch")); | ||||
| @@ -411,13 +424,15 @@ void cMenuSetupFavorites::Set(void) { | ||||
|     int currentItem = Current(); | ||||
|     Clear(); | ||||
|  | ||||
|     Add(new cOsdItem(tr("Instant recording:"), osUnknown, false)); | ||||
|     Add(new cMenuEditStraItem(tr("Folder for instant Recordings"), &tmpConfig->instRecFolderMode, 3, recFolderMode)); | ||||
|     if (tmpConfig->instRecFolderMode == eFolderFixed) { | ||||
|         Add(new cMenuEditStrItem(cString::sprintf("%s%s", *indent, tr("Folder")), fixedFolder, sizeof(fixedFolder), trVDR(FileNameChars))); | ||||
|     } | ||||
|     Add(new cMenuEditStraItem(tr("Add episode to manual timers"), &tmpConfig->addSubtitleToTimer, 3, addSubtitleMode)); | ||||
|     if (pRemoteTimers) | ||||
|         Add(new cMenuEditBoolItem(tr("Use Remotetimers"), &tmpConfig->useRemoteTimers)); | ||||
|  | ||||
|     Add(new cOsdItem(tr("Favorites:"), osUnknown, false)); | ||||
|     Add(new cMenuEditBoolItem(tr("Limit channels in favorites"), &tmpConfig->favLimitChannels)); | ||||
|     if (tmpConfig->favLimitChannels) { | ||||
|         Add(new cMenuEditChanItem(tr("Start Channel"), &tmpConfig->favStartChannel)); | ||||
|   | ||||
							
								
								
									
										1
									
								
								setup.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								setup.h
									
									
									
									
									
								
							| @@ -70,6 +70,7 @@ class cMenuSetupFavorites : public cMenuSetupSubMenu { | ||||
|         char description3[256]; | ||||
|         char description4[256]; | ||||
|         const char * recFolderMode[3]; | ||||
|         const char * addSubtitleMode[3]; | ||||
|         const char * switchModeItems[3]; | ||||
|         char fixedFolder[256]; | ||||
|         void Set(void); | ||||
|   | ||||
							
								
								
									
										129
									
								
								timeline.c
									
									
									
									
									
								
							
							
						
						
									
										129
									
								
								timeline.c
									
									
									
									
									
								
							| @@ -5,34 +5,29 @@ cTimeLine::cTimeLine(cTimeManager *timeManager) { | ||||
|     this->timeManager = timeManager; | ||||
|     lastClock = ""; | ||||
|     timeBase = NULL; | ||||
|     int x11, x21, y11, y21, x12, x22, y12, y22; | ||||
|     if (config.displayMode == eVertical) { | ||||
|         dateViewer = new cStyledPixmap(osdManager.requestPixmap(1, cRect(0,  | ||||
|                                                                          geoManager.statusHeaderHeight + geoManager.clockHeight,  | ||||
|                                                                          geoManager.dateVieverWidth,  | ||||
|                                                                          geoManager.dateVieverHeight))); | ||||
|         timeline = osdManager.requestPixmap(2, cRect(0,  | ||||
|                                                      geoManager.statusHeaderHeight + geoManager.channelHeaderHeight + geoManager.channelGroupsHeight,  | ||||
|                                                      geoManager.timeLineWidth,  | ||||
|                                                      geoManager.osdHeight - geoManager.statusHeaderHeight - geoManager.channelHeaderHeight - geoManager.channelGroupsHeight - geoManager.footerHeight) | ||||
|                                              , cRect(0, | ||||
|                                                      0,  | ||||
|                                                      geoManager.timeLineWidth,  | ||||
|                                                      1440 * geoManager.minutePixel)); | ||||
|         x11 = 0; | ||||
|         x21 = geoManager.dateVieverWidth; | ||||
|         y11 = geoManager.statusHeaderHeight + geoManager.clockHeight; | ||||
|         y21 = geoManager.dateVieverHeight; | ||||
|         x12 = 0; | ||||
|         x22 = geoManager.timeLineWidth; | ||||
|         y12 = geoManager.statusHeaderHeight + geoManager.channelHeaderHeight + geoManager.channelGroupsHeight; | ||||
|         y22 = geoManager.osdHeight - geoManager.statusHeaderHeight - geoManager.channelHeaderHeight - geoManager.channelGroupsHeight - geoManager.footerHeight; | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         dateViewer = new cStyledPixmap(osdManager.requestPixmap(1, cRect(geoManager.clockWidth,  | ||||
|                                                                          geoManager.statusHeaderHeight,  | ||||
|                                                                          geoManager.dateVieverWidth, | ||||
|                                                                          geoManager.dateVieverHeight))); | ||||
|         timeline = osdManager.requestPixmap(2, cRect(geoManager.channelHeaderWidth + geoManager.channelGroupsWidth,  | ||||
|                                                      geoManager.statusHeaderHeight,  | ||||
|                                                      geoManager.osdWidth - geoManager.channelHeaderWidth - geoManager.channelGroupsWidth, | ||||
|                                                      geoManager.timeLineHeight) | ||||
|                                              , cRect(0, | ||||
|                                                      0,  | ||||
|                                                      1440 * geoManager.minutePixel,  | ||||
|                                                      geoManager.timeLineHeight)); | ||||
|         x11 = geoManager.clockWidth; | ||||
|         x21 = geoManager.dateVieverWidth; | ||||
|         y11 = geoManager.statusHeaderHeight; | ||||
|         y21 = geoManager.dateVieverHeight; | ||||
|         x12 = geoManager.channelHeaderWidth + geoManager.channelGroupsWidth; | ||||
|         x22 = geoManager.osdWidth - geoManager.channelHeaderWidth - geoManager.channelGroupsWidth; | ||||
|         y12 = geoManager.statusHeaderHeight; | ||||
|         y22 = geoManager.timeLineHeight; | ||||
|     } | ||||
|     clock = new cStyledPixmap(osdManager.requestPixmap(4, cRect(0,  | ||||
|     dateViewer = new cStyledPixmap(osdManager.requestPixmap(1, cRect(x11, y11, x21, y21))); | ||||
|     timeline = osdManager.requestPixmap(2, cRect(x12, y12, x22, y22)); | ||||
|     clock = new cStyledPixmap(osdManager.requestPixmap(3, cRect(0,  | ||||
|                                                                 geoManager.statusHeaderHeight,  | ||||
|                                                                 geoManager.clockWidth,  | ||||
|                                                                 geoManager.clockHeight))); | ||||
| @@ -43,10 +38,11 @@ cTimeLine::~cTimeLine(void) { | ||||
|        delete clock; | ||||
|     osdManager.releasePixmap(timeBase); | ||||
|     osdManager.releasePixmap(timeline); | ||||
|     if (dateViewer) | ||||
|         delete dateViewer; | ||||
| } | ||||
|  | ||||
| void cTimeLine::drawDateViewer() { | ||||
| void cTimeLine::DrawDateViewer(void) { | ||||
|     cString weekDay = timeManager->GetWeekday(); | ||||
|     cString date = timeManager->GetDate();    | ||||
|     if (config.style != eStyleGraphical) { | ||||
| @@ -80,8 +76,8 @@ void cTimeLine::drawDateViewer() { | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTimeLine::drawTimeline() { | ||||
|     timeline->SetTile(true); | ||||
| void cTimeLine::DrawTimeline(void) { | ||||
| //    timeline->SetTile(true); | ||||
|     timeline->Fill(clrTransparent); | ||||
|     tColor colorFont, colorBackground; | ||||
|      | ||||
| @@ -93,8 +89,8 @@ void cTimeLine::drawTimeline() { | ||||
|         img1 = imgCache.GetOsdElement(oeTimeline1); | ||||
|         img2 = imgCache.GetOsdElement(oeTimeline2); | ||||
|     } else { | ||||
|         img1 = createBackgroundImage(imgWidth, imgHeight, theme.Color(clrTimeline1), theme.Color(clrTimeline1Blending)); | ||||
|         img2 = createBackgroundImage(imgWidth, imgHeight, theme.Color(clrTimeline2), theme.Color(clrTimeline2Blending)); | ||||
|         img1 = CreateBackgroundImage(imgWidth, imgHeight, theme.Color(clrTimeline1), theme.Color(clrTimeline1Blending)); | ||||
|         img2 = CreateBackgroundImage(imgWidth, imgHeight, theme.Color(clrTimeline2), theme.Color(clrTimeline2Blending)); | ||||
|     } | ||||
|     const cImage *img = NULL; | ||||
|     if (!img1 || !img2) | ||||
| @@ -102,8 +98,19 @@ void cTimeLine::drawTimeline() { | ||||
|     int textWidth, posX, posY; | ||||
|     char timetext[10]; | ||||
|      | ||||
|     for (int i=0; i<48; i++) { | ||||
|         if (i%2==0) { | ||||
|     int halfHours; | ||||
|     if (config.displayMode == eVertical) | ||||
|         halfHours = config.displayTime / 30 + 1; | ||||
|     else | ||||
|         halfHours = config.displayHorizontalTime / 30 + 1; | ||||
|  | ||||
|     time_t tStart = timeManager->GetStart(); | ||||
|     tm *t = localtime ( &tStart ); | ||||
|  | ||||
|     int x = 2 * t->tm_hour + ((t->tm_min == 0) ? 0 : 1); | ||||
|     for (int j = x; j < (x + halfHours); j++) { | ||||
|         int i = (j >= 48) ? (j - 48) : j; | ||||
|         if (i % 2 == 0) { | ||||
|             img = img1; | ||||
|             colorFont = theme.Color(clrTimeline2); | ||||
|             colorBackground = (config.style == eStyleFlat)?theme.Color(clrTimeline1):clrTransparent; | ||||
| @@ -111,11 +118,11 @@ void cTimeLine::drawTimeline() { | ||||
|                 if (i == 0) | ||||
|                     sprintf(timetext, "12:00 PM"); | ||||
|                 else if (i/2 < 13) | ||||
|                     sprintf(timetext, "%d:00 AM", i/2); | ||||
|                     sprintf(timetext, "%d:00 AM", i / 2); | ||||
|                 else  | ||||
|                     sprintf(timetext, "%d:00 PM", i/2-12); | ||||
|                     sprintf(timetext, "%d:00 PM", i / 2 - 12); | ||||
|             } else { | ||||
|                 sprintf(timetext, "%d:00", i/2); | ||||
|                 sprintf(timetext, "%d:00", i / 2); | ||||
|             } | ||||
|         } else { | ||||
|             img = img2; | ||||
| @@ -125,38 +132,38 @@ void cTimeLine::drawTimeline() { | ||||
|                 if (i == 1) | ||||
|                     sprintf(timetext, "12:30 PM"); | ||||
|                 else if (i/2 < 13) | ||||
|                     sprintf(timetext, "%d:30 AM", i/2); | ||||
|                     sprintf(timetext, "%d:30 AM", i / 2); | ||||
|                 else  | ||||
|                     sprintf(timetext, "%d:30 PM", i/2-12); | ||||
|                     sprintf(timetext, "%d:30 PM", i / 2 - 12); | ||||
|             } else { | ||||
|                 sprintf(timetext, "%d:30", i/2); | ||||
|                 sprintf(timetext, "%d:30", i / 2); | ||||
|             } | ||||
|         } | ||||
|         if (config.displayMode == eVertical) { | ||||
|             posY = i*geoManager.minutePixel*30; | ||||
|             posY = (j - x) * geoManager.minutePixel * 30; | ||||
|             timeline->DrawImage(cPoint(0, posY), *img); | ||||
|             if (config.style != eStyleGraphical) { | ||||
|                 decorateTile(0, posY, imgWidth+2, imgHeight); | ||||
|                 DecorateTile(0, posY, imgWidth + 2, imgHeight); | ||||
|             } | ||||
|             textWidth = fontManager.FontTimeLineTime->Width(timetext); | ||||
|             timeline->DrawText(cPoint((geoManager.timeLineWidth-textWidth)/2, posY + 5), timetext, colorFont, colorBackground, fontManager.FontTimeLineTime); | ||||
|             timeline->DrawText(cPoint((geoManager.timeLineWidth-textWidth) / 2, posY + 5), timetext, colorFont, colorBackground, fontManager.FontTimeLineTime); | ||||
|         } else if (config.displayMode == eHorizontal) { | ||||
|             posX = i*geoManager.minutePixel*30; | ||||
|             posX = (j - x) * geoManager.minutePixel * 30; | ||||
|             timeline->DrawImage(cPoint(posX, 0), *img); | ||||
|             if (config.style != eStyleGraphical) { | ||||
|                 decorateTile(posX, 0, imgWidth, imgHeight+2); | ||||
|                 DecorateTile(posX, 0, imgWidth, imgHeight + 2); | ||||
|             } | ||||
|             timeline->DrawText(cPoint(posX + 15, (dateViewer->Height() - fontManager.FontTimeLineTimeHorizontal->Height())/2), timetext, colorFont, colorBackground, fontManager.FontTimeLineTimeHorizontal); | ||||
|             timeline->DrawText(cPoint(posX + 15, (dateViewer->Height() - fontManager.FontTimeLineTimeHorizontal->Height()) / 2), timetext, colorFont, colorBackground, fontManager.FontTimeLineTimeHorizontal); | ||||
|        } | ||||
|     } | ||||
|     setTimeline(); | ||||
|     DrawTimeIndicator(); | ||||
|     if (config.style != eStyleGraphical) { | ||||
|         delete img1; | ||||
|         delete img2; | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTimeLine::decorateTile(int posX, int posY, int tileWidth, int tileHeight) { | ||||
| void cTimeLine::DecorateTile(int posX, int posY, int tileWidth, int tileHeight) { | ||||
|     timeline->DrawRectangle(cRect(posX,posY,tileWidth,2), clrTransparent);          //top | ||||
|     timeline->DrawRectangle(cRect(posX,posY,2,tileHeight), clrTransparent);         //left | ||||
|     timeline->DrawRectangle(cRect(posX,posY + tileHeight-2,tileWidth,2), clrTransparent);   //bottom | ||||
| @@ -169,11 +176,11 @@ void cTimeLine::decorateTile(int posX, int posY, int tileWidth, int tileHeight) | ||||
|      | ||||
|     if (config.roundedCorners) { | ||||
|         int borderRadius = 12; | ||||
|         drawRoundedCorners(posX, posY, tileWidth, tileHeight, borderRadius); | ||||
|         DrawRoundedCorners(posX, posY, tileWidth, tileHeight, borderRadius); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTimeLine::drawRoundedCorners(int posX, int posY, int width, int height, int radius) { | ||||
| void cTimeLine::DrawRoundedCorners(int posX, int posY, int width, int height, int radius) { | ||||
|     timeline->DrawEllipse(cRect(posX+2,posY+2,radius,radius), theme.Color(clrBorder), -2); | ||||
|     timeline->DrawEllipse(cRect(posX+1,posY+1,radius,radius), clrTransparent, -2); | ||||
|  | ||||
| @@ -189,14 +196,16 @@ void cTimeLine::drawRoundedCorners(int posX, int posY, int width, int height, in | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTimeLine::drawCurrentTimeBase(void) { | ||||
| void cTimeLine::DrawTimeIndicator(void) { | ||||
|     if (!config.displayTimeBase) | ||||
|         return; | ||||
|     if (!timeManager->NowVisible()) { | ||||
|        if (timeBase) | ||||
|           timeBase->Fill(clrTransparent); | ||||
|        return; | ||||
|     } | ||||
|     int deltaTime = (time(0) - timeManager->GetStart()) / 60 * geoManager.minutePixel; | ||||
|     osdManager.releasePixmap(timeBase); | ||||
|     int deltaTime = (timeManager->GetNow() - timeManager->GetStart()) / 60 * geoManager.minutePixel; | ||||
|     int x1, x2, y1, y2; | ||||
|     if (config.displayMode == eVertical) { | ||||
|        x1 = 0; | ||||
| @@ -214,7 +223,7 @@ void cTimeLine::drawCurrentTimeBase(void) { | ||||
|     timeBase->DrawRectangle(cRect(0, 0, timeBase->ViewPort().Width(), timeBase->ViewPort().Height()), theme.Color(clrTimeBase)); | ||||
| } | ||||
|  | ||||
| cImage *cTimeLine::createBackgroundImage(int width, int height, tColor clrBgr, tColor clrBlend) { | ||||
| cImage *cTimeLine::CreateBackgroundImage(int width, int height, tColor clrBgr, tColor clrBlend) { | ||||
|     cImage *image = NULL; | ||||
|     if (config.style == eStyleBlendingDefault) { | ||||
|         image = new cImage(cSize(width, height)); | ||||
| @@ -243,22 +252,7 @@ cImage *cTimeLine::createBackgroundImage(int width, int height, tColor clrBgr, t | ||||
|     return image; | ||||
| } | ||||
|  | ||||
| void cTimeLine::setTimeline() { | ||||
|     int offset = timeManager->GetTimelineOffset(); | ||||
|     int xNew, yNew; | ||||
|     if (config.displayMode == eVertical) { | ||||
|         xNew = 0; | ||||
|         yNew = -offset*geoManager.minutePixel; | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         xNew = -offset*geoManager.minutePixel; | ||||
|         yNew = 0; | ||||
|     } | ||||
|     timeline->SetDrawPortPoint(cPoint(xNew, yNew)); | ||||
|     if (config.displayTimeBase) | ||||
|         drawCurrentTimeBase(); | ||||
| } | ||||
|  | ||||
| bool cTimeLine::drawClock() { | ||||
| bool cTimeLine::DrawClock(void) { | ||||
|     cString currentTime = timeManager->GetCurrentTime(); | ||||
|     if (strcmp(currentTime, lastClock)) { | ||||
|        clock->Fill(clrTransparent); | ||||
| @@ -275,6 +269,7 @@ bool cTimeLine::drawClock() { | ||||
|        } | ||||
|        clock->DrawText(cPoint((geoManager.clockWidth - clockTextWidth) / 2, (geoManager.clockHeight - textHeight) / 2), *currentTime, theme.Color(clrFont), colorFontBack, font); | ||||
|        lastClock = currentTime; | ||||
|        DrawTimeIndicator(); | ||||
|        return true; | ||||
|     } | ||||
|     return false; | ||||
|   | ||||
							
								
								
									
										15
									
								
								timeline.h
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								timeline.h
									
									
									
									
									
								
							| @@ -14,17 +14,16 @@ private: | ||||
|     cStyledPixmap *clock; | ||||
|     cPixmap *timeBase; | ||||
|     cString lastClock; | ||||
|     void decorateTile(int posX, int posY, int tileWidth, int tileHeight); | ||||
|     void drawRoundedCorners(int posX, int posY, int width, int height, int radius); | ||||
|     cImage *createBackgroundImage(int width, int height, tColor clrBgr, tColor clrBlend); | ||||
|     void DecorateTile(int posX, int posY, int tileWidth, int tileHeight); | ||||
|     void DrawRoundedCorners(int posX, int posY, int width, int height, int radius); | ||||
|     cImage *CreateBackgroundImage(int width, int height, tColor clrBgr, tColor clrBlend); | ||||
| public: | ||||
|     cTimeLine(cTimeManager *timeManager); | ||||
|     virtual ~cTimeLine(void); | ||||
|     void setTimeline(void); | ||||
|     void drawDateViewer(void); | ||||
|     void drawTimeline(void); | ||||
|     void drawCurrentTimeBase(void); | ||||
|     bool drawClock(); | ||||
|     void DrawDateViewer(void); | ||||
|     void DrawTimeline(void); | ||||
|     void DrawTimeIndicator(void); | ||||
|     bool DrawClock(void); | ||||
| }; | ||||
|  | ||||
| #endif //__TVGUIDE_TIMELINE_H | ||||
|   | ||||
| @@ -3,6 +3,14 @@ | ||||
| #include "config.h" | ||||
| #include "timemanager.h" | ||||
|  | ||||
| cTimeManager::cTimeManager(void) { | ||||
|     if (config.displayMode == eVertical) { | ||||
|         displaySeconds = (geoManager.osdHeight - geoManager.statusHeaderHeight - geoManager.channelHeaderHeight - geoManager.channelGroupsHeight - geoManager.footerHeight) / geoManager.minutePixel * 60; | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         displaySeconds = (geoManager.osdWidth - geoManager.channelHeaderWidth - geoManager.channelGroupsWidth) / geoManager.minutePixel * 60; | ||||
|     } | ||||
| } | ||||
|  | ||||
| cTimeManager::~cTimeManager(void) { | ||||
| } | ||||
|  | ||||
| @@ -18,40 +26,32 @@ void cTimeManager::Now() { | ||||
|     t = time(0); | ||||
|     tStart = t; | ||||
|     tStart = GetRounded(); | ||||
|     if (config.displayMode == eVertical) { | ||||
|         tEnd = tStart + (geoManager.osdHeight - geoManager.statusHeaderHeight - geoManager.channelHeaderHeight - geoManager.channelGroupsHeight - geoManager.footerHeight)/geoManager.minutePixel*60; | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         tEnd = tStart + (geoManager.osdWidth - geoManager.channelHeaderWidth - geoManager.channelGroupsWidth)/geoManager.minutePixel*60; | ||||
|     } | ||||
|     tEnd   = tStart + displaySeconds; | ||||
| } | ||||
|  | ||||
| void cTimeManager::AddStep(int step) { | ||||
|     tStart += step*60; | ||||
|     tEnd  += step*60; | ||||
|     tStart += step * 60; | ||||
|     tEnd    = tStart + displaySeconds; | ||||
| } | ||||
|  | ||||
| bool cTimeManager::DelStep(int step) { | ||||
|     if ((tStart - step*60)+30*60 < t) { | ||||
|         return true; | ||||
| void cTimeManager::DelStep(int step) { | ||||
|     if ((tStart - step * 60) + 30 * 60 < t) { | ||||
|         Now(); | ||||
|     } else { | ||||
|         tStart -= step * 60; | ||||
|         tEnd    = tStart + displaySeconds; | ||||
|     } | ||||
|     tStart -= step*60; | ||||
|     tEnd -= step*60; | ||||
|     return false; | ||||
| } | ||||
|  | ||||
| void cTimeManager::SetTime(time_t newTime) { | ||||
|     tStart = newTime; | ||||
|     if (config.displayMode == eVertical) { | ||||
|         tEnd = tStart + (geoManager.osdHeight - geoManager.statusHeaderHeight - geoManager.channelHeaderHeight - geoManager.channelGroupsHeight - geoManager.footerHeight)/geoManager.minutePixel*60; | ||||
|     } else if (config.displayMode == eHorizontal) { | ||||
|         tEnd = tStart + (geoManager.osdWidth - geoManager.channelHeaderWidth - geoManager.channelGroupsWidth)/geoManager.minutePixel*60; | ||||
|     } | ||||
|     tEnd   = tStart + displaySeconds; | ||||
| } | ||||
|  | ||||
| time_t cTimeManager::getPrevPrimetime(time_t current) { | ||||
|     tm *st = localtime(¤t); | ||||
|     if (st->tm_hour < 21) { | ||||
|         current -= 24 * 60* 60; | ||||
|         current -= 24 * 60 * 60; | ||||
|         st = localtime(¤t); | ||||
|     } | ||||
|     st->tm_hour = 20; | ||||
| @@ -63,7 +63,7 @@ time_t cTimeManager::getPrevPrimetime(time_t current) { | ||||
| time_t cTimeManager::getNextPrimetime(time_t current){ | ||||
|     tm *st = localtime(¤t); | ||||
|     if (st->tm_hour > 19) { | ||||
|         current += 24 * 60* 60; | ||||
|         current += 24 * 60 * 60; | ||||
|         st = localtime(¤t); | ||||
|     } | ||||
|     st->tm_hour = 20; | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
| #define __TVGUIDE_TIMEMANAGER_H | ||||
|  | ||||
| #include <vdr/tools.h> | ||||
| #include "config.h" | ||||
|  | ||||
| // --- cTimeManager -------------------------------------------------------------  | ||||
|  | ||||
| @@ -10,14 +11,16 @@ class cTimeManager { | ||||
|         time_t t; | ||||
|         time_t tStart; | ||||
|         time_t tEnd; | ||||
|         int displaySeconds; | ||||
|         eTimeFormat timeFormat; | ||||
|     public: | ||||
|         cTimeManager(){}; | ||||
|         cTimeManager(); | ||||
|         virtual ~cTimeManager(void); | ||||
|         static cString printTime(time_t displayTime); | ||||
|         void Now(); | ||||
|         time_t GetNow() { return t; }; | ||||
|         void AddStep(int step); | ||||
|         bool DelStep(int step); | ||||
|         void DelStep(int step); | ||||
|         void SetTime(time_t newTime); | ||||
|         time_t Get() {return t;}; | ||||
|         time_t GetStart() {return tStart;}; | ||||
| @@ -31,6 +34,7 @@ class cTimeManager { | ||||
|         int GetTimelineOffset(); | ||||
|         time_t GetRounded(); | ||||
|         bool NowVisible(void); | ||||
|         int GetDisplaySeconds(void) { return displaySeconds; }; | ||||
|         void debug(); | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -16,12 +16,11 @@ cTVGuideTimerConflict::cTVGuideTimerConflict(void) { | ||||
| } | ||||
|  | ||||
| cTVGuideTimerConflict::~cTVGuideTimerConflict(void) { | ||||
|  | ||||
| } | ||||
|  | ||||
| bool cTVGuideTimerConflict::timerInvolved(int involvedID) { | ||||
|     int numConflicts = timerIDs.size(); | ||||
|     for (int i=0; i<numConflicts; i++) { | ||||
|     for (int i = 0; i < numConflicts; i++) { | ||||
|         if (timerIDs[i] == involvedID) | ||||
|             return true; | ||||
|     } | ||||
| @@ -49,8 +48,7 @@ void cTVGuideTimerConflicts::AddConflict(std::string epgSearchConflictLine) { | ||||
|     1190232780:152|30|50#152#45:45|10|50#152#45 | ||||
|     '1190232780' is the time of the conflict in seconds since 1970-01-01.  | ||||
|     It's followed by list of timers that have a conflict at this time: | ||||
|     '152|30|50#1    int editTimer(cTimer *timer, bool active, int prio, int start, int stop); | ||||
|     52#45' is the description of the first conflicting timer. Here: | ||||
|     '152|30|50#152#45' is the description of the first conflicting timer. Here: | ||||
|     '152' is VDR's timer id of this timer as returned from VDR's LSTT command | ||||
|     '30' is the percentage of recording that would be done (0...100) | ||||
|     '50#152#45' is the list of concurrent timers at this conflict | ||||
| @@ -86,11 +84,13 @@ void cTVGuideTimerConflicts::CalculateConflicts(void) { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|         LOCK_TIMERS_READ; | ||||
|         const cTimers* timers = Timers; | ||||
|         for (int j=0; j < numTimers; j++) { | ||||
|             const cTimer *timer = timers->GetById(conflicts[i]->timerIDs[j] + 1); | ||||
| #else | ||||
|         const cTimers* timers = &Timers; | ||||
| #endif | ||||
|         for (int j=0; j < numTimers; j++) { | ||||
|             const cTimer *timer = timers->Get(conflicts[i]->timerIDs[j]); | ||||
| #endif | ||||
|             if (timer) { | ||||
|                 if (!unionSet) { | ||||
|                     unionSet = new cTimeInterval(timer->StartTime(), timer->StopTime()); | ||||
| @@ -109,7 +109,11 @@ void cTVGuideTimerConflicts::CalculateConflicts(void) { | ||||
|          | ||||
|         cTimeInterval *intersect = NULL; | ||||
|         for (int j=0; j < numTimers; j++) { | ||||
| #if VDRVERSNUM >= 20301 | ||||
|             const cTimer *timer = timers->GetById(conflicts[i]->timerIDs[j] + 1); | ||||
| #else | ||||
|             const cTimer *timer = timers->Get(conflicts[i]->timerIDs[j]); | ||||
| #endif | ||||
|             if (timer) { | ||||
|                 if (!intersect) { | ||||
|                     intersect = new cTimeInterval(timer->StartTime(), timer->StopTime()); | ||||
| @@ -152,7 +156,7 @@ int cTVGuideTimerConflicts::GetCurrentConflictTimerID(int timerIndex) { | ||||
| int cTVGuideTimerConflicts::GetCorrespondingConflict(int timerID) { | ||||
|     int conflictIndex = -1; | ||||
|     if (numConflicts > 0) { | ||||
|         for (int i=0; i<numConflicts; i++) { | ||||
|         for (int i = 0; i < numConflicts; i++) { | ||||
|             if (conflicts[i]->timerInvolved(timerID)) { | ||||
|                 conflictIndex = i; | ||||
|                 break; | ||||
| @@ -172,7 +176,7 @@ cTVGuideTimerConflict *cTVGuideTimerConflicts::GetConflict(int conflictIndex) { | ||||
|  | ||||
| std::vector<cTVGuideTimerConflict*> cTVGuideTimerConflicts::GetConflictsBetween(time_t start, time_t stop) { | ||||
|     std::vector<cTVGuideTimerConflict*> conflictsFound; | ||||
|     for (int i=0; i < numConflicts; i++) { | ||||
|     for (int i = 0; i < numConflicts; i++) { | ||||
|         if ((conflicts[i]->timeStart > start) && (conflicts[i]->timeStart < stop)|| | ||||
|             (conflicts[i]->timeStop  > start) && (conflicts[i]->timeStop < stop)) | ||||
|             conflictsFound.push_back(conflicts[i]); | ||||
|   | ||||
							
								
								
									
										60
									
								
								tools.c
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								tools.c
									
									
									
									
									
								
							| @@ -23,32 +23,49 @@ cPlugin *GetScraperPlugin(void) { | ||||
| /**************************************************************************************** | ||||
| *            CUTTEXT | ||||
| ****************************************************************************************/ | ||||
| std::string utf8_substr(const std::string& str, unsigned int start, long unsigned int leng) { | ||||
|     if (leng==0) { return ""; } | ||||
|     unsigned int c, i, ix, q; | ||||
|     long unsigned int min=std::string::npos, max=std::string::npos; | ||||
|     for (q=0, i=0, ix=str.length(); i < ix; i++, q++) { | ||||
|         if (q==start){ min=i; } | ||||
|         if (q<=start+leng || leng==std::string::npos){ max=i; } | ||||
|  | ||||
|         c = (unsigned char) str[i]; | ||||
|         if      (c>=0   && c<=127) i+=0; | ||||
|         else if ((c & 0xE0) == 0xC0) i+=1; | ||||
|         else if ((c & 0xF0) == 0xE0) i+=2; | ||||
|         else if ((c & 0xF8) == 0xF0) i+=3; | ||||
|         //else if (($c & 0xFC) == 0xF8) i+=4; // 111110bb //byte 5, unnecessary in 4 byte UTF-8 | ||||
|         //else if (($c & 0xFE) == 0xFC) i+=5; // 1111110b //byte 6, unnecessary in 4 byte UTF-8 | ||||
|         else return "";//invalid utf8 | ||||
|     } | ||||
|     if (q<=start+leng || leng==std::string::npos){ max=i; } | ||||
|     if (min==std::string::npos || max==std::string::npos) { return ""; } | ||||
|     return str.substr(min,max); | ||||
| } | ||||
|  | ||||
| std::string CutText(std::string text, int width, const cFont *font) { | ||||
|     if (width <= font->Size()) | ||||
|     int actWidth = font->Width(text.c_str()); | ||||
|     if (actWidth <= width) { | ||||
|         return text.c_str(); | ||||
|     if (font->Width(text.c_str()) < width) | ||||
|         return text.c_str(); | ||||
|     cTextWrapper twText; | ||||
|     twText.Set(text.c_str(), font, width); | ||||
|     std::string cuttedTextNative = twText.GetLine(0); | ||||
|     } else { | ||||
|         int i = std::max(width / font->Size(), 1) - 1; | ||||
|         std::string cuttext, oldtext; | ||||
|         cuttext = utf8_substr(text, 0, i); | ||||
|         do { | ||||
|             oldtext = cuttext; | ||||
|             i++; | ||||
|             cuttext = utf8_substr(text, 0, i); | ||||
|             std::stringstream sstrText; | ||||
|     sstrText << cuttedTextNative << "..."; | ||||
|     std::string cuttedText = sstrText.str(); | ||||
|     int actWidth = font->Width(cuttedText.c_str()); | ||||
|     if (actWidth > width) { | ||||
|         int overlap = actWidth - width; | ||||
|         int charWidth = font->Width("."); | ||||
|         if (charWidth == 0) | ||||
|             charWidth = 1; | ||||
|         int cutChars = overlap / charWidth; | ||||
|         if (cutChars > 0) { | ||||
|             cuttedTextNative = cuttedTextNative.substr(0, cuttedTextNative.length() - cutChars); | ||||
|             sstrText << cuttext << "..."; | ||||
|             actWidth = font->Width(sstrText.str().c_str()); | ||||
|         } | ||||
|         while (actWidth < width); | ||||
|         std::stringstream sstrText2; | ||||
|             sstrText2 << cuttedTextNative << "..."; | ||||
|             cuttedText = sstrText2.str(); | ||||
|         sstrText2 << oldtext << "..."; | ||||
|         return sstrText2.str(); | ||||
|     } | ||||
|     } | ||||
|     return cuttedText; | ||||
| } | ||||
|  | ||||
| /**************************************************************************************** | ||||
| @@ -113,7 +130,6 @@ void ReadRecordingDirectories(std::vector<std::string> *folders, cList<cNestedIt | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| /**************************************************************************************** | ||||
| *            DrawRoundedCorners | ||||
| ****************************************************************************************/ | ||||
|   | ||||
							
								
								
									
										1
									
								
								tools.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								tools.h
									
									
									
									
									
								
							| @@ -9,6 +9,7 @@ | ||||
|  | ||||
| cPlugin *GetScraperPlugin(void); | ||||
|  | ||||
| std::string utf8_substr(const std::string& str, unsigned int start=0, long unsigned int leng=std::string::npos); | ||||
| std::string CutText(std::string text, int width, const cFont *font); | ||||
| std::string StrToLowerCase(std::string str); | ||||
| std::string GetDirectoryFromTimer(std::string file); | ||||
|   | ||||
| @@ -27,7 +27,7 @@ | ||||
| #error "VDR-2.0.0 API version or greater is required!" | ||||
| #endif | ||||
|  | ||||
| static const char *VERSION        = "1.2.14"; | ||||
| static const char *VERSION        = "1.3.0"; | ||||
| static const char *DESCRIPTION    = tr("A fancy 2d EPG Viewer"); | ||||
| static const char *MAINMENUENTRY  = "Tvguide"; | ||||
|  | ||||
|   | ||||
							
								
								
									
										63
									
								
								tvguideosd.c
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								tvguideosd.c
									
									
									
									
									
								
							| @@ -112,9 +112,9 @@ void cTvGuideOsd::drawOsd() { | ||||
|         statusHeader->ScaleVideo(); | ||||
|     } | ||||
|     timeLine = new cTimeLine(timeManager); | ||||
|     timeLine->drawDateViewer(); | ||||
|     timeLine->drawTimeline(); | ||||
|     timeLine->drawClock(); | ||||
|     timeLine->DrawDateViewer(); | ||||
|     timeLine->DrawTimeline(); | ||||
|     timeLine->DrawClock(); | ||||
|     channelGroups = new cChannelGroups(); | ||||
|     channelGroups->ReadChannelGroups(); | ||||
|     footer = new cFooter(channelGroups); | ||||
| @@ -195,7 +195,7 @@ void cTvGuideOsd::drawGridsChannelJump(int offset) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTvGuideOsd::drawGridsTimeJump() { | ||||
| void cTvGuideOsd::drawGridsTimeJump(bool last) { | ||||
|     if (columns.Count() == 0) | ||||
|         return; | ||||
|     cChannelEpg *colActive = NULL; | ||||
| @@ -209,7 +209,7 @@ void cTvGuideOsd::drawGridsTimeJump() { | ||||
|         column->readGrids(); | ||||
|         column->drawGrids(); | ||||
|     } | ||||
|     activeGrid = colActive->getActive(); | ||||
|     activeGrid = colActive->getActive(last); | ||||
|     if (activeGrid) { | ||||
|         activeGrid->SetActive(); | ||||
|         activeGrid->Draw(); | ||||
| @@ -372,13 +372,20 @@ void cTvGuideOsd::timeForward() { | ||||
|  | ||||
| void cTvGuideOsd::ScrollForward() { | ||||
|     timeManager->AddStep(config.stepMinutes); | ||||
|     timeLine->drawDateViewer(); | ||||
|     timeLine->setTimeline(); | ||||
|     if (config.useHWAccel) { | ||||
|         drawGridsTimeJump(true); | ||||
|         timeLine->DrawDateViewer(); | ||||
|         timeLine->DrawClock(); | ||||
|         timeLine->DrawTimeline(); | ||||
|     } else { | ||||
|         timeLine->DrawDateViewer(); | ||||
|         timeLine->DrawTimeline(); | ||||
|         for (cChannelEpg *column = columns.First(); column; column = columns.Next(column)) { | ||||
|             column->AddNewGridsAtEnd(); | ||||
|             column->ClearOutdatedStart(); | ||||
|             column->drawGrids(); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTvGuideOsd::timeBack() { | ||||
| @@ -403,16 +410,21 @@ void cTvGuideOsd::timeBack() { | ||||
| } | ||||
|  | ||||
| void cTvGuideOsd::ScrollBack() { | ||||
|     bool tooFarInPast = timeManager->DelStep(config.stepMinutes); | ||||
|     if (tooFarInPast) | ||||
|         return; | ||||
|     timeLine->drawDateViewer(); | ||||
|     timeLine->setTimeline(); | ||||
|     timeManager->DelStep(config.stepMinutes); | ||||
|     if (config.useHWAccel) { | ||||
|         drawGridsTimeJump(); | ||||
|         timeLine->DrawDateViewer(); | ||||
|         timeLine->DrawClock(); | ||||
|         timeLine->DrawTimeline(); | ||||
|     } else { | ||||
|         timeLine->DrawDateViewer(); | ||||
|         timeLine->DrawTimeline(); | ||||
|         for (cChannelEpg *column = columns.First(); column; column = columns.Next(column)) { | ||||
|             column->AddNewGridsAtStart(); | ||||
|             column->ClearOutdatedEnd(); | ||||
|             column->drawGrids(); | ||||
|         }    | ||||
|     } | ||||
| } | ||||
|  | ||||
| void cTvGuideOsd::processKeyUp() { | ||||
| @@ -626,23 +638,19 @@ void cTvGuideOsd::processNumKey(int numKey) { | ||||
| void cTvGuideOsd::TimeJump(int mode) { | ||||
|     switch (mode) { | ||||
|         case 1: { | ||||
|             bool tooFarInPast = timeManager->DelStep(config.bigStepHours*60); | ||||
|             if (tooFarInPast) | ||||
|                 return; | ||||
|             timeManager->DelStep(((config.displayMode == eVertical) ? config.bigStepHours : config.bigStepHoursHorizontal) * 60); | ||||
|             } | ||||
|             break; | ||||
|         case 3: { | ||||
|             timeManager->AddStep(config.bigStepHours*60); | ||||
|             timeManager->AddStep(((config.displayMode == eVertical) ? config.bigStepHours : config.bigStepHoursHorizontal) * 60); | ||||
|             } | ||||
|             break; | ||||
|         case 4: { | ||||
|             bool tooFarInPast = timeManager->DelStep(config.hugeStepHours*60); | ||||
|             if (tooFarInPast) | ||||
|                 return; | ||||
|             timeManager->DelStep(((config.displayMode == eVertical) ? config.hugeStepHours : config.hugeStepHoursHorizontal) * 60); | ||||
|             } | ||||
|             break; | ||||
|         case 6: { | ||||
|             timeManager->AddStep(config.hugeStepHours*60); | ||||
|             timeManager->AddStep(((config.displayMode == eVertical) ? config.hugeStepHours : config.hugeStepHoursHorizontal) * 60); | ||||
|             } | ||||
|             break; | ||||
|         case 7: { | ||||
| @@ -664,9 +672,9 @@ void cTvGuideOsd::TimeJump(int mode) { | ||||
|             return; | ||||
|     } | ||||
|     drawGridsTimeJump(); | ||||
|     timeLine->drawDateViewer(); | ||||
|     timeLine->drawClock(); | ||||
|     timeLine->setTimeline(); | ||||
|     timeLine->DrawDateViewer(); | ||||
|     timeLine->DrawClock(); | ||||
|     timeLine->DrawTimeline(); | ||||
|     osdManager.flush(); | ||||
| } | ||||
|  | ||||
| @@ -769,13 +777,16 @@ eOSState cTvGuideOsd::ProcessKey(eKeys Key) { | ||||
|             case kYellow:   processKeyYellow(); break; | ||||
|             case kBlue:     state = processKeyBlue(&alreadyUnlocked); break; | ||||
|             case kOk:       state = processKeyOk(&alreadyUnlocked); break; | ||||
|             case kBack:     state=osEnd; break;     | ||||
|             case kBack:     state = osEnd; break;     | ||||
|             case k0 ... k9: processNumKey(Key - k0); break; | ||||
|             case kFastRew:  TimeJump(1); break; // Doesnt work, if used from timeshiftmode | ||||
|             case kFastFwd:  TimeJump(3); break; | ||||
|             case kPrev:     TimeJump(4); break; | ||||
|             case kNext:     TimeJump(6); break; | ||||
|             case kNone:     if (channelJumper) CheckTimeout(); break; | ||||
|             default:        break; | ||||
|         } | ||||
|         if (timeLine->drawClock()) { | ||||
|             timeLine->drawCurrentTimeBase(); | ||||
|         if (timeLine->DrawClock()) { | ||||
|             osdManager.flush(); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -31,7 +31,7 @@ private: | ||||
|   void drawOsd(); | ||||
|   void readChannels(const cChannel *channelStart); | ||||
|   void drawGridsChannelJump(int offset = 0); | ||||
|   void drawGridsTimeJump(); | ||||
|   void drawGridsTimeJump(bool last = false); | ||||
|   void processKeyUp(); | ||||
|   void processKeyDown(); | ||||
|   void processKeyLeft(); | ||||
|   | ||||
							
								
								
									
										4
									
								
								view.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								view.c
									
									
									
									
									
								
							| @@ -116,7 +116,7 @@ void cView::DrawHeader(void) { | ||||
|     int yDateTime = border / 2; | ||||
|     int yTitle = (headerHeight - fontHeaderLarge->Height()) / 2; | ||||
|     int ySubtitle = headerHeight - fontHeader->Height() - border / 3; | ||||
|     int textWidthMax = headerWidth - xText; | ||||
|     int textWidthMax = headerWidth - xText - border / 2; | ||||
|     pixmapHeader->DrawText(cPoint(xText, yDateTime), CutText(dateTime, textWidthMax, fontHeader).c_str(), theme.Color(clrFont), theme.Color(clrStatusHeader), fontHeader); | ||||
|     pixmapHeader->DrawText(cPoint(xText, yTitle), CutText(title, textWidthMax, fontHeaderLarge).c_str(), theme.Color(clrFont), theme.Color(clrStatusHeader), fontHeaderLarge); | ||||
|     pixmapHeader->DrawText(cPoint(xText, ySubtitle), CutText(subTitle, textWidthMax, fontHeader).c_str(), theme.Color(clrFont), theme.Color(clrStatusHeader), fontHeader); | ||||
| @@ -522,7 +522,7 @@ cEPGView::cEPGView(void) : cView() { | ||||
| } | ||||
|  | ||||
| cEPGView::~cEPGView(void) { | ||||
|     Cancel(-1); | ||||
|     Cancel(2); | ||||
|     while (Active()) | ||||
|         cCondWait::SleepMs(10); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user