diff options
Diffstat (limited to 'setup-image.c')
-rw-r--r-- | setup-image.c | 125 |
1 files changed, 89 insertions, 36 deletions
diff --git a/setup-image.c b/setup-image.c index 8cf05d0..4f523b1 100644 --- a/setup-image.c +++ b/setup-image.c @@ -1,8 +1,8 @@ /* * Image plugin to VDR (C++) * - * (C) 2004 Andreas Brachold <vdr04-at-deltab.de> - * (C) 2003 Kai Tobias Burwieck <kai-at-burwieck.net> + * (C) 2004-2005 Andreas Brachold <vdr04-at-deltab.de> + * based on (C) 2003 Kai Tobias Burwieck <kai-at-burwieck.net> * * based on MP3/MPlayer plugin to VDR (C++) * (C) 2001,2002 Stefan Huelswitt <huels-at-iname.com> @@ -37,44 +37,62 @@ cImageSetup ImageSetup; const int cImageSetup::m_cSSMin = 2; const int cImageSetup::m_cSSMax = 300; + +const int cImageSetup::m_cnMinBorderHeight = 0; +const int cImageSetup::m_cnMaxBorderHeight = 480/2; //(Half NTSC) + +const int cImageSetup::m_cnMinBorderWidth = 0; +const int cImageSetup::m_cnMaxBorderWidth = 720/2; //(Half NTSC/PAL) + // --- cImageSetup ----------------------------------------------------------- cImageSetup::cImageSetup(void) { - SlideShow = 0; - SSsec = 10; - strncpy(TempDir, "/tmp/image", sizeof(TempDir)); + m_bSlideShow = 0; + m_nSSsec = 10; + strncpy(m_szTempDir, "/tmp/image", sizeof(m_szTempDir)); #if VDRVERSNUM < 10307 - ShowDate = 1; + m_bShowDate = 1; #endif - AutoRepeat = 0; - ShowNumbers = 1; + m_bAutoRepeat = 0; + m_bShowNumbers = 1; #if VDRVERSNUM >= 10308 m_bLiveAudio = 0; #endif m_bHousekeeping = 1; + + m_nBorderHeight = 16; + m_nBorderWidth = 16; } +#define ParseInteger(szTitle,nValue,nMin,nMax) \ + if(!strcasecmp(szName, szTitle)) \ + { \ + nValue = atoi(szValue); \ + if(nValue < nMin) nValue = nMin; \ + if(nValue > nMax) nValue = nMax; \ + } + + bool cImageSetup::SetupParse(const char *szName, const char *szValue) { - if(!strcasecmp(szName, "SlideShow")) SlideShow = atoi(szValue); - else if(!strcasecmp(szName, "SSsec")) - { - SSsec = atoi(szValue); - if(SSsec < m_cSSMin) SSsec = cImageSetup::m_cSSMin; - if(SSsec > m_cSSMax) SSsec = cImageSetup::m_cSSMax; - } - else if(!strcasecmp(szName, "TempDir")) strn0cpy(TempDir,szValue,sizeof(TempDir)); + ParseInteger("SlideShow", m_bSlideShow,0,1) + else ParseInteger("SSsec", m_nSSsec,m_cSSMin,m_cSSMax) + else ParseInteger("BorderHeight", m_nBorderHeight,m_cnMinBorderHeight,m_cnMaxBorderHeight) + else ParseInteger("BorderWidth", m_nBorderWidth,m_cnMinBorderWidth,m_cnMaxBorderWidth) #if VDRVERSNUM < 10307 - else if(!strcasecmp(szName, "ShowDate")) ShowDate = atoi(szValue); + else ParseInteger("ShowDate", m_bShowDate,0,1) #endif - else if(!strcasecmp(szName, "AutoRepeat")) AutoRepeat = atoi(szValue); - else if(!strcasecmp(szName, "ShowNumbers")) ShowNumbers = atoi(szValue); + else ParseInteger("AutoRepeat", m_bAutoRepeat,0,1) + else ParseInteger("ShowNumbers", m_bShowNumbers,0,1) #if VDRVERSNUM >= 10308 - else if(!strcasecmp(szName, "LiveAudio")) m_bLiveAudio = atoi(szValue); + else ParseInteger("LiveAudio", m_bLiveAudio,0,1) #endif - else if(!strcasecmp(szName, "Housekeeping")) m_bHousekeeping = atoi(szValue); + else ParseInteger("Housekeeping", m_bHousekeeping,0,1) + else if(!strcasecmp(szName, "TempDir")) { + strn0cpy(m_szTempDir,szValue,sizeof(m_szTempDir)); + } else return false; return true; } @@ -83,36 +101,71 @@ bool cImageSetup::SetupParse(const char *szName, const char *szValue) void cMenuSetupImage::Store(void) { ImageSetup = m_tmpSetup; - SetupStore("SlideShow", ImageSetup.SlideShow); - SetupStore("SSsec", ImageSetup.SSsec); - SetupStore("TempDir", ImageSetup.TempDir); + SetupStore("SlideShow", ImageSetup.m_bSlideShow); + SetupStore("SSsec", ImageSetup.m_nSSsec); + SetupStore("TempDir", ImageSetup.m_szTempDir); #if VDRVERSNUM < 10307 - SetupStore("ShowDate", ImageSetup.ShowDate); + SetupStore("ShowDate", ImageSetup.m_bShowDate); #endif - SetupStore("AutoRepeat", ImageSetup.AutoRepeat); - SetupStore("ShowNumbers", ImageSetup.ShowNumbers); + SetupStore("AutoRepeat", ImageSetup.m_bAutoRepeat); + SetupStore("ShowNumbers", ImageSetup.m_bShowNumbers); #if VDRVERSNUM >= 10308 SetupStore("LiveAudio", ImageSetup.m_bLiveAudio); #endif SetupStore("Housekeeping", ImageSetup.m_bHousekeeping); + SetupStore("BorderHeight", ImageSetup.m_nBorderHeight); + SetupStore("BorderWidth", ImageSetup.m_nBorderWidth); } cMenuSetupImage::cMenuSetupImage(void) : m_tmpSetup(ImageSetup) { SetSection(tr("Image")); - Add(new cMenuEditBoolItem(tr("SlideShow ?"), &m_tmpSetup.SlideShow, tr("no"), tr("yes"))); - Add(new cMenuEditIntItem (tr("Slide duration (sec)"), &m_tmpSetup.SSsec, cImageSetup::m_cSSMin, cImageSetup::m_cSSMax)); - Add(new cMenuEditBoolItem(tr("Repeat SlideShow"), &m_tmpSetup.AutoRepeat, tr("no"), tr("yes"))); + + Add(new cMenuEditBoolItem(tr("SlideShow ?"), + &m_tmpSetup.m_bSlideShow, + tr("no"), tr("yes"))); + + Add(new cMenuEditIntItem (tr("Slide duration (sec)"), + &m_tmpSetup.m_nSSsec, + cImageSetup::m_cSSMin, cImageSetup::m_cSSMax)); + + Add(new cMenuEditBoolItem(tr("Repeat SlideShow"), + &m_tmpSetup.m_bAutoRepeat, + tr("no"), tr("yes"))); + #if VDRVERSNUM < 10307 - Add(new cMenuEditBoolItem(tr("Show Filedate on OSD"), &m_tmpSetup.ShowDate, tr("no"), tr("yes"))); + Add(new cMenuEditBoolItem(tr("Show Filedate on OSD"), + &m_tmpSetup.m_bShowDate, + tr("no"), tr("yes"))); #endif - Add(new cMenuEditBoolItem(tr("Show Numbers on index image"), &m_tmpSetup.ShowNumbers, tr("no"), tr("yes"))); + + Add(new cMenuEditBoolItem(tr("Show Numbers on index image"), + &m_tmpSetup.m_bShowNumbers, + tr("no"), tr("yes"))); + #if VDRVERSNUM >= 10308 - Add(new cMenuEditBoolItem(tr("Live Audio from primary Device"), &m_tmpSetup.m_bLiveAudio, tr("no"), tr("yes"))); + Add(new cMenuEditBoolItem(tr("Live Audio from primary Device"), + &m_tmpSetup.m_bLiveAudio, + tr("no"), tr("yes"))); #endif - Add(new cMenuEditStrItem (tr("Directory with temporary files"), m_tmpSetup.TempDir,sizeof(m_tmpSetup.TempDir), "abcdefghijklmopqrstuvwxyz/-")); - Add(new cMenuEditBoolItem(tr("Remove temporary files"), &m_tmpSetup.m_bHousekeeping, tr("no"), tr("yes"))); + + Add(new cMenuEditStrItem (tr("Directory with temporary files"), + m_tmpSetup.m_szTempDir,sizeof(m_tmpSetup.m_szTempDir), + "abcdefghijklmopqrstuvwxyz/-")); + + Add(new cMenuEditBoolItem(tr("Remove temporary files"), + &m_tmpSetup.m_bHousekeeping, + tr("no"), tr("yes"))); + + Add(new cMenuEditIntItem (tr("Border for Underscan (Height)"), + &m_tmpSetup.m_nBorderHeight, + cImageSetup::m_cnMinBorderHeight, cImageSetup::m_cnMaxBorderHeight)); + + Add(new cMenuEditIntItem (tr("Border for Underscan (Width)"), + &m_tmpSetup.m_nBorderWidth, + cImageSetup::m_cnMinBorderWidth, cImageSetup::m_cnMaxBorderWidth)); + } @@ -128,7 +181,7 @@ void cImageSetup::SetEnv(void) const } nEnvironTable [] = { {"ASPECT_RATIO",Setup.VideoFormat?"16:9":"4:3"}, // Get from DVB-Setup - {"CONVERT_TEMPDIR",TempDir}, + {"CONVERT_TEMPDIR",m_szTempDir}, }; for(i=0;i < sizeof(nEnvironTable)/sizeof(*nEnvironTable);++i) |