Mercurial > mplayer.hg
annotate libmpcodecs/ve_libdv.c @ 15465:8a7ef5cfb024
German man page review part III
added missing option '-loadidx'
author | kraymer |
---|---|
date | Sat, 14 May 2005 14:16:12 +0000 |
parents | 05aa13cdf92f |
children | 6ff3379a0862 |
rev | line source |
---|---|
5577 | 1 // requires libdv-0.9.5 !!! |
2 // (v0.9.0 is too old and has no encoding functionality exported!) | |
3 | |
4 #include <stdio.h> | |
5 #include <stdlib.h> | |
6 #include <string.h> | |
7 | |
8 #include "../config.h" | |
9 #include "../mp_msg.h" | |
10 | |
11 #ifdef HAVE_LIBDV095 | |
12 | |
13 #include "codec-cfg.h" | |
14 #include "stream.h" | |
15 #include "demuxer.h" | |
16 #include "stheader.h" | |
17 | |
8585 | 18 #include "muxer.h" |
5577 | 19 |
5607 | 20 #include "img_format.h" |
21 #include "mp_image.h" | |
5577 | 22 #include "vf.h" |
23 | |
24 #include <libdv/dv.h> | |
25 | |
26 #ifndef DV_WIDTH | |
27 #define DV_WIDTH 720 | |
28 #define DV_PAL_HEIGHT 576 | |
29 #define DV_NTSC_HEIGHT 480 | |
30 #endif | |
31 | |
32 struct vf_priv_s { | |
8585 | 33 muxer_stream_t* mux; |
5577 | 34 dv_encoder_t* enc; |
35 | |
36 }; | |
37 #define mux_v (vf->priv->mux) | |
38 | |
39 //===========================================================================// | |
40 | |
41 static int config(struct vf_instance_s* vf, | |
42 int width, int height, int d_width, int d_height, | |
43 unsigned int flags, unsigned int outfmt){ | |
44 | |
45 if(width!=DV_WIDTH || (height!=DV_PAL_HEIGHT && height!=DV_NTSC_HEIGHT)){ | |
11261 | 46 mp_msg(MSGT_VFILTER,MSGL_ERR,"DV: only 720x480 (NTSC) and 720x576 (PAL) resolutions allowed! Try with -vf scale=720:480\n"); |
5577 | 47 } |
48 | |
49 vf->priv->enc->isPAL=(height==DV_PAL_HEIGHT); | |
50 vf->priv->enc->is16x9=(d_width/(float)d_height > 1.7); // 16:9=1.777777 | |
51 vf->priv->enc->vlc_encode_passes=3; | |
52 vf->priv->enc->static_qno=0; | |
53 vf->priv->enc->force_dct=0; | |
54 | |
55 mux_v->bih->biWidth=width; | |
56 mux_v->bih->biHeight=height; | |
57 mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8); | |
12061 | 58 mux_v->aspect = (float)d_width/d_height; |
5577 | 59 |
60 return 1; | |
61 } | |
62 | |
63 static int control(struct vf_instance_s* vf, int request, void* data){ | |
64 | |
65 return CONTROL_UNKNOWN; | |
66 } | |
67 | |
68 static int query_format(struct vf_instance_s* vf, unsigned int fmt){ | |
15212
05aa13cdf92f
replace VO and VF numeric flags with #defined identifiers
henry
parents:
14878
diff
changeset
|
69 if(fmt==IMGFMT_YUY2) return VFCAP_CSP_SUPPORTED | VFCAP_CSP_SUPPORTED_BY_HW; |
05aa13cdf92f
replace VO and VF numeric flags with #defined identifiers
henry
parents:
14878
diff
changeset
|
70 if(fmt==IMGFMT_RGB24) return VFCAP_CSP_SUPPORTED; |
5577 | 71 return 0; |
72 } | |
73 | |
7368 | 74 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi){ |
5577 | 75 |
76 dv_encode_full_frame(vf->priv->enc, mpi->planes, | |
77 (mpi->flags&MP_IMGFLAG_YUV) ? e_dv_color_yuv : e_dv_color_rgb, | |
78 mux_v->buffer); | |
79 | |
9014
c671e9adbe22
Cleanup of the muxer API, func parameters muxer & muxer_f eliminated.
arpi
parents:
8585
diff
changeset
|
80 muxer_write_chunk(mux_v, 480 * (vf->priv->enc->isPAL ? 300 : 250) , 0x10); |
7368 | 81 return 1; |
5577 | 82 } |
83 | |
84 //===========================================================================// | |
85 | |
86 static int vf_open(vf_instance_t *vf, char* args){ | |
87 vf->config=config; | |
14878 | 88 vf->default_caps=VFCAP_CONSTANT; |
5577 | 89 vf->control=control; |
90 vf->query_format=query_format; | |
91 vf->put_image=put_image; | |
92 vf->priv=malloc(sizeof(struct vf_priv_s)); | |
93 memset(vf->priv,0,sizeof(struct vf_priv_s)); | |
8585 | 94 vf->priv->mux=(muxer_stream_t*)args; |
5577 | 95 |
11811
30507afa1cf6
prevent the libdv decoder from adding "NTSC setup" on decode
attila
parents:
11261
diff
changeset
|
96 vf->priv->enc=dv_encoder_new(0,1,1); // FIXME, parse some options! |
5577 | 97 if(!vf->priv->enc) return 0; |
98 | |
14549
acf3241be19b
Initialized BITMAPINFOHEADER to 0 to avoid problems, esp. windows has problems
reimar
parents:
12061
diff
changeset
|
99 mux_v->bih=calloc(1, sizeof(BITMAPINFOHEADER)); |
5577 | 100 mux_v->bih->biSize=sizeof(BITMAPINFOHEADER); |
101 mux_v->bih->biWidth=0; | |
102 mux_v->bih->biHeight=0; | |
103 mux_v->bih->biCompression=mmioFOURCC('d','v','s','d'); | |
104 mux_v->bih->biPlanes=1; | |
105 mux_v->bih->biBitCount=24; | |
106 | |
107 return 1; | |
108 } | |
109 | |
110 vf_info_t ve_info_libdv = { | |
111 "DV encoder using libdv", | |
112 "libdv", | |
113 "A'rpi", | |
114 "for internal use by mencoder", | |
115 vf_open | |
116 }; | |
117 | |
118 //===========================================================================// | |
119 #endif |