annotate wc3movie.c @ 382:37a29b5200d8 libavformat

added SGI image format, encoding and decoding, courtesy of Todd Kirby <doubleshot@pacbell.net>
author melanson
date Sat, 13 Mar 2004 17:30:37 +0000
parents 845f9de2c883
children c152849ee643
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
1 /*
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
2 * Wing Commander III Movie (.mve) File Demuxer
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
3 * Copyright (c) 2003 The ffmpeg Project
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
4 *
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
5 * This library is free software; you can redistribute it and/or
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
8 * version 2 of the License, or (at your option) any later version.
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
9 *
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
10 * This library is distributed in the hope that it will be useful,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
13 * Lesser General Public License for more details.
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
14 *
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
16 * License along with this library; if not, write to the Free Software
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
18 */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
19
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
20 /**
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
21 * @file wc3movie.c
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
22 * Wing Commander III Movie file demuxer
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
23 * by Mike Melanson (melanson@pcisys.net)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
24 * for more information on the WC3 .mve file format, visit:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
25 * http://www.pcisys.net/~melanson/codecs/
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
26 */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
27
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
28 #include "avformat.h"
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
29
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
30 #define LE_16(x) ((((uint8_t*)(x))[1] << 8) | ((uint8_t*)(x))[0])
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
31 #define LE_32(x) ((((uint8_t*)(x))[3] << 24) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
32 (((uint8_t*)(x))[2] << 16) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
33 (((uint8_t*)(x))[1] << 8) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
34 ((uint8_t*)(x))[0])
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
35 #define BE_16(x) ((((uint8_t*)(x))[0] << 8) | ((uint8_t*)(x))[1])
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
36 #define BE_32(x) ((((uint8_t*)(x))[0] << 24) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
37 (((uint8_t*)(x))[1] << 16) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
38 (((uint8_t*)(x))[2] << 8) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
39 ((uint8_t*)(x))[3])
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
40
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
41 #define WC3_PREAMBLE_SIZE 8
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
42
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
43 #define FOURCC_TAG( ch0, ch1, ch2, ch3 ) \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
44 ( (long)(unsigned char)(ch0) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
45 ( (long)(unsigned char)(ch1) << 8 ) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
46 ( (long)(unsigned char)(ch2) << 16 ) | \
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
47 ( (long)(unsigned char)(ch3) << 24 ) )
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
48
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
49 #define FORM_TAG FOURCC_TAG('F', 'O', 'R', 'M')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
50 #define MOVE_TAG FOURCC_TAG('M', 'O', 'V', 'E')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
51 #define _PC__TAG FOURCC_TAG('_', 'P', 'C', '_')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
52 #define SOND_TAG FOURCC_TAG('S', 'O', 'N', 'D')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
53 #define BNAM_TAG FOURCC_TAG('B', 'N', 'A', 'M')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
54 #define SIZE_TAG FOURCC_TAG('S', 'I', 'Z', 'E')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
55 #define PALT_TAG FOURCC_TAG('P', 'A', 'L', 'T')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
56 #define INDX_TAG FOURCC_TAG('I', 'N', 'D', 'X')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
57 #define BRCH_TAG FOURCC_TAG('B', 'R', 'C', 'H')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
58 #define SHOT_TAG FOURCC_TAG('S', 'H', 'O', 'T')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
59 #define VGA__TAG FOURCC_TAG('V', 'G', 'A', ' ')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
60 #define TEXT_TAG FOURCC_TAG('T', 'E', 'X', 'T')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
61 #define AUDI_TAG FOURCC_TAG('A', 'U', 'D', 'I')
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
62
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
63 /* video resolution unless otherwise specified */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
64 #define WC3_DEFAULT_WIDTH 320
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
65 #define WC3_DEFAULT_HEIGHT 165
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
66
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
67 /* always use the same PCM audio parameters */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
68 #define WC3_SAMPLE_RATE 22050
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
69 #define WC3_AUDIO_CHANNELS 1
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
70 #define WC3_AUDIO_BITS 16
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
71
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
72 /* nice, constant framerate */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
73 #define WC3_FRAME_PTS_INC (90000 / 15)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
74
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
75 #define PALETTE_SIZE (256 * 3)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
76 #define PALETTE_COUNT 256
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
77
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
78 typedef struct Wc3DemuxContext {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
79 int width;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
80 int height;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
81 unsigned char *palettes;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
82 int palette_count;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
83 int64_t pts;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
84 int video_stream_index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
85 int audio_stream_index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
86
245
d8b6af80b1dd deploy palette control API
tmmm
parents: 243
diff changeset
87 AVPaletteControl palette_control;
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
88
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
89 } Wc3DemuxContext;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
90
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
91 /* bizarre palette lookup table */
243
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
92 static const unsigned char wc3_pal_lookup[] = {
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
93 0x00, 0x03, 0x05, 0x07, 0x09, 0x0B, 0x0D, 0x0E,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
94 0x10, 0x12, 0x13, 0x15, 0x16, 0x18, 0x19, 0x1A,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
95 0x1C, 0x1D, 0x1F, 0x20, 0x21, 0x23, 0x24, 0x25,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
96 0x27, 0x28, 0x29, 0x2A, 0x2C, 0x2D, 0x2E, 0x2F,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
97 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x38, 0x39,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
98 0x3A, 0x3B, 0x3C, 0x3D, 0x3F, 0x40, 0x41, 0x42,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
99 0x43, 0x44, 0x45, 0x46, 0x48, 0x49, 0x4A, 0x4B,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
100 0x4C, 0x4D, 0x4E, 0x4F, 0x50, 0x51, 0x52, 0x53,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
101 0x54, 0x56, 0x57, 0x58, 0x59, 0x5A, 0x5B, 0x5C,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
102 0x5D, 0x5E, 0x5F, 0x60, 0x61, 0x62, 0x63, 0x64,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
103 0x65, 0x66, 0x67, 0x68, 0x69, 0x6A, 0x6B, 0x6C,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
104 0x6D, 0x6E, 0x6F, 0x70, 0x71, 0x72, 0x73, 0x74,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
105 0x75, 0x76, 0x77, 0x78, 0x79, 0x7A, 0x7B, 0x7C,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
106 0x7D, 0x7D, 0x7E, 0x7F, 0x80, 0x81, 0x82, 0x83,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
107 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8A, 0x8B,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
108 0x8C, 0x8D, 0x8D, 0x8E, 0x8F, 0x90, 0x91, 0x92,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
109 0x93, 0x94, 0x95, 0x96, 0x97, 0x98, 0x99, 0x99,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
110 0x9A, 0x9B, 0x9C, 0x9D, 0x9E, 0x9F, 0xA0, 0xA1,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
111 0xA2, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
112 0xA9, 0xAA, 0xAA, 0xAB, 0xAC, 0xAD, 0xAE, 0xAF,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
113 0xB0, 0xB1, 0xB2, 0xB2, 0xB3, 0xB4, 0xB5, 0xB6,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
114 0xB7, 0xB8, 0xB9, 0xB9, 0xBA, 0xBB, 0xBC, 0xBD,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
115 0xBE, 0xBF, 0xBF, 0xC0, 0xC1, 0xC2, 0xC3, 0xC4,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
116 0xC5, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, 0xCB,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
117 0xCB, 0xCC, 0xCD, 0xCE, 0xCF, 0xD0, 0xD0, 0xD1,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
118 0xD2, 0xD3, 0xD4, 0xD5, 0xD5, 0xD6, 0xD7, 0xD8,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
119 0xD9, 0xDA, 0xDA, 0xDB, 0xDC, 0xDD, 0xDE, 0xDF,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
120 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, 0xE4, 0xE4, 0xE5,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
121 0xE6, 0xE7, 0xE8, 0xE9, 0xE9, 0xEA, 0xEB, 0xEC,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
122 0xED, 0xED, 0xEE, 0xEF, 0xF0, 0xF1, 0xF1, 0xF2,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
123 0xF3, 0xF4, 0xF5, 0xF6, 0xF6, 0xF7, 0xF8, 0xF9,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
124 0xFA, 0xFA, 0xFB, 0xFC, 0xFD, 0xFD, 0xFD, 0xFD
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
125 };
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
126
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
127
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
128 static int wc3_probe(AVProbeData *p)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
129 {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
130 if (p->buf_size < 12)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
131 return 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
132
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
133 if ((LE_32(&p->buf[0]) != FORM_TAG) ||
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
134 (LE_32(&p->buf[8]) != MOVE_TAG))
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
135 return 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
136
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
137 return AVPROBE_SCORE_MAX;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
138 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
139
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
140 static int wc3_read_header(AVFormatContext *s,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
141 AVFormatParameters *ap)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
142 {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
143 Wc3DemuxContext *wc3 = (Wc3DemuxContext *)s->priv_data;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
144 ByteIOContext *pb = &s->pb;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
145 unsigned int fourcc_tag;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
146 unsigned int size;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
147 AVStream *st;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
148 unsigned char preamble[WC3_PREAMBLE_SIZE];
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
149 int ret = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
150 int current_palette = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
151 int bytes_to_read;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
152 int i;
243
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
153 unsigned char rotate;
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
154
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
155 /* default context members */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
156 wc3->width = WC3_DEFAULT_WIDTH;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
157 wc3->height = WC3_DEFAULT_HEIGHT;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
158 wc3->palettes = NULL;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
159 wc3->palette_count = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
160 wc3->pts = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
161 wc3->video_stream_index = wc3->audio_stream_index = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
162
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
163 /* skip the first 3 32-bit numbers */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
164 url_fseek(pb, 12, SEEK_CUR);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
165
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
166 /* traverse through the chunks and load the header information before
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
167 * the first BRCH tag */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
168 if ((ret = get_buffer(pb, preamble, WC3_PREAMBLE_SIZE)) !=
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
169 WC3_PREAMBLE_SIZE)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
170 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
171 fourcc_tag = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
172 size = (BE_32(&preamble[4]) + 1) & (~1);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
173
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
174 do {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
175 switch (fourcc_tag) {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
176
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
177 case SOND_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
178 case INDX_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
179 /* SOND unknown, INDX unnecessary; ignore both */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
180 url_fseek(pb, size, SEEK_CUR);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
181 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
182
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
183 case _PC__TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
184 /* need the number of palettes */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
185 url_fseek(pb, 8, SEEK_CUR);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
186 if ((ret = get_buffer(pb, preamble, 4)) != 4)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
187 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
188 wc3->palette_count = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
189 wc3->palettes = av_malloc(wc3->palette_count * PALETTE_SIZE);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
190 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
191
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
192 case BNAM_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
193 /* load up the name */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
194 if (size < 512)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
195 bytes_to_read = size;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
196 else
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
197 bytes_to_read = 512;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
198 if ((ret = get_buffer(pb, s->title, bytes_to_read)) != bytes_to_read)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
199 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
200 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
201
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
202 case SIZE_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
203 /* video resolution override */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
204 if ((ret = get_buffer(pb, preamble, WC3_PREAMBLE_SIZE)) !=
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
205 WC3_PREAMBLE_SIZE)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
206 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
207 wc3->width = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
208 wc3->height = LE_32(&preamble[4]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
209 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
210
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
211 case PALT_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
212 /* one of several palettes */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
213 if (current_palette >= wc3->palette_count)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
214 return AVERROR_INVALIDDATA;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
215 if ((ret = get_buffer(pb,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
216 &wc3->palettes[current_palette * PALETTE_SIZE],
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
217 PALETTE_SIZE)) != PALETTE_SIZE)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
218 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
219
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
220 /* transform the current palette in place */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
221 for (i = current_palette * PALETTE_SIZE;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
222 i < (current_palette + 1) * PALETTE_SIZE; i++) {
243
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
223 /* rotate each palette component left by 2 and use the result
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
224 * as an index into the color component table */
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
225 rotate = ((wc3->palettes[i] << 2) & 0xFF) |
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
226 ((wc3->palettes[i] >> 6) & 0xFF);
a315234e11eb forgot to apply the palette component lookup table
tmmm
parents: 225
diff changeset
227 wc3->palettes[i] = wc3_pal_lookup[rotate];
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
228 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
229 current_palette++;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
230 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
231
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
232 default:
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
233 av_log(s, AV_LOG_ERROR, " unrecognized WC3 chunk: %c%c%c%c (0x%02X%02X%02X%02X)\n",
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
234 preamble[0], preamble[1], preamble[2], preamble[3],
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
235 preamble[0], preamble[1], preamble[2], preamble[3]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
236 return AVERROR_INVALIDDATA;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
237 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
238 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
239
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
240 if ((ret = get_buffer(pb, preamble, WC3_PREAMBLE_SIZE)) !=
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
241 WC3_PREAMBLE_SIZE)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
242 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
243 fourcc_tag = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
244 /* chunk sizes are 16-bit aligned */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
245 size = (BE_32(&preamble[4]) + 1) & (~1);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
246
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
247 } while (fourcc_tag != BRCH_TAG);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
248
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
249 /* initialize the decoder streams */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
250 st = av_new_stream(s, 0);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
251 if (!st)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
252 return AVERROR_NOMEM;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
253 wc3->video_stream_index = st->index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
254 st->codec.codec_type = CODEC_TYPE_VIDEO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
255 st->codec.codec_id = CODEC_ID_XAN_WC3;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
256 st->codec.codec_tag = 0; /* no fourcc */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
257 st->codec.width = wc3->width;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
258 st->codec.height = wc3->height;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
259
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
260 /* palette considerations */
295
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
261 st->codec.palctrl = &wc3->palette_control;
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
262
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
263 st = av_new_stream(s, 0);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
264 if (!st)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
265 return AVERROR_NOMEM;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
266 wc3->audio_stream_index = st->index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
267 st->codec.codec_type = CODEC_TYPE_AUDIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
268 st->codec.codec_id = CODEC_ID_PCM_S16LE;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
269 st->codec.codec_tag = 1;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
270 st->codec.channels = WC3_AUDIO_CHANNELS;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
271 st->codec.bits_per_sample = WC3_AUDIO_BITS;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
272 st->codec.sample_rate = WC3_SAMPLE_RATE;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
273 st->codec.bit_rate = st->codec.channels * st->codec.sample_rate *
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
274 st->codec.bits_per_sample;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
275 st->codec.block_align = WC3_AUDIO_BITS * WC3_AUDIO_CHANNELS;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
276
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
277 /* set the pts reference (1 pts = 1/90000) */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
278 s->pts_num = 1;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
279 s->pts_den = 90000;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
280
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
281 return 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
282 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
283
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
284 static int wc3_read_packet(AVFormatContext *s,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
285 AVPacket *pkt)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
286 {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
287 Wc3DemuxContext *wc3 = (Wc3DemuxContext *)s->priv_data;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
288 ByteIOContext *pb = &s->pb;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
289 unsigned int fourcc_tag;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
290 unsigned int size;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
291 int packet_read = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
292 int ret = 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
293 unsigned char preamble[WC3_PREAMBLE_SIZE];
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
294 unsigned char text[1024];
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
295 unsigned int palette_number;
295
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
296 int i;
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
297 unsigned char r, g, b;
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
298 int base_palette_index;
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
299
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
300 while (!packet_read) {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
301
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
302 /* get the next chunk preamble */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
303 if ((ret = get_buffer(pb, preamble, WC3_PREAMBLE_SIZE)) !=
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
304 WC3_PREAMBLE_SIZE)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
305 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
306
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
307 fourcc_tag = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
308 /* chunk sizes are 16-bit aligned */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
309 size = (BE_32(&preamble[4]) + 1) & (~1);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
310
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
311 switch (fourcc_tag) {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
312
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
313 case BRCH_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
314 /* no-op */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
315 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
316
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
317 case SHOT_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
318 /* load up new palette */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
319 if ((ret = get_buffer(pb, preamble, 4)) != 4)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
320 return -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
321 palette_number = LE_32(&preamble[0]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
322 if (palette_number >= wc3->palette_count)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
323 return AVERROR_INVALIDDATA;
295
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
324 base_palette_index = palette_number * PALETTE_COUNT * 3;
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
325 for (i = 0; i < PALETTE_COUNT; i++) {
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
326 r = wc3->palettes[base_palette_index + i * 3 + 0];
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
327 g = wc3->palettes[base_palette_index + i * 3 + 1];
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
328 b = wc3->palettes[base_palette_index + i * 3 + 2];
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
329 wc3->palette_control.palette[i] = (r << 16) | (g << 8) | (b);
bff1a372ae38 revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents: 245
diff changeset
330 }
245
d8b6af80b1dd deploy palette control API
tmmm
parents: 243
diff changeset
331 wc3->palette_control.palette_changed = 1;
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
332 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
333
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
334 case VGA__TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
335 /* send out video chunk */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
336 if (av_new_packet(pkt, size))
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
337 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
338 pkt->stream_index = wc3->video_stream_index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
339 pkt->pts = wc3->pts;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
340 ret = get_buffer(pb, pkt->data, size);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
341 if (ret != size)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
342 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
343 packet_read = 1;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
344 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
345
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
346 case TEXT_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
347 /* subtitle chunk */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
348 #if 0
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
349 url_fseek(pb, size, SEEK_CUR);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
350 #else
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
351 if ((ret = get_buffer(pb, text, size)) != size)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
352 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
353 else {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
354 int i = 0;
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
355 av_log (s, AV_LOG_DEBUG, "Subtitle time!\n");
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
356 av_log (s, AV_LOG_DEBUG, " inglish: %s\n", &text[i + 1]);
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
357 i += text[i] + 1;
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
358 av_log (s, AV_LOG_DEBUG, " doytsch: %s\n", &text[i + 1]);
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
359 i += text[i] + 1;
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
360 av_log (s, AV_LOG_DEBUG, " fronsay: %s\n", &text[i + 1]);
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
361 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
362 #endif
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
363 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
364
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
365 case AUDI_TAG:
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
366 /* send out audio chunk */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
367 if (av_new_packet(pkt, size))
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
368 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
369 pkt->stream_index = wc3->audio_stream_index;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
370 pkt->pts = wc3->pts;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
371 ret = get_buffer(pb, pkt->data, size);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
372 if (ret != size)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
373 ret = -EIO;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
374
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
375 /* time to advance pts */
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
376 wc3->pts += WC3_FRAME_PTS_INC;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
377
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
378 packet_read = 1;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
379 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
380
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
381 default:
370
845f9de2c883 av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents: 295
diff changeset
382 av_log (s, AV_LOG_ERROR, " unrecognized WC3 chunk: %c%c%c%c (0x%02X%02X%02X%02X)\n",
225
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
383 preamble[0], preamble[1], preamble[2], preamble[3],
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
384 preamble[0], preamble[1], preamble[2], preamble[3]);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
385 ret = AVERROR_INVALIDDATA;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
386 packet_read = 1;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
387 break;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
388 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
389 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
390
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
391 return ret;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
392 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
393
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
394 static int wc3_read_close(AVFormatContext *s)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
395 {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
396 Wc3DemuxContext *wc3 = (Wc3DemuxContext *)s->priv_data;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
397
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
398 av_free(wc3->palettes);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
399
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
400 return 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
401 }
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
402
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
403 static AVInputFormat wc3_iformat = {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
404 "wc3movie",
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
405 "Wing Commander III movie format",
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
406 sizeof(Wc3DemuxContext),
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
407 wc3_probe,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
408 wc3_read_header,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
409 wc3_read_packet,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
410 wc3_read_close,
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
411 };
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
412
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
413 int wc3_init(void)
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
414 {
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
415 av_register_input_format(&wc3_iformat);
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
416 return 0;
d0332f4362b6 demuxer for custom Wing Commander III movie (.mve) files
tmmm
parents:
diff changeset
417 }