changeset 11966:b58fdd5d8e8d

remove raw nonsense and replace it by one ovc patch by John Earl <jwe21@cam.ac.uk>
author attila
date Tue, 17 Feb 2004 12:43:07 +0000
parents 3d75bcc28231
children 4f4b81257d19
files DOCS/man/en/mplayer.1 cfg-mencoder.h libmpcodecs/Makefile libmpcodecs/ve.c libmpcodecs/ve_raw.c libmpcodecs/ve_rawrgb.c libmpcodecs/ve_rawyuv.c mencoder.c
diffstat 8 files changed, 161 insertions(+), 184 deletions(-) [+]
line wrap: on
line diff
--- a/DOCS/man/en/mplayer.1	Tue Feb 17 12:30:45 2004 +0000
+++ b/DOCS/man/en/mplayer.1	Tue Feb 17 12:43:07 2004 +0000
@@ -3832,10 +3832,8 @@
 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 "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 \-
--- a/cfg-mencoder.h	Tue Feb 17 12:30:45 2004 +0000
+++ b/cfg-mencoder.h	Tue Feb 17 12:43:07 2004 +0000
@@ -67,8 +67,7 @@
 //	{"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 @@
 	{"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
--- a/libmpcodecs/Makefile	Tue Feb 17 12:30:45 2004 +0000
+++ b/libmpcodecs/Makefile	Tue Feb 17 12:43:07 2004 +0000
@@ -19,7 +19,7 @@
 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
 
--- a/libmpcodecs/ve.c	Tue Feb 17 12:30:45 2004 +0000
+++ b/libmpcodecs/ve.c	Tue Feb 17 12:43:07 2004 +0000
@@ -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 @@
 #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
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libmpcodecs/ve_raw.c	Tue Feb 17 12:43:07 2004 +0000
@@ -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
+};
+
+//===========================================================================//
--- a/libmpcodecs/ve_rawrgb.c	Tue Feb 17 12:30:45 2004 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -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
-};
-
-//===========================================================================//
--- a/libmpcodecs/ve_rawyuv.c	Tue Feb 17 12:30:45 2004 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -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
-};
-
-//===========================================================================//
--- a/mencoder.c	Tue Feb 17 12:30:45 2004 +0000
+++ b/mencoder.c	Tue Feb 17 12:43:07 2004 +0000
@@ -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 @@
 	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: