Mercurial > mplayer.hg
annotate TOOLS/vivodump.c @ 2977:28bcf0ca1448
ao_mpegpes isn't really optional
author | pl |
---|---|
date | Sun, 18 Nov 2001 18:58:03 +0000 |
parents | d0f26c572633 |
children | 5a8d7b6920d6 |
rev | line source |
---|---|
2665 | 1 #include <stdio.h> |
2667 | 2 #include <stdlib.h> |
3 #include <string.h> | |
4 | |
5 #include "wine/mmreg.h" | |
6 #include "wine/avifmt.h" | |
7 #include "wine/vfw.h" | |
8 | |
9 #include "aviwrite.h" | |
2665 | 10 |
11 static const short h263_format[8][2] = { | |
12 { 0, 0 }, | |
13 { 128, 96 }, | |
14 { 176, 144 }, | |
15 { 352, 288 }, | |
16 { 704, 576 }, | |
17 { 1408, 1152 }, | |
2696 | 18 { 320, 240 } |
2665 | 19 }; |
20 | |
21 unsigned char* buffer; | |
22 int bufptr=0; | |
23 int bitcnt=0; | |
24 unsigned char buf=0; | |
25 | |
26 unsigned int x_get_bits(int n){ | |
27 unsigned int x=0; | |
28 while(n-->0){ | |
29 if(!bitcnt){ | |
30 // fill buff | |
31 buf=buffer[bufptr++]; | |
32 bitcnt=8; | |
33 } | |
34 //x=(x<<1)|(buf&1);buf>>=1; | |
35 x=(x<<1)|(buf>>7);buf<<=1; | |
36 --bitcnt; | |
37 } | |
38 return x; | |
39 } | |
40 | |
41 #define get_bits(xxx,n) x_get_bits(n) | |
42 #define get_bits1(xxx) x_get_bits(1) | |
43 #define skip_bits(xxx,n) x_get_bits(n) | |
44 #define skip_bits1(xxx) x_get_bits(1) | |
45 | |
2696 | 46 int format; |
47 int width=320; | |
48 int height=240; | |
2667 | 49 |
2665 | 50 /* most is hardcoded. should extend to handle all h263 streams */ |
51 int h263_decode_picture_header(unsigned char *b_ptr) | |
52 { | |
2696 | 53 int i; |
54 | |
55 for(i=0;i<16;i++) printf(" %02X",b_ptr[i]); printf("\n"); | |
2665 | 56 |
57 buffer=b_ptr; | |
58 bufptr=bitcnt=buf=0; | |
59 | |
60 /* picture header */ | |
2696 | 61 if (get_bits(&s->gb, 22) != 0x20){ |
62 printf("bad picture header\n"); | |
2665 | 63 return -1; |
2696 | 64 } |
2665 | 65 skip_bits(&s->gb, 8); /* picture timestamp */ |
66 | |
2696 | 67 if (get_bits1(&s->gb) != 1){ |
68 printf("bad marker\n"); | |
2665 | 69 return -1; /* marker */ |
2696 | 70 } |
71 if (get_bits1(&s->gb) != 0){ | |
72 printf("bad h263 id\n"); | |
2665 | 73 return -1; /* h263 id */ |
2696 | 74 } |
2665 | 75 skip_bits1(&s->gb); /* split screen off */ |
76 skip_bits1(&s->gb); /* camera off */ | |
77 skip_bits1(&s->gb); /* freeze picture release off */ | |
78 | |
79 format = get_bits(&s->gb, 3); | |
80 | |
81 if (format != 7) { | |
82 printf("h263_plus = 0 format = %d\n",format); | |
83 /* H.263v1 */ | |
84 width = h263_format[format][0]; | |
85 height = h263_format[format][1]; | |
86 printf("%d x %d\n",width,height); | |
2696 | 87 // if (!width) return -1; |
2665 | 88 |
89 printf("pict_type=%d\n",get_bits1(&s->gb)); | |
90 printf("unrestricted_mv=%d\n",get_bits1(&s->gb)); | |
91 #if 1 | |
92 printf("SAC: %d\n",get_bits1(&s->gb)); | |
93 printf("advanced prediction mode: %d\n",get_bits1(&s->gb)); | |
94 printf("PB frame: %d\n",get_bits1(&s->gb)); | |
95 #else | |
96 if (get_bits1(&s->gb) != 0) | |
97 return -1; /* SAC: off */ | |
98 if (get_bits1(&s->gb) != 0) | |
99 return -1; /* advanced prediction mode: off */ | |
100 if (get_bits1(&s->gb) != 0) | |
101 return -1; /* not PB frame */ | |
102 #endif | |
103 printf("qscale=%d\n",get_bits(&s->gb, 5)); | |
104 skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */ | |
105 } else { | |
106 printf("h263_plus = 1\n"); | |
107 /* H.263v2 */ | |
2696 | 108 if (get_bits(&s->gb, 3) != 1){ |
109 printf("H.263v2 A error\n"); | |
2665 | 110 return -1; |
2696 | 111 } |
112 if (get_bits(&s->gb, 3) != 6){ /* custom source format */ | |
113 printf("custom source format\n"); | |
2665 | 114 return -1; |
2696 | 115 } |
2665 | 116 skip_bits(&s->gb, 12); |
117 skip_bits(&s->gb, 3); | |
118 printf("pict_type=%d\n",get_bits(&s->gb, 3) + 1); | |
119 // if (s->pict_type != I_TYPE && | |
120 // s->pict_type != P_TYPE) | |
121 // return -1; | |
122 skip_bits(&s->gb, 7); | |
123 skip_bits(&s->gb, 4); /* aspect ratio */ | |
124 width = (get_bits(&s->gb, 9) + 1) * 4; | |
125 skip_bits1(&s->gb); | |
126 height = get_bits(&s->gb, 9) * 4; | |
127 printf("%d x %d\n",width,height); | |
2696 | 128 //if (height == 0) |
129 // return -1; | |
2665 | 130 printf("qscale=%d\n",get_bits(&s->gb, 5)); |
131 } | |
132 | |
133 /* PEI */ | |
134 while (get_bits1(&s->gb) != 0) { | |
135 skip_bits(&s->gb, 8); | |
136 } | |
137 // s->f_code = 1; | |
138 // s->width = width; | |
139 // s->height = height; | |
140 return 0; | |
141 } | |
142 | |
2667 | 143 int postable[32768]; |
2665 | 144 |
145 int main(){ | |
146 int c; | |
147 unsigned int head=-1; | |
148 int pos=0; | |
2667 | 149 int frames=0; |
2696 | 150 FILE *f=fopen("GB1.viv","rb"); |
151 FILE *f2=fopen("GB1.avi","wb"); | |
2667 | 152 aviwrite_t* avi=aviwrite_new_muxer(); |
153 aviwrite_stream_t* mux=aviwrite_new_stream(avi,AVIWRITE_TYPE_VIDEO); | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
154 //unsigned char* buffer=malloc(0x200000); |
2696 | 155 int i,len; |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
156 int v_id=0; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
157 int flag=0; |
2696 | 158 int flag2=0; |
2667 | 159 |
160 mux->buffer_size=0x200000; | |
161 mux->buffer=malloc(mux->buffer_size); | |
162 | |
163 mux->h.dwScale=1; | |
164 mux->h.dwRate=10; | |
2665 | 165 |
2667 | 166 mux->bih=malloc(sizeof(BITMAPINFOHEADER)); |
167 mux->bih->biSize=sizeof(BITMAPINFOHEADER); | |
168 mux->bih->biPlanes=1; | |
169 mux->bih->biBitCount=24; | |
170 mux->bih->biCompression=0x6f766976;// 7669766f; | |
171 aviwrite_write_header(avi,f2); | |
172 | |
2696 | 173 /* |
174 c=fgetc(f); if(c) printf("error! not vivo file?\n"); | |
175 len=0; | |
176 while((c=fgetc(f))>=0x80) len+=0x80*(c&0x0F); | |
177 len+=c; | |
178 printf("hdr1: %d\n",len); | |
179 for(i=0;i<len;i++) fgetc(f); | |
180 */ | |
181 | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
182 while((c=fgetc(f))>=0){ |
2696 | 183 |
184 // printf("%02X\n",c); | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
185 |
2696 | 186 if(c==0x00){ |
187 // header | |
188 int len=0; | |
189 while((c=fgetc(f))>=0x80) len+=0x80*(c&0x0F); | |
190 len+=c; | |
191 printf("header: 00 (%d)\n",len); | |
192 for(i=0;i<len;i++) fgetc(f); | |
193 continue; | |
194 } | |
195 | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
196 if((c&0xF0)==0x40){ |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
197 // audio |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
198 printf("audio: %02X (24)\n",c); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
199 for(i=0;i<24;i++) fgetc(f); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
200 continue; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
201 } |
2696 | 202 if((c&0xF0)==0x30){ |
203 // audio | |
204 printf("audio: %02X (40)\n",c); | |
205 for(i=0;i<40;i++) fgetc(f); | |
206 continue; | |
207 } | |
208 if(flag2 || (((c&0xF0)==0x10 || (c&0xF0)==0x20) && (c&0x0F)!=(v_id&0xF))){ | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
209 // end of frame: |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
210 printf("Frame size: %d\n",mux->buffer_len); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
211 h263_decode_picture_header(mux->buffer); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
212 aviwrite_write_chunk(avi,mux,f2,mux->buffer_len,0x10); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
213 mux->buffer_len=0; |
2696 | 214 |
215 if((v_id&0xF0)==0x10) fprintf(stderr,"hmm. last video packet %02X\n",v_id); | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
216 } |
2696 | 217 v_id=c; |
218 flag2=0; | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
219 if((c&0xF0)==0x10){ |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
220 // 128 byte |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
221 printf("video: %02X (128)\n",c); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
222 fread(mux->buffer+mux->buffer_len,128,1,f); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
223 mux->buffer_len+=128; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
224 continue; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
225 } |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
226 if((c&0xF0)==0x20){ |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
227 int len=fgetc(f); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
228 printf("video: %02X (%d)\n",c,len); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
229 fread(mux->buffer+mux->buffer_len,len,1,f); |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
230 mux->buffer_len+=len; |
2696 | 231 flag2=1; |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
232 continue; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
233 } |
2696 | 234 printf("error: %02X!\n",c); |
2665 | 235 } |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
236 |
2696 | 237 if(!width) width=320; |
238 if(!height) height=240; | |
239 | |
2672
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
240 mux->bih->biWidth=width; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
241 mux->bih->biHeight=height; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
242 mux->bih->biSizeImage=3*width*height; |
1ff47e4ff44d
works! copy video steram to .avi file playable with ivvideo.dll
arpi
parents:
2667
diff
changeset
|
243 |
2667 | 244 aviwrite_write_index(avi,f2); |
245 fseek(f2,0,SEEK_SET); | |
246 aviwrite_write_header(avi,f2); | |
247 | |
248 } |