summaryrefslogtreecommitdiff
path: root/dvbapi.c
diff options
context:
space:
mode:
authorKlaus Schmidinger <vdr@tvdr.de>2000-03-11 11:22:37 +0100
committerKlaus Schmidinger <vdr@tvdr.de>2000-03-11 11:22:37 +0100
commit571686d90996968c01a8bc560659e364efab2942 (patch)
tree85cf564cd0f48e44431a93ea2f22bba7fc924e98 /dvbapi.c
parent4a9d9c5876cde9f21ccd165a7630727e6aca576a (diff)
downloadvdr-0.0.2.tar.gz
vdr-0.0.2.tar.bz2
Menu uses colors; support for RGYB buttons; fixed DEBUG_REMOTE; Add, Del and Move for channels and timers; basic record/play file handling0.0.2
Diffstat (limited to 'dvbapi.c')
-rw-r--r--dvbapi.c168
1 files changed, 143 insertions, 25 deletions
diff --git a/dvbapi.c b/dvbapi.c
index 5597fbd5..484a22e5 100644
--- a/dvbapi.c
+++ b/dvbapi.c
@@ -4,20 +4,14 @@
* See the main source file 'osm.c' for copyright information and
* how to reach the author.
*
- * $Id: dvbapi.c 1.1 2000/02/19 13:36:48 kls Exp $
+ * $Id: dvbapi.c 1.2 2000/03/11 10:39:09 kls Exp $
*/
-// FIXME: these should be defined in ../DVB/driver/dvb.h!!!
-typedef unsigned int u32;
-typedef unsigned short u16;
-typedef unsigned char u8;
-
#include "dvbapi.h"
#include <fcntl.h>
#include <stdio.h>
#include <sys/ioctl.h>
#include <unistd.h>
-#include "../DVB/driver/dvb.h"
#include "interface.h"
#include "tools.h"
@@ -60,6 +54,7 @@ bool DvbSetChannel(int FrequencyMHz, char Polarization, int Diseqc, int Srate, i
cDvbRecorder::cDvbRecorder(void)
{
+ recording = false;
}
cDvbRecorder::~cDvbRecorder()
@@ -67,18 +62,41 @@ cDvbRecorder::~cDvbRecorder()
Stop();
}
+bool cDvbRecorder::Recording(void)
+{
+ return recording;
+}
+
bool cDvbRecorder::Record(const char *FileName, char Quality)
{
isyslog(LOG_INFO, "record %s (%c)", FileName, Quality);
- return true;
+ if (MakeDirs(FileName)) {
+ FILE *f = fopen(FileName, "a");
+ if (f) {
+ fprintf(f, "%s, %c\n", FileName, Quality);
+ fclose(f);
+ recording = true;
+ // TODO
+ Interface.Error("Recording not yet implemented!");
+ return true;
+ }
+ else {
+ Interface.Error("Can't write to file!");
+ return false;
+ }
+ }
// TODO
return false;
}
bool cDvbRecorder::Play(const char *FileName, int Frame)
{
- isyslog(LOG_INFO, "play %s (%d)", FileName, Frame);
- // TODO
+ if (!recording) {
+ isyslog(LOG_INFO, "play %s (%d)", FileName, Frame);
+ // TODO
+ Interface.Error("Playback not yet implemented!");
+ return true;
+ }
return false;
}
@@ -106,6 +124,7 @@ bool cDvbRecorder::Pause(void)
void cDvbRecorder::Stop(void)
{
isyslog(LOG_INFO, "stop");
+ recording = false;
// TODO
}
@@ -116,9 +135,57 @@ int cDvbRecorder::Frame(void)
return 0;
}
-// ---------------------------------------------------------------------------
+// --- cDvbOsd ---------------------------------------------------------------
-static void DvbOsdCmd(OSD_Command cmd, int color = 0, int x0 = 0, int y0 = 0, int x1 = 0, int y1 = 0, void *data = NULL)
+cDvbOsd::cDvbOsd(void)
+{
+ cols = rows = 0;
+#ifdef DEBUG_OSD
+ memset(&colorPairs, 0, sizeof(colorPairs));
+ initscr();
+ start_color();
+ keypad(stdscr, TRUE);
+ nonl();
+ cbreak();
+ noecho();
+ timeout(1000);
+ leaveok(stdscr, TRUE);
+ window = stdscr;
+#endif
+#ifdef DEBUG_REMOTE
+ initscr();
+ keypad(stdscr, TRUE);
+ nonl();
+ cbreak();
+ noecho();
+ timeout(1000);
+#endif
+}
+
+cDvbOsd::~cDvbOsd()
+{
+ Close();
+}
+
+#ifdef DEBUG_OSD
+void cDvbOsd::SetColor(eDvbColor colorFg, eDvbColor colorBg)
+{
+ int color = (colorBg << 16) | colorFg | 0x80000000;
+ for (int i = 0; i < MaxColorPairs; i++) {
+ if (!colorPairs[i]) {
+ colorPairs[i] = color;
+ init_pair(i + 1, colorFg, colorBg);
+ wattrset(window, COLOR_PAIR(i + 1));
+ break;
+ }
+ else if (color == colorPairs[i]) {
+ wattrset(window, COLOR_PAIR(i + 1));
+ break;
+ }
+ }
+}
+#else
+void cDvbOsd::Cmd(OSD_Command cmd, int color, int x0, int y0, int x1, int y1, const void *data)
{
int v = open(VIDEODEVICE, O_RDWR);
@@ -130,37 +197,88 @@ static void DvbOsdCmd(OSD_Command cmd, int color = 0, int x0 = 0, int y0 = 0, in
dc.y0 = y0;
dc.x1 = x1;
dc.y1 = y1;
- dc.data = data;
+ dc.data = (void *)data;
ioctl(v, VIDIOCSOSDCOMMAND, &dc);
close(v);
}
else
Interface.Error("can't open VIDEODEVICE");//XXX
}
+#endif
+
+void cDvbOsd::Open(int w, int h)
+{
+ cols = w;
+ rows = h;
+#ifdef DEBUG_OSD
+ //XXX size...
+ #define B2C(b) (((b) * 1000) / 255)
+ #define SETCOLOR(n, r, g, b, o) init_color(n, B2C(r), B2C(g), B2C(b))
+#else
+ w *= charWidth;
+ h *= lineHeight;
+ int x = (720 - w) / 2; //TODO PAL vs. NTSC???
+ int y = (576 - h) / 2;
+ Cmd(OSD_Open, 4, x, y, x + w - 1, y + h - 1);
+ #define SETCOLOR(n, r, g, b, o) Cmd(OSD_SetColor, n, r, g, b, o)
+#endif
+ SETCOLOR(clrBackground, 0x00, 0x00, 0x00, 127); // background 50% gray
+ SETCOLOR(clrBlack, 0x00, 0x00, 0x00, 255);
+ SETCOLOR(clrRed, 0xFC, 0x14, 0x14, 255);
+ SETCOLOR(clrGreen, 0x24, 0xFC, 0x24, 255);
+ SETCOLOR(clrYellow, 0xFC, 0xC0, 0x24, 255);
+ SETCOLOR(clrBlue, 0x00, 0x00, 0xFC, 255);
+ SETCOLOR(clrCyan, 0x00, 0xFC, 0xFC, 255);
+ SETCOLOR(clrMagenta, 0xB0, 0x00, 0xFC, 255);
+ SETCOLOR(clrWhite, 0xFC, 0xFC, 0xFC, 255);
+}
-void DvbOsdOpen(int x, int y, int w, int h)
+void cDvbOsd::Close(void)
{
- DvbOsdCmd(OSD_Open, 1, x, y, x + w - 1, y + h - 1);
- DvbOsdCmd(OSD_SetColor, 0, 0, 0, 0, 127); // background 50% gray
- DvbOsdCmd(OSD_SetColor, 1, 255, 255, 255, 255); // text white
+#ifndef DEBUG_OSD
+ Cmd(OSD_Close);
+#endif
}
-void DvbOsdClose(void)
+void cDvbOsd::Clear(void)
{
- DvbOsdCmd(OSD_Close);
+#ifdef DEBUG_OSD
+ SetColor(clrBackground, clrBackground);
+ Fill(0, 0, cols, rows, clrBackground);
+#else
+ Cmd(OSD_Clear);
+#endif
}
-void DvbOsdClear(void)
+void cDvbOsd::Fill(int x, int y, int w, int h, eDvbColor color)
{
- DvbOsdCmd(OSD_Clear);
+ if (x < 0) x = cols + x;
+ if (y < 0) y = rows + y;
+#ifdef DEBUG_OSD
+ SetColor(color, color);
+ for (int r = 0; r < h; r++) {
+ wmove(window, y + r, x); // ncurses wants 'y' before 'x'!
+ whline(window, ' ', w);
+ }
+#else
+ Cmd(OSD_FillBlock, color, x * charWidth, y * lineHeight, (x + w) * charWidth - 1, (y + h) * lineHeight - 1);
+#endif
}
-void DvbOsdClrEol(int x, int y)
+void cDvbOsd::ClrEol(int x, int y, eDvbColor color)
{
- DvbOsdCmd(OSD_FillBlock, 0, x, y * DvbOsdLineHeight, x + 490, (y + 1) * DvbOsdLineHeight);//XXX
+ Fill(x, y, cols - x, 1, color);
}
-void DvbOsdText(int x, int y, char *s)
+void cDvbOsd::Text(int x, int y, const char *s, eDvbColor colorFg, eDvbColor colorBg)
{
- DvbOsdCmd(OSD_Text, 1, x, y, 1, 0, s);
+ if (x < 0) x = cols + x;
+ if (y < 0) y = rows + y;
+#ifdef DEBUG_OSD
+ SetColor(colorFg, colorBg);
+ wmove(window, y, x); // ncurses wants 'y' before 'x'!
+ waddstr(window, s);
+#else
+ Cmd(OSD_Text, (int(colorBg) << 16) | colorFg, x * charWidth, y * lineHeight, 1, 0, s);
+#endif
}