diff options
author | Klaus Schmidinger <kls (at) cadsoft (dot) de> | 2009-05-03 17:15:00 +0200 |
---|---|---|
committer | Klaus Schmidinger <kls (at) cadsoft (dot) de> | 2009-05-03 17:15:00 +0200 |
commit | 991eda006700f1703bcec528c1ff178a4cab9048 (patch) | |
tree | 11f216938606e63027bc717e3d36668df646f474 /osd.c | |
parent | 733a2becc44a02daf10b97d24b8a9c8b00de3964 (diff) | |
download | vdr-patch-lnbsharing-991eda006700f1703bcec528c1ff178a4cab9048.tar.gz vdr-patch-lnbsharing-991eda006700f1703bcec528c1ff178a4cab9048.tar.bz2 |
Version 1.7.7vdr-1.7.7
- The new function cDevice::GetVideoSize() returns the size and aspect ratio
of the video material currently displayed. This function is used to determine
the proper size of the OSD. Plugin authors should implement this function in
classes derived from cDevice, if they are able to replay video.
- The OSD and font sizes are now defined in percent of the actual video display
size. The maximum OSD size has been raised to 1920x1080, to allow full
screen OSD on HD systems.
- The OSD size is now automatically adjusted to the actual video display
(provided the output device implements the GetVideoSize() function).
- cFrameDetector::Analyze() now syncs on the TS packet sync bytes (thanks to
Oliver Endriss for reporting broken index generation after a buffer overflow).
Diffstat (limited to 'osd.c')
-rw-r--r-- | osd.c | 30 |
1 files changed, 29 insertions, 1 deletions
@@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: osd.c 2.2 2009/04/05 10:17:25 kls Exp $ + * $Id: osd.c 2.3 2009/05/03 13:52:47 kls Exp $ */ #include "osd.h" @@ -14,6 +14,7 @@ #include <sys/ioctl.h> #include <sys/stat.h> #include <sys/unistd.h> +#include "device.h" #include "tools.h" // --- cPalette -------------------------------------------------------------- @@ -880,6 +881,9 @@ void cOsd::Flush(void) // --- cOsdProvider ---------------------------------------------------------- cOsdProvider *cOsdProvider::osdProvider = NULL; +int cOsdProvider::oldWidth = 0; +int cOsdProvider::oldHeight = 0; +int cOsdProvider::oldAspect = va4_3; cOsdProvider::cOsdProvider(void) { @@ -911,6 +915,30 @@ cOsd *cOsdProvider::NewOsd(int Left, int Top, uint Level) return new cOsd(Left, Top, 999); // create a dummy cOsd, so that access won't result in a segfault } +void cOsdProvider::UpdateOsdSize(bool Force) +{ + int Width; + int Height; + eVideoAspect Aspect; + cDevice::PrimaryDevice()->GetVideoSize(Width, Height, Aspect); + if (Width != oldWidth || Height != oldHeight || Aspect != oldAspect || Force) { + Setup.OSDLeft = int(round(Width * Setup.OSDLeftP)); + Setup.OSDTop = int(round(Height * Setup.OSDTopP)); + Setup.OSDWidth = int(round(Width * Setup.OSDWidthP)) & ~0x07; // OSD width must be a multiple of 8 + Setup.OSDHeight = int(round(Height * Setup.OSDHeightP)); + Setup.FontOsdSize = int(round(Height * Setup.FontOsdSizeP)); + Setup.FontFixSize = int(round(Height * Setup.FontFixSizeP)); + Setup.FontSmlSize = int(round(Height * Setup.FontSmlSizeP)); + cFont::SetFont(fontOsd, Setup.FontOsd, Setup.FontOsdSize); + cFont::SetFont(fontFix, Setup.FontFix, Setup.FontFixSize); + cFont::SetFont(fontSml, Setup.FontSml, Setup.FontSmlSize); + oldWidth = Width; + oldHeight = Height; + oldAspect = Aspect; + dsyslog("OSD size changed to %dx%d @ %s", Width, Height, VideoAspectString[Aspect]); + } +} + void cOsdProvider::Shutdown(void) { delete osdProvider; |