mirror of
https://github.com/mpv-player/mpv
synced 2025-02-23 00:06:56 +00:00
remove raw nonsense and replace it by one ovc
patch by John Earl <jwe21@cam.ac.uk> git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@11967 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
parent
b603289132
commit
268daef9cd
@ -3832,10 +3832,8 @@ Use \-ovc help to get a list of available codecs.
|
||||
no encoding, just streamcopy
|
||||
.IPs "\-ovc divx4"
|
||||
encode to DivX4/\:DivX5
|
||||
.IPs "\-ovc rawrgb"
|
||||
encode to uncompressed RGB24
|
||||
.IPs "\-ovc rawyuv"
|
||||
encode to uncompressed YUV (I420)
|
||||
.IPs "\-ovc raw"
|
||||
encode to arbitrary uncompressed format (use \-vf format to select)
|
||||
.IPs "\-ovc lavc"
|
||||
encode with a libavcodec codecs
|
||||
.RE
|
||||
@ -5273,7 +5271,7 @@ mencoder dvd://2 \-o titel2.avi \-ovc lavc
|
||||
mencoder "mf://*.jpg" \-mf fps=25 \-o output.avi \-ovc divx4
|
||||
.TP
|
||||
.B Encoding from tuner
|
||||
mencoder \-tv driver=v4l:width=640:height=480 tv:// \-o tv.avi \-ovc rawrgb
|
||||
mencoder \-tv driver=v4l:width=640:height=480 tv:// \-o tv.avi \-ovc raw
|
||||
.TP
|
||||
.B Encoding from a pipe
|
||||
rar p test-SVCD.rar | mencoder \-ovc divx4 \-divx4opts br=800 \-ofps 24 \-
|
||||
|
@ -67,8 +67,7 @@ m_option_t ovc_conf[]={
|
||||
// {"raw", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_RAW, NULL},
|
||||
{"lavc", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_LIBAVCODEC, NULL},
|
||||
// {"null", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_NULL, NULL},
|
||||
{"rawrgb", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_RAWRGB, NULL},
|
||||
{"rawyuv", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_RAWYUV, NULL},
|
||||
{"raw", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_RAW, NULL},
|
||||
{"vfw", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_VFW, NULL},
|
||||
{"libdv", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_LIBDV, NULL},
|
||||
{"xvid", &out_video_codec, CONF_TYPE_FLAG, 0, 0, VCODEC_XVID, NULL},
|
||||
@ -77,8 +76,7 @@ m_option_t ovc_conf[]={
|
||||
{"help", "\nAvailable codecs:\n"
|
||||
" copy - frame copy, without re-encoding. doesn't work with filters!\n"
|
||||
" frameno - special audio-only file for 3-pass encoding, see DOCS!\n"
|
||||
" rawrgb - uncompressed RGB 24bpp video\n"
|
||||
" rawyuv - uncompressed 4:2:0 YUV (I420) 12bpp video\n"
|
||||
" raw - uncompressed video. Use fourcc option to set format explicitly.\n"
|
||||
" nuv - nuppel video\n"
|
||||
#ifdef HAVE_DIVX4ENCORE
|
||||
#ifdef ENCORE_XVID
|
||||
|
@ -19,7 +19,7 @@ ifeq ($(HAVE_FFPOSTPROCESS),yes)
|
||||
VFILTER_SRCS += vf_pp.c
|
||||
endif
|
||||
|
||||
ENCODER_SRCS=ve.c ve_divx4.c ve_lavc.c ve_vfw.c ve_rawrgb.c ve_rawyuv.c ve_libdv.c ve_xvid.c ve_xvid4.c ve_qtvideo.c ve_nuv.c
|
||||
ENCODER_SRCS=ve.c ve_divx4.c ve_lavc.c ve_vfw.c ve_raw.c ve_libdv.c ve_xvid.c ve_xvid4.c ve_qtvideo.c ve_nuv.c
|
||||
|
||||
NATIVE_SRCS=native/RTjpegN.c native/cinepak.c native/fli.c native/minilzo.c native/nuppelvideo.c native/qtrle.c native/roqav.c native/xa_gsm.c native/decode144.c native/decode288.c
|
||||
|
||||
|
@ -12,8 +12,7 @@
|
||||
extern vf_info_t ve_info_divx4;
|
||||
extern vf_info_t ve_info_lavc;
|
||||
extern vf_info_t ve_info_vfw;
|
||||
extern vf_info_t ve_info_rawrgb;
|
||||
extern vf_info_t ve_info_rawyuv;
|
||||
extern vf_info_t ve_info_raw;
|
||||
extern vf_info_t ve_info_libdv;
|
||||
extern vf_info_t ve_info_xvid;
|
||||
extern vf_info_t ve_info_qtvideo;
|
||||
@ -33,8 +32,7 @@ static vf_info_t* encoder_list[]={
|
||||
#ifdef HAVE_LIBDV095
|
||||
&ve_info_libdv,
|
||||
#endif
|
||||
&ve_info_rawrgb,
|
||||
&ve_info_rawyuv,
|
||||
&ve_info_raw,
|
||||
#if defined(HAVE_XVID3) || defined(HAVE_XVID4)
|
||||
&ve_info_xvid,
|
||||
#endif
|
||||
|
150
libmpcodecs/ve_raw.c
Normal file
150
libmpcodecs/ve_raw.c
Normal file
@ -0,0 +1,150 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "../config.h"
|
||||
#include "../mp_msg.h"
|
||||
|
||||
#include "codec-cfg.h"
|
||||
#include "stream.h"
|
||||
#include "demuxer.h"
|
||||
#include "stheader.h"
|
||||
|
||||
#include "muxer.h"
|
||||
|
||||
#include "img_format.h"
|
||||
#include "mp_image.h"
|
||||
#include "vf.h"
|
||||
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
struct vf_priv_s {
|
||||
muxer_stream_t* mux;
|
||||
};
|
||||
#define mux_v (vf->priv->mux)
|
||||
|
||||
static int set_format(struct vf_instance_s *vf, unsigned int fmt) {
|
||||
mux_v->bih->biCompression = fmt;
|
||||
|
||||
mux_v->bih->biPlanes = 1;
|
||||
if (IMGFMT_IS_RGB(fmt)) {
|
||||
if (IMGFMT_RGB_DEPTH(fmt) < 8 && !(fmt&128))
|
||||
mux_v->bih->biBitCount = IMGFMT_RGB_DEPTH(fmt);
|
||||
else
|
||||
mux_v->bih->biBitCount = (IMGFMT_RGB_DEPTH(fmt)+7)&(~7);
|
||||
return 1;
|
||||
}
|
||||
if (IMGFMT_IS_BGR(fmt)) {
|
||||
if (IMGFMT_BGR_DEPTH(fmt) < 8 && !(fmt&128))
|
||||
mux_v->bih->biBitCount = IMGFMT_BGR_DEPTH(fmt);
|
||||
else
|
||||
mux_v->bih->biBitCount = (IMGFMT_BGR_DEPTH(fmt)+7)&(~7);
|
||||
return 1;
|
||||
}
|
||||
switch (fmt) {
|
||||
case IMGFMT_I420:
|
||||
case IMGFMT_IYUV:
|
||||
case IMGFMT_YV12:
|
||||
case IMGFMT_411P:
|
||||
mux_v->bih->biPlanes = 3;
|
||||
mux_v->bih->biBitCount = 12;
|
||||
break;
|
||||
case IMGFMT_444P:
|
||||
mux_v->bih->biPlanes = 3;
|
||||
mux_v->bih->biBitCount = 24;
|
||||
break;
|
||||
case IMGFMT_422P:
|
||||
mux_v->bih->biPlanes = 3;
|
||||
mux_v->bih->biBitCount = 16;
|
||||
break;
|
||||
case IMGFMT_IF09:
|
||||
mux_v->bih->biPlanes = 4;
|
||||
case IMGFMT_YVU9:
|
||||
mux_v->bih->biBitCount = 9;
|
||||
break;
|
||||
case IMGFMT_UYVY:
|
||||
case IMGFMT_YUY2:
|
||||
mux_v->bih->biBitCount = 16;
|
||||
break;
|
||||
default:
|
||||
printf("ve_raw: raw output with fourcc [%x] not supported!\n", fmt);
|
||||
mux_v->bih->biCompression = 0;
|
||||
return 0;
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
static int config(struct vf_instance_s *vf,
|
||||
int width, int height, int d_width, int d_height,
|
||||
unsigned int flags, unsigned int outfmt)
|
||||
{
|
||||
int ret;
|
||||
mux_v->bih->biWidth = width;
|
||||
mux_v->bih->biHeight = height;
|
||||
ret = set_format(vf, outfmt);
|
||||
if (!ret) return 0;
|
||||
|
||||
mux_v->bih->biSizeImage = mux_v->bih->biWidth*mux_v->bih->biHeight*mux_v->bih->biBitCount/8;
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int control(struct vf_instance_s *vf, int request, void *data) {
|
||||
return CONTROL_UNKNOWN;
|
||||
}
|
||||
|
||||
static int query_format(struct vf_instance_s *vf, unsigned int fmt) {
|
||||
if (IMGFMT_IS_RGB(fmt) || IMGFMT_IS_BGR(fmt))
|
||||
return VFCAP_CSP_SUPPORTED | VFCAP_CSP_SUPPORTED_BY_HW;
|
||||
switch (fmt) {
|
||||
case IMGFMT_I420:
|
||||
case IMGFMT_IYUV:
|
||||
case IMGFMT_YV12:
|
||||
case IMGFMT_411P:
|
||||
case IMGFMT_444P:
|
||||
case IMGFMT_422P:
|
||||
case IMGFMT_UYVY:
|
||||
case IMGFMT_YUY2:
|
||||
case IMGFMT_YVU9:
|
||||
case IMGFMT_IF09:
|
||||
return VFCAP_CSP_SUPPORTED | VFCAP_CSP_SUPPORTED_BY_HW;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int put_image(struct vf_instance_s *vf, mp_image_t *mpi) {
|
||||
mux_v->buffer = mpi->planes[0];
|
||||
muxer_write_chunk(mux_v, mpi->width*mpi->height*mux_v->bih->biBitCount/8, 0x10);
|
||||
return 1;
|
||||
}
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
static int vf_open(vf_instance_t *vf, char* args){
|
||||
vf->config = config;
|
||||
vf->control = control;
|
||||
vf->query_format = query_format;
|
||||
vf->put_image = put_image;
|
||||
vf->priv = malloc(sizeof(struct vf_priv_s));
|
||||
memset(vf->priv, 0, sizeof(struct vf_priv_s));
|
||||
vf->priv->mux = (muxer_stream_t*)args;
|
||||
|
||||
mux_v->bih = malloc(sizeof(BITMAPINFOHEADER));
|
||||
mux_v->bih->biSize = sizeof(BITMAPINFOHEADER);
|
||||
mux_v->bih->biWidth = 0;
|
||||
mux_v->bih->biHeight = 0;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
vf_info_t ve_info_raw = {
|
||||
"raw encoder",
|
||||
"raw",
|
||||
"jwe21@cam.ac.uk",
|
||||
"Based on rawrgb",
|
||||
vf_open
|
||||
};
|
||||
|
||||
//===========================================================================//
|
@ -1,83 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "../config.h"
|
||||
#include "../mp_msg.h"
|
||||
|
||||
#include "codec-cfg.h"
|
||||
#include "stream.h"
|
||||
#include "demuxer.h"
|
||||
#include "stheader.h"
|
||||
|
||||
#include "muxer.h"
|
||||
|
||||
#include "img_format.h"
|
||||
#include "mp_image.h"
|
||||
#include "vf.h"
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
struct vf_priv_s {
|
||||
muxer_stream_t* mux;
|
||||
};
|
||||
#define mux_v (vf->priv->mux)
|
||||
|
||||
static int config(struct vf_instance_s* vf,
|
||||
int width, int height, int d_width, int d_height,
|
||||
unsigned int flags, unsigned int outfmt){
|
||||
|
||||
mux_v->bih->biWidth=width;
|
||||
mux_v->bih->biHeight=height;
|
||||
mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int control(struct vf_instance_s* vf, int request, void* data){
|
||||
|
||||
return CONTROL_UNKNOWN;
|
||||
}
|
||||
|
||||
static int query_format(struct vf_instance_s* vf, unsigned int fmt){
|
||||
if(fmt==IMGFMT_BGR24) return 3 | VFCAP_FLIPPED;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int put_image(struct vf_instance_s* vf, mp_image_t *mpi){
|
||||
mux_v->buffer=mpi->planes[0];
|
||||
muxer_write_chunk(mux_v, mpi->width*mpi->height*3, 0x10);
|
||||
return 1;
|
||||
}
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
static int vf_open(vf_instance_t *vf, char* args){
|
||||
vf->config=config;
|
||||
vf->control=control;
|
||||
vf->query_format=query_format;
|
||||
vf->put_image=put_image;
|
||||
vf->priv=malloc(sizeof(struct vf_priv_s));
|
||||
memset(vf->priv,0,sizeof(struct vf_priv_s));
|
||||
vf->priv->mux=(muxer_stream_t*)args;
|
||||
|
||||
mux_v->bih=malloc(sizeof(BITMAPINFOHEADER));
|
||||
mux_v->bih->biSize=sizeof(BITMAPINFOHEADER);
|
||||
mux_v->bih->biWidth=0;
|
||||
mux_v->bih->biHeight=0;
|
||||
mux_v->bih->biCompression=0;
|
||||
mux_v->bih->biPlanes=1;
|
||||
mux_v->bih->biBitCount=24;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
vf_info_t ve_info_rawrgb = {
|
||||
"rawrgb encoder",
|
||||
"rawrgb",
|
||||
"A'rpi",
|
||||
"for internal use by mencoder",
|
||||
vf_open
|
||||
};
|
||||
|
||||
//===========================================================================//
|
@ -1,81 +0,0 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "../config.h"
|
||||
#include "../mp_msg.h"
|
||||
|
||||
#include "codec-cfg.h"
|
||||
#include "stream.h"
|
||||
#include "demuxer.h"
|
||||
#include "stheader.h"
|
||||
|
||||
#include "muxer.h"
|
||||
|
||||
#include "img_format.h"
|
||||
#include "mp_image.h"
|
||||
#include "vf.h"
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
struct vf_priv_s {
|
||||
muxer_stream_t* mux;
|
||||
};
|
||||
#define mux_v (vf->priv->mux)
|
||||
|
||||
static int config(struct vf_instance_s *vf,
|
||||
int width, int height, int d_width, int d_height,
|
||||
unsigned int flags, unsigned int outfmt)
|
||||
{
|
||||
mux_v->bih->biWidth = width;
|
||||
mux_v->bih->biHeight = height;
|
||||
mux_v->bih->biSizeImage = mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8);
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int control(struct vf_instance_s *vf, int request, void *data) {
|
||||
return CONTROL_UNKNOWN;
|
||||
}
|
||||
|
||||
static int query_format(struct vf_instance_s *vf, unsigned int fmt) {
|
||||
if (fmt==IMGFMT_I420) return VFCAP_CSP_SUPPORTED | VFCAP_CSP_SUPPORTED_BY_HW;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int put_image(struct vf_instance_s *vf, mp_image_t *mpi) {
|
||||
mux_v->buffer = mpi->planes[0];
|
||||
muxer_write_chunk(mux_v, mpi->width*mpi->height*3/2, 0x10);
|
||||
return 1;
|
||||
}
|
||||
|
||||
//===========================================================================//
|
||||
|
||||
static int vf_open(vf_instance_t *vf, char* args){
|
||||
vf->config = config;
|
||||
vf->control = control;
|
||||
vf->query_format = query_format;
|
||||
vf->put_image = put_image;
|
||||
vf->priv = malloc(sizeof(struct vf_priv_s));
|
||||
memset(vf->priv, 0, sizeof(struct vf_priv_s));
|
||||
vf->priv->mux = (muxer_stream_t*)args;
|
||||
|
||||
mux_v->bih = malloc(sizeof(BITMAPINFOHEADER));
|
||||
mux_v->bih->biSize = sizeof(BITMAPINFOHEADER);
|
||||
mux_v->bih->biWidth = 0;
|
||||
mux_v->bih->biHeight = 0;
|
||||
mux_v->bih->biCompression = mmioFOURCC('I', '4', '2', '0');
|
||||
mux_v->bih->biPlanes = 3;
|
||||
mux_v->bih->biBitCount = 12;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
vf_info_t ve_info_rawyuv = {
|
||||
"rawyuv encoder",
|
||||
"rawyuv",
|
||||
"tuukkat@ee.oulu.fi",
|
||||
"Based on rawrgb",
|
||||
vf_open
|
||||
};
|
||||
|
||||
//===========================================================================//
|
@ -3,13 +3,12 @@
|
||||
// real codecs:
|
||||
#define VCODEC_DIVX4 2
|
||||
#define VCODEC_LIBAVCODEC 4
|
||||
#define VCODEC_RAWRGB 6
|
||||
#define VCODEC_VFW 7
|
||||
#define VCODEC_LIBDV 8
|
||||
#define VCODEC_XVID 9
|
||||
#define VCODEC_QTVIDEO 10
|
||||
#define VCODEC_NUV 11
|
||||
#define VCODEC_RAWYUV 12
|
||||
#define VCODEC_RAW 12
|
||||
|
||||
#define ACODEC_COPY 0
|
||||
#define ACODEC_PCM 1
|
||||
@ -681,10 +680,8 @@ default:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"divx4",(char *)mux_v); break;
|
||||
case VCODEC_LIBAVCODEC:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"lavc",(char *)mux_v); break;
|
||||
case VCODEC_RAWRGB:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"rawrgb",(char *)mux_v); break;
|
||||
case VCODEC_RAWYUV:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"rawyuv",(char *)mux_v); break;
|
||||
case VCODEC_RAW:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"raw",(char *)mux_v); break;
|
||||
case VCODEC_VFW:
|
||||
sh_video->vfilter=vf_open_encoder(NULL,"vfw",(char *)mux_v); break;
|
||||
case VCODEC_LIBDV:
|
||||
|
Loading…
Reference in New Issue
Block a user