annotate libmpdemux/aviwrite.c @ 6969:be2505036de1

New noise filter by Jindrich Makovicka. Reformatted the paragraph because its column layout completely broke in 80 character displays.
author diego
date Sun, 11 Aug 2002 13:37:35 +0000
parents 62ac2cac100d
children 4f912998013e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
587
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
1
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
2 #include <stdio.h>
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
3 #include <stdlib.h>
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
4 #include <string.h>
5572
8cd761968f35 BSD-BT848 TV update patch by Charles Henrich <henrich@sigbus.com>
arpi
parents: 2652
diff changeset
5 #include <sys/types.h>
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
6
2555
66837325b929 config.h cleanup, few things added to steram/demuxer headers
arpi
parents: 2529
diff changeset
7 #include "config.h"
66837325b929 config.h cleanup, few things added to steram/demuxer headers
arpi
parents: 2529
diff changeset
8
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
9 //#include "stream.h"
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
10 //#include "demuxer.h"
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
11 //#include "stheader.h"
587
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
12
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
13 #include "wine/mmreg.h"
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
14 #include "wine/avifmt.h"
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
15 #include "wine/vfw.h"
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
16 #include "bswap.h"
587
8511095c5283 stage#1 completed: c files no more included from mplayer.c
arpi_esp
parents: 1
diff changeset
17
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
18 #include "aviwrite.h"
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
19 #include "aviheader.h"
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
20
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
21 aviwrite_stream_t* aviwrite_new_stream(aviwrite_t *muxer,int type){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
22 aviwrite_stream_t* s;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
23 if(muxer->avih.dwStreams>=AVIWRITE_MAX_STREAMS){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
24 printf("Too many streams! increase AVIWRITE_MAX_STREAMS !\n");
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
25 return NULL;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
26 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
27 s=malloc(sizeof(aviwrite_stream_t));
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
28 memset(s,0,sizeof(aviwrite_stream_t));
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
29 if(!s) return NULL; // no mem!?
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
30 muxer->streams[muxer->avih.dwStreams]=s;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
31 s->type=type;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
32 s->id=muxer->avih.dwStreams;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
33 s->timer=0.0;
2652
fd279f14b9ab new stream field: size
arpi
parents: 2635
diff changeset
34 s->size=0;
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
35 switch(type){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
36 case AVIWRITE_TYPE_VIDEO:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
37 s->ckid=mmioFOURCC(('0'+s->id/10),('0'+(s->id%10)),'d','c');
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
38 s->h.fccType=streamtypeVIDEO;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
39 if(!muxer->def_v) muxer->def_v=s;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
40 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
41 case AVIWRITE_TYPE_AUDIO:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
42 s->ckid=mmioFOURCC(('0'+s->id/10),('0'+(s->id%10)),'w','b');
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
43 s->h.fccType=streamtypeAUDIO;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
44 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
45 default:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
46 printf("WarninG! unknown stream type: %d\n",type);
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
47 return NULL;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
48 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
49 muxer->avih.dwStreams++;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
50 return s;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
51 }
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
52
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
53 aviwrite_t* aviwrite_new_muxer(){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
54 aviwrite_t* muxer=malloc(sizeof(aviwrite_t));
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
55 memset(muxer,0,sizeof(aviwrite_t));
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
56 return muxer;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
57 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
58
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
59 static void write_avi_chunk(FILE *f,unsigned int id,int len,void* data){
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
60 int le_len = le2me_32(len);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
61 int le_id = le2me_32(id);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
62 fwrite(&le_id,4,1,f);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
63 fwrite(&le_len,4,1,f);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
64
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
65 if(len>0){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
66 if(data){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
67 // DATA
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
68 fwrite(data,len,1,f);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
69 if(len&1){ // padding
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
70 unsigned char zerobyte=0;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
71 fwrite(&zerobyte,1,1,f);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
72 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
73 } else {
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
74 // JUNK
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
75 char *avi_junk_data="[= MPlayer junk data! =]";
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
76 if(len&1) ++len; // padding
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
77 while(len>0){
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
78 int l=strlen(avi_junk_data);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
79 if(l>len) l=len;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
80 fwrite(avi_junk_data,l,1,f);
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
81 len-=l;
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
82 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
83 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
84 }
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
85 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
86
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
87 void aviwrite_write_chunk(aviwrite_t *muxer,aviwrite_stream_t *s, FILE *f,int len,unsigned int flags){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
88
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
89 // add to the index:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
90 if(muxer->idx_pos>=muxer->idx_size){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
91 muxer->idx_size+=256; // 4kB
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
92 muxer->idx=realloc(muxer->idx,16*muxer->idx_size);
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
93 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
94 muxer->idx[muxer->idx_pos].ckid=s->ckid;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
95 muxer->idx[muxer->idx_pos].dwFlags=flags; // keyframe?
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
96 muxer->idx[muxer->idx_pos].dwChunkOffset=ftell(f)-(muxer->movi_start-4);
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
97 muxer->idx[muxer->idx_pos].dwChunkLength=len;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
98 ++muxer->idx_pos;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
99
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
100 // write out the chunk:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
101 write_avi_chunk(f,s->ckid,len,s->buffer); /* unsigned char */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
102
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
103 // alter counters:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
104 if(s->h.dwSampleSize){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
105 // CBR
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
106 s->h.dwLength+=len/s->h.dwSampleSize;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
107 if(len%s->h.dwSampleSize) printf("Warning! len isn't divisable by samplesize!\n");
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
108 } else {
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
109 // VBR
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
110 s->h.dwLength++;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
111 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
112 s->timer=(double)s->h.dwLength*s->h.dwScale/s->h.dwRate;
2652
fd279f14b9ab new stream field: size
arpi
parents: 2635
diff changeset
113 s->size+=len;
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
114 if(len>s->h.dwSuggestedBufferSize) s->h.dwSuggestedBufferSize=len;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
115
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
116 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
117
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
118 static void write_avi_list(FILE *f,unsigned int id,int len){
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
119 unsigned int list_id=FOURCC_LIST;
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
120 int le_len;
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
121 int le_id;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
122 len+=4; // list fix
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
123 list_id = le2me_32(list_id);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
124 le_len = le2me_32(len);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
125 le_id = le2me_32(id);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
126 fwrite(&list_id,4,1,f);
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
127 fwrite(&le_len,4,1,f);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
128 fwrite(&le_id,4,1,f);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
129 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
130
2635
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
131 // muxer->streams[i]->wf->cbSize
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
132 #define WFSIZE(wf) (sizeof(WAVEFORMATEX)+(((wf)->cbSize)?((wf)->cbSize-2):0))
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
133
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
134 void aviwrite_write_header(aviwrite_t *muxer,FILE *f){
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
135 unsigned int riff[3];
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
136 int i;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
137 unsigned int hdrsize;
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
138 // RIFF header:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
139 #ifdef WORDS_BIGENDIAN
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
140 /* FIXME: updating the header on big-endian causes the video
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
141 * to be unreadable ("AVI_NI: No video stream found!").
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
142 * Just don't update it (no seeking, not playable with WMP,
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
143 * but better than nothing)
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
144 */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
145 if(muxer->file_end != 0)
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
146 return;
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
147 #endif
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
148 riff[0]=mmioFOURCC('R','I','F','F');
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
149 riff[1]=muxer->file_end; // filesize
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
150 riff[2]=formtypeAVI; // 'AVI '
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
151 riff[0]=le2me_32(riff[0]);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
152 riff[1]=le2me_32(riff[1]);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
153 riff[2]=le2me_32(riff[2]);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
154 fwrite(&riff,12,1,f);
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
155 // update AVI header:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
156 if(muxer->def_v){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
157 muxer->avih.dwMicroSecPerFrame=1000000.0*muxer->def_v->h.dwScale/muxer->def_v->h.dwRate;
2635
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
158 // muxer->avih.dwMaxBytesPerSec=1000000; // dummy!!!!! FIXME
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
159 // muxer->avih.dwPaddingGranularity=2; // ???
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
160 muxer->avih.dwFlags|=AVIF_ISINTERLEAVED|AVIF_TRUSTCKTYPE;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
161 muxer->avih.dwTotalFrames=muxer->def_v->h.dwLength;
2635
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
162 // muxer->avih.dwSuggestedBufferSize=muxer->def_v->h.dwSuggestedBufferSize;
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
163 muxer->avih.dwWidth=muxer->def_v->bih->biWidth;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
164 muxer->avih.dwHeight=muxer->def_v->bih->biHeight;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
165 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
166
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
167 // AVI header:
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
168 hdrsize=sizeof(muxer->avih)+8;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
169 // calc total header size:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
170 for(i=0;i<muxer->avih.dwStreams;i++){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
171 hdrsize+=12; // LIST
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
172 hdrsize+=sizeof(muxer->streams[i]->h)+8; // strh
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
173 switch(muxer->streams[i]->type){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
174 case AVIWRITE_TYPE_VIDEO:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
175 hdrsize+=muxer->streams[i]->bih->biSize+8; // strf
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
176 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
177 case AVIWRITE_TYPE_AUDIO:
2635
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
178 hdrsize+=WFSIZE(muxer->streams[i]->wf)+8; // strf
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
179 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
180 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
181 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
182 write_avi_list(f,listtypeAVIHEADER,hdrsize);
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
183
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
184 le2me_MainAVIHeader(&muxer->avih);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
185 write_avi_chunk(f,ckidAVIMAINHDR,sizeof(muxer->avih),&muxer->avih); /* MainAVIHeader */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
186 le2me_MainAVIHeader(&muxer->avih);
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
187
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
188 // stream headers:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
189 for(i=0;i<muxer->avih.dwStreams;i++){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
190 hdrsize=sizeof(muxer->streams[i]->h)+8; // strh
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
191 switch(muxer->streams[i]->type){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
192 case AVIWRITE_TYPE_VIDEO:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
193 hdrsize+=muxer->streams[i]->bih->biSize+8; // strf
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
194 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
195 case AVIWRITE_TYPE_AUDIO:
2635
c1e24e01601b fixed AVI header creation - now should be compatible with NaNdub
arpi
parents: 2555
diff changeset
196 hdrsize+=WFSIZE(muxer->streams[i]->wf)+8; // strf
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
197 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
198 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
199 write_avi_list(f,listtypeSTREAMHEADER,hdrsize);
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
200 le2me_AVIStreamHeader(&muxer->streams[i]->h);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
201 write_avi_chunk(f,ckidSTREAMHEADER,sizeof(muxer->streams[i]->h),&muxer->streams[i]->h); /* AVISTreamHeader */ // strh
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
202 le2me_AVIStreamHeader(&muxer->streams[i]->h);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
203
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
204 switch(muxer->streams[i]->type){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
205 case AVIWRITE_TYPE_VIDEO:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
206 {
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
207 int biSize=muxer->streams[i]->bih->biSize;
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
208 le2me_BITMAPINFOHEADER(muxer->streams[i]->bih);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
209 write_avi_chunk(f,ckidSTREAMFORMAT,biSize,muxer->streams[i]->bih); /* BITMAPINFOHEADER */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
210 le2me_BITMAPINFOHEADER(muxer->streams[i]->bih);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
211 }
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
212 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
213 case AVIWRITE_TYPE_AUDIO:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
214 {
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
215 int wfsize = WFSIZE(muxer->streams[i]->wf);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
216 le2me_WAVEFORMATEX(muxer->streams[i]->wf);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
217 write_avi_chunk(f,ckidSTREAMFORMAT,wfsize,muxer->streams[i]->wf); /* WAVEFORMATEX */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
218 le2me_WAVEFORMATEX(muxer->streams[i]->wf);
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
219 }
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
220 break;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
221 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
222 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
223
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
224 // JUNK:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
225 write_avi_chunk(f,ckidAVIPADDING,2048-(ftell(f)&2047)-8,NULL); /* junk */
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
226 // 'movi' header:
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
227 write_avi_list(f,listtypeAVIMOVIE,muxer->movi_end-ftell(f)-12);
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
228 muxer->movi_start=ftell(f);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
229 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
230
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
231 void aviwrite_write_index(aviwrite_t *muxer,FILE *f){
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
232 muxer->movi_end=ftell(f);
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
233 if(muxer->idx && muxer->idx_pos>0){
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
234 int i;
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
235 // fixup index entries:
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
236 // for(i=0;i<muxer->idx_pos;i++) muxer->idx[i].dwChunkOffset-=muxer->movi_start-4;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
237 // write index chunk:
6918
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
238 for (i=0; i<muxer->idx_pos; i++) le2me_AVIINDEXENTRY((&muxer->idx[i]));
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
239 write_avi_chunk(f,ckidAVINEWINDEX,16*muxer->idx_pos,muxer->idx); /* AVIINDEXENTRY */
62ac2cac100d PPC endianess fix by Colin Leroy <colin@colino.net>
arpi
parents: 5572
diff changeset
240 for (i=0; i<muxer->idx_pos; i++) le2me_AVIINDEXENTRY((&muxer->idx[i]));
2529
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
241 muxer->avih.dwFlags|=AVIF_HASINDEX;
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
242 }
266dab71162b AVI muxer rewritten
arpi
parents: 2310
diff changeset
243 muxer->file_end=ftell(f);
1
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
244 }
3b5f5d1c5041 Initial revision
arpi_esp
parents:
diff changeset
245