annotate flvenc.c @ 10787:3f8e40fe25c2 libavcodec

Split out flv encoding.
author michael
date Thu, 07 Jan 2010 04:42:39 +0000
parents
children edaaa3fa540c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10787
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
1 /*
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
2 * FLV Encoding specific code.
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
3 * This file is part of FFmpeg.
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
4 *
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
5 * FFmpeg is free software; you can redistribute it and/or
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
8 * version 2.1 of the License, or (at your option) any later version.
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
9 *
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
10 * FFmpeg is distributed in the hope that it will be useful,
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
13 * Lesser General Public License for more details.
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
14 *
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
16 * License along with FFmpeg; if not, write to the Free Software
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
18 */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
19
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
20 #include "mpegvideo.h"
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
21 #include "flv.h"
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
22
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
23 void ff_flv_encode_picture_header(MpegEncContext * s, int picture_number)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
24 {
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
25 int format;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
26
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
27 align_put_bits(&s->pb);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
28
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
29 put_bits(&s->pb, 17, 1);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
30 put_bits(&s->pb, 5, (s->h263_flv-1)); /* 0: h263 escape codes 1: 11-bit escape codes */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
31 put_bits(&s->pb, 8, (((int64_t)s->picture_number * 30 * s->avctx->time_base.num) / //FIXME use timestamp
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
32 s->avctx->time_base.den) & 0xff); /* TemporalReference */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
33 if (s->width == 352 && s->height == 288)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
34 format = 2;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
35 else if (s->width == 176 && s->height == 144)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
36 format = 3;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
37 else if (s->width == 128 && s->height == 96)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
38 format = 4;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
39 else if (s->width == 320 && s->height == 240)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
40 format = 5;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
41 else if (s->width == 160 && s->height == 120)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
42 format = 6;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
43 else if (s->width <= 255 && s->height <= 255)
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
44 format = 0; /* use 1 byte width & height */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
45 else
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
46 format = 1; /* use 2 bytes width & height */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
47 put_bits(&s->pb, 3, format); /* PictureSize */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
48 if (format == 0) {
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
49 put_bits(&s->pb, 8, s->width);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
50 put_bits(&s->pb, 8, s->height);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
51 } else if (format == 1) {
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
52 put_bits(&s->pb, 16, s->width);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
53 put_bits(&s->pb, 16, s->height);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
54 }
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
55 put_bits(&s->pb, 2, s->pict_type == FF_P_TYPE); /* PictureType */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
56 put_bits(&s->pb, 1, 1); /* DeblockingFlag: on */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
57 put_bits(&s->pb, 5, s->qscale); /* Quantizer */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
58 put_bits(&s->pb, 1, 0); /* ExtraInformation */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
59
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
60 if(s->h263_aic){
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
61 s->y_dc_scale_table=
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
62 s->c_dc_scale_table= ff_aic_dc_scale_table;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
63 }else{
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
64 s->y_dc_scale_table=
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
65 s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
66 }
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
67 }
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
68
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
69 void ff_flv2_encode_ac_esc(PutBitContext *pb, int slevel, int level, int run, int last){
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
70 if(level < 64) { // 7-bit level
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
71 put_bits(pb, 1, 0);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
72 put_bits(pb, 1, last);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
73 put_bits(pb, 6, run);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
74
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
75 put_sbits(pb, 7, slevel);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
76 } else {
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
77 /* 11-bit level */
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
78 put_bits(pb, 1, 1);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
79 put_bits(pb, 1, last);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
80 put_bits(pb, 6, run);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
81
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
82 put_sbits(pb, 11, slevel);
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
83 }
3f8e40fe25c2 Split out flv encoding.
michael
parents:
diff changeset
84 }