mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-25 16:52:31 +00:00
Split out flv encoding.
Originally committed as revision 21050 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
f867378771
commit
eb52376915
@ -128,7 +128,7 @@ OBJS-$(CONFIG_H263_DECODER) += h263dec.o h263.o \
|
|||||||
mpegvideo.o error_resilience.o
|
mpegvideo.o error_resilience.o
|
||||||
OBJS-$(CONFIG_H263_VAAPI_HWACCEL) += vaapi_mpeg4.o
|
OBJS-$(CONFIG_H263_VAAPI_HWACCEL) += vaapi_mpeg4.o
|
||||||
OBJS-$(CONFIG_H263_ENCODER) += mpegvideo_enc.o motion_est.o \
|
OBJS-$(CONFIG_H263_ENCODER) += mpegvideo_enc.o motion_est.o \
|
||||||
ratecontrol.o h263.o mpeg12data.o \
|
ratecontrol.o h263.o flvenc.o mpeg12data.o \
|
||||||
mpegvideo.o error_resilience.o
|
mpegvideo.o error_resilience.o
|
||||||
OBJS-$(CONFIG_H264_DECODER) += h264.o h264idct.o h264pred.o cabac.o \
|
OBJS-$(CONFIG_H264_DECODER) += h264.o h264idct.o h264pred.o cabac.o \
|
||||||
mpegvideo.o error_resilience.o
|
mpegvideo.o error_resilience.o
|
||||||
|
27
libavcodec/flv.h
Normal file
27
libavcodec/flv.h
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
/*
|
||||||
|
* FLV specific private header.
|
||||||
|
* This file is part of FFmpeg.
|
||||||
|
*
|
||||||
|
* FFmpeg is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* FFmpeg is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with FFmpeg; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef AVCODEC_FLV_H
|
||||||
|
#define AVCODEC_FLV_H
|
||||||
|
|
||||||
|
void ff_flv_encode_picture_header(MpegEncContext * s, int picture_number);
|
||||||
|
void ff_flv2_encode_ac_esc(PutBitContext *pb, int slevel, int level, int run, int last);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
84
libavcodec/flvenc.c
Normal file
84
libavcodec/flvenc.c
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
/*
|
||||||
|
* FLV Encoding specific code.
|
||||||
|
* This file is part of FFmpeg.
|
||||||
|
*
|
||||||
|
* FFmpeg is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* FFmpeg is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with FFmpeg; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "mpegvideo.h"
|
||||||
|
#include "flv.h"
|
||||||
|
|
||||||
|
void ff_flv_encode_picture_header(MpegEncContext * s, int picture_number)
|
||||||
|
{
|
||||||
|
int format;
|
||||||
|
|
||||||
|
align_put_bits(&s->pb);
|
||||||
|
|
||||||
|
put_bits(&s->pb, 17, 1);
|
||||||
|
put_bits(&s->pb, 5, (s->h263_flv-1)); /* 0: h263 escape codes 1: 11-bit escape codes */
|
||||||
|
put_bits(&s->pb, 8, (((int64_t)s->picture_number * 30 * s->avctx->time_base.num) / //FIXME use timestamp
|
||||||
|
s->avctx->time_base.den) & 0xff); /* TemporalReference */
|
||||||
|
if (s->width == 352 && s->height == 288)
|
||||||
|
format = 2;
|
||||||
|
else if (s->width == 176 && s->height == 144)
|
||||||
|
format = 3;
|
||||||
|
else if (s->width == 128 && s->height == 96)
|
||||||
|
format = 4;
|
||||||
|
else if (s->width == 320 && s->height == 240)
|
||||||
|
format = 5;
|
||||||
|
else if (s->width == 160 && s->height == 120)
|
||||||
|
format = 6;
|
||||||
|
else if (s->width <= 255 && s->height <= 255)
|
||||||
|
format = 0; /* use 1 byte width & height */
|
||||||
|
else
|
||||||
|
format = 1; /* use 2 bytes width & height */
|
||||||
|
put_bits(&s->pb, 3, format); /* PictureSize */
|
||||||
|
if (format == 0) {
|
||||||
|
put_bits(&s->pb, 8, s->width);
|
||||||
|
put_bits(&s->pb, 8, s->height);
|
||||||
|
} else if (format == 1) {
|
||||||
|
put_bits(&s->pb, 16, s->width);
|
||||||
|
put_bits(&s->pb, 16, s->height);
|
||||||
|
}
|
||||||
|
put_bits(&s->pb, 2, s->pict_type == FF_P_TYPE); /* PictureType */
|
||||||
|
put_bits(&s->pb, 1, 1); /* DeblockingFlag: on */
|
||||||
|
put_bits(&s->pb, 5, s->qscale); /* Quantizer */
|
||||||
|
put_bits(&s->pb, 1, 0); /* ExtraInformation */
|
||||||
|
|
||||||
|
if(s->h263_aic){
|
||||||
|
s->y_dc_scale_table=
|
||||||
|
s->c_dc_scale_table= ff_aic_dc_scale_table;
|
||||||
|
}else{
|
||||||
|
s->y_dc_scale_table=
|
||||||
|
s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ff_flv2_encode_ac_esc(PutBitContext *pb, int slevel, int level, int run, int last){
|
||||||
|
if(level < 64) { // 7-bit level
|
||||||
|
put_bits(pb, 1, 0);
|
||||||
|
put_bits(pb, 1, last);
|
||||||
|
put_bits(pb, 6, run);
|
||||||
|
|
||||||
|
put_sbits(pb, 7, slevel);
|
||||||
|
} else {
|
||||||
|
/* 11-bit level */
|
||||||
|
put_bits(pb, 1, 1);
|
||||||
|
put_bits(pb, 1, last);
|
||||||
|
put_bits(pb, 6, run);
|
||||||
|
|
||||||
|
put_sbits(pb, 11, slevel);
|
||||||
|
}
|
||||||
|
}
|
@ -41,6 +41,7 @@
|
|||||||
#include "mpeg4data.h"
|
#include "mpeg4data.h"
|
||||||
#include "mathops.h"
|
#include "mathops.h"
|
||||||
#include "unary.h"
|
#include "unary.h"
|
||||||
|
#include "flv.h"
|
||||||
|
|
||||||
//#undef NDEBUG
|
//#undef NDEBUG
|
||||||
//#include <assert.h>
|
//#include <assert.h>
|
||||||
@ -170,52 +171,6 @@ static av_const int aspect_to_info(AVRational aspect){
|
|||||||
return FF_ASPECT_EXTENDED;
|
return FF_ASPECT_EXTENDED;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ff_flv_encode_picture_header(MpegEncContext * s, int picture_number)
|
|
||||||
{
|
|
||||||
int format;
|
|
||||||
|
|
||||||
align_put_bits(&s->pb);
|
|
||||||
|
|
||||||
put_bits(&s->pb, 17, 1);
|
|
||||||
put_bits(&s->pb, 5, (s->h263_flv-1)); /* 0: h263 escape codes 1: 11-bit escape codes */
|
|
||||||
put_bits(&s->pb, 8, (((int64_t)s->picture_number * 30 * s->avctx->time_base.num) / //FIXME use timestamp
|
|
||||||
s->avctx->time_base.den) & 0xff); /* TemporalReference */
|
|
||||||
if (s->width == 352 && s->height == 288)
|
|
||||||
format = 2;
|
|
||||||
else if (s->width == 176 && s->height == 144)
|
|
||||||
format = 3;
|
|
||||||
else if (s->width == 128 && s->height == 96)
|
|
||||||
format = 4;
|
|
||||||
else if (s->width == 320 && s->height == 240)
|
|
||||||
format = 5;
|
|
||||||
else if (s->width == 160 && s->height == 120)
|
|
||||||
format = 6;
|
|
||||||
else if (s->width <= 255 && s->height <= 255)
|
|
||||||
format = 0; /* use 1 byte width & height */
|
|
||||||
else
|
|
||||||
format = 1; /* use 2 bytes width & height */
|
|
||||||
put_bits(&s->pb, 3, format); /* PictureSize */
|
|
||||||
if (format == 0) {
|
|
||||||
put_bits(&s->pb, 8, s->width);
|
|
||||||
put_bits(&s->pb, 8, s->height);
|
|
||||||
} else if (format == 1) {
|
|
||||||
put_bits(&s->pb, 16, s->width);
|
|
||||||
put_bits(&s->pb, 16, s->height);
|
|
||||||
}
|
|
||||||
put_bits(&s->pb, 2, s->pict_type == FF_P_TYPE); /* PictureType */
|
|
||||||
put_bits(&s->pb, 1, 1); /* DeblockingFlag: on */
|
|
||||||
put_bits(&s->pb, 5, s->qscale); /* Quantizer */
|
|
||||||
put_bits(&s->pb, 1, 0); /* ExtraInformation */
|
|
||||||
|
|
||||||
if(s->h263_aic){
|
|
||||||
s->y_dc_scale_table=
|
|
||||||
s->c_dc_scale_table= ff_aic_dc_scale_table;
|
|
||||||
}else{
|
|
||||||
s->y_dc_scale_table=
|
|
||||||
s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void h263_encode_picture_header(MpegEncContext * s, int picture_number)
|
void h263_encode_picture_header(MpegEncContext * s, int picture_number)
|
||||||
{
|
{
|
||||||
int format, coded_frame_rate, coded_frame_rate_base, i, temp_ref;
|
int format, coded_frame_rate, coded_frame_rate_base, i, temp_ref;
|
||||||
@ -1634,7 +1589,7 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
|
|||||||
code = get_rl_index(rl, last, run, level);
|
code = get_rl_index(rl, last, run, level);
|
||||||
put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
|
put_bits(&s->pb, rl->table_vlc[code][1], rl->table_vlc[code][0]);
|
||||||
if (code == rl->n) {
|
if (code == rl->n) {
|
||||||
if(s->h263_flv <= 1){
|
if(!CONFIG_FLV_ENCODER || s->h263_flv <= 1){
|
||||||
put_bits(&s->pb, 1, last);
|
put_bits(&s->pb, 1, last);
|
||||||
put_bits(&s->pb, 6, run);
|
put_bits(&s->pb, 6, run);
|
||||||
|
|
||||||
@ -1648,20 +1603,7 @@ static void h263_encode_block(MpegEncContext * s, DCTELEM * block, int n)
|
|||||||
put_sbits(&s->pb, 6, slevel>>5);
|
put_sbits(&s->pb, 6, slevel>>5);
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
if(level < 64) { // 7-bit level
|
ff_flv2_encode_ac_esc(&s->pb, slevel, level, run, last);
|
||||||
put_bits(&s->pb, 1, 0);
|
|
||||||
put_bits(&s->pb, 1, last);
|
|
||||||
put_bits(&s->pb, 6, run);
|
|
||||||
|
|
||||||
put_sbits(&s->pb, 7, slevel);
|
|
||||||
} else {
|
|
||||||
/* 11-bit level */
|
|
||||||
put_bits(&s->pb, 1, 1);
|
|
||||||
put_bits(&s->pb, 1, last);
|
|
||||||
put_bits(&s->pb, 6, run);
|
|
||||||
|
|
||||||
put_sbits(&s->pb, 11, slevel);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
put_bits(&s->pb, 1, sign);
|
put_bits(&s->pb, 1, sign);
|
||||||
|
@ -814,7 +814,6 @@ void mpeg4_encode_mb(MpegEncContext *s,
|
|||||||
DCTELEM block[6][64],
|
DCTELEM block[6][64],
|
||||||
int motion_x, int motion_y);
|
int motion_x, int motion_y);
|
||||||
void h263_encode_picture_header(MpegEncContext *s, int picture_number);
|
void h263_encode_picture_header(MpegEncContext *s, int picture_number);
|
||||||
void ff_flv_encode_picture_header(MpegEncContext *s, int picture_number);
|
|
||||||
void h263_encode_gob_header(MpegEncContext * s, int mb_line);
|
void h263_encode_gob_header(MpegEncContext * s, int mb_line);
|
||||||
int16_t *h263_pred_motion(MpegEncContext * s, int block, int dir,
|
int16_t *h263_pred_motion(MpegEncContext * s, int block, int dir,
|
||||||
int *px, int *py);
|
int *px, int *py);
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#include "msmpeg4.h"
|
#include "msmpeg4.h"
|
||||||
#include "faandct.h"
|
#include "faandct.h"
|
||||||
#include "aandcttab.h"
|
#include "aandcttab.h"
|
||||||
|
#include "flv.h"
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
//#undef NDEBUG
|
//#undef NDEBUG
|
||||||
|
Loading…
Reference in New Issue
Block a user