]> git.vomp.tv Git - vompclient.git/blob - video.h
Windows port
[vompclient.git] / video.h
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #ifndef VIDEO_H
22 #define VIDEO_H
23
24 #include <stdio.h>
25 #include "defines.h"
26
27 class Video
28 {
29   public:
30     Video();
31     virtual ~Video();
32     static Video* getInstance();
33
34     virtual int init(UCHAR format)=0;
35     virtual int shutdown()=0;
36     virtual int setFormat(UCHAR format)=0;
37     virtual int setConnection(UCHAR connection)=0;
38     virtual int setAspectRatio(UCHAR aspectRatio)=0;   // This one does the pin 8 scart widescreen switching
39     virtual int setMode(UCHAR mode)=0;
40     virtual int setTVsize(UCHAR size)=0;               // Is the TV a widescreen?
41     virtual int setDefaultAspect()=0;
42     virtual int setSource()=0;
43     virtual int setPosition(int x, int y)=0;
44     virtual int sync()=0;
45     virtual int play()=0;
46     virtual int stop()=0;
47     virtual int pause()=0;
48     virtual int unPause()=0;
49     virtual int fastForward()=0;
50     virtual int unFastForward()=0;
51     virtual int reset()=0;
52     virtual int blank()=0;
53     virtual int signalOn()=0;
54     virtual int signalOff()=0;
55     virtual int attachFrameBuffer()=0; // What does this do?
56     virtual ULONG timecodeToFrameNumber(ULLONG timecode)=0;
57     virtual int getFD()=0;
58     virtual ULLONG getCurrentTimestamp()=0;
59
60 #ifdef DEV
61     virtual int test() { return 0; }
62     virtual int test2() { return 0; }
63 #endif
64
65     int getMode()           { return mode; }
66     UCHAR getFormat()       { return format; }
67     UINT getScreenWidth()   { return screenWidth; }
68     UINT getScreenHeight()  { return screenHeight; }
69     UCHAR getTVsize()       { return tvsize; }
70
71     // Video formats - AV_SET_VID_DISP_FMT
72     const static UCHAR NTSC = 0;
73     const static UCHAR PAL = 1;
74
75     // Video connections - AV_SET_VID_OUTPUT
76     const static UCHAR COMPOSITERGB = 1;
77     const static UCHAR SVIDEO = 2;
78
79     // Video aspect ratios - AV_SET_VID_RATIO
80     const static UCHAR ASPECT4X3 = 0;
81     const static UCHAR ASPECT16X9 = 1;
82
83     // Video modes - AV_SET_VID_MODE
84     const static UCHAR NORMAL = 0;
85     const static UCHAR LETTERBOX = 1;
86 /*
87     Actual Source Aspect      Aspect IOCTL       Mode IOCTL       MODE A            MODE B
88
89           4:3                     4:3             NORMAL          fullframe43       fullframe43
90           4:3                     16:9            NORMAL          fullframe43       fullframe43      -- invalid?
91           4:3                     4:3             LETTERBOX       fullframe43       fullframe43
92           4:3                     16:9            LETTERBOX       fullframe43       fullframe43      -- invalid?
93           16:9                    4:3             NORMAL          chop sides        fullframe169
94           16:9                    16:9            NORMAL          chop sides        fullframe169
95           16:9                    4:3             LETTERBOX       letterbox         letterbox
96           16:9                    16:9            LETTERBOX       chop sides        fullframe169
97
98     Conclusions
99
100     1. There are two chip modes - accessible by reopening the fd
101     2. The video chip knows the aspect ratio purely from the incoming MPEG
102     3. MODE A is for 4:3 TVs, MODE B is for 16:9 TVs
103
104     To switch to MODE A, set the aspect ioctl to 4:3 and reopen the FD.
105     To switch to MODE B, set the aspect ioctl to 16:9 and reopen the FD.
106 */
107
108     const static UCHAR UNKNOWN2 = 2;
109     const static UCHAR QUARTER = 3;
110     const static UCHAR EIGHTH = 4;
111     const static UCHAR ZOOM = 5;
112     const static UCHAR UNKNOWN6 = 6;
113
114   protected:
115     static Video* instance;
116     int initted;
117     int fdVideo;
118
119     UCHAR tvsize;
120     UCHAR format;
121     UCHAR connection;
122     UCHAR aspectRatio;
123     UCHAR mode;
124
125     UINT screenWidth;
126     UINT screenHeight;
127 };
128
129 #endif