Mercurial > mplayer.hg
annotate libmpcodecs/ve_libdv.c @ 22340:d1ff13042a2a
Add commit nick for Rik Snel.
author | diego |
---|---|
date | Tue, 27 Feb 2007 16:00:34 +0000 |
parents | ca9da45d13e9 |
children | 3c2b4a866c6a |
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 | |
17012 | 8 #include "config.h" |
9 #include "mp_msg.h" | |
5577 | 10 |
11 #include "codec-cfg.h" | |
12 #include "stream.h" | |
13 #include "demuxer.h" | |
14 #include "stheader.h" | |
15 | |
21660
ca9da45d13e9
muxers now write to output muxer->stream rather than to muxer->file
nicodvb
parents:
18771
diff
changeset
|
16 #include "stream.h" |
8585 | 17 #include "muxer.h" |
5577 | 18 |
5607 | 19 #include "img_format.h" |
20 #include "mp_image.h" | |
5577 | 21 #include "vf.h" |
22 | |
23 #include <libdv/dv.h> | |
24 | |
25 #ifndef DV_WIDTH | |
26 #define DV_WIDTH 720 | |
27 #define DV_PAL_HEIGHT 576 | |
28 #define DV_NTSC_HEIGHT 480 | |
29 #endif | |
30 | |
31 struct vf_priv_s { | |
8585 | 32 muxer_stream_t* mux; |
5577 | 33 dv_encoder_t* enc; |
34 | |
35 }; | |
36 #define mux_v (vf->priv->mux) | |
37 | |
38 //===========================================================================// | |
39 | |
40 static int config(struct vf_instance_s* vf, | |
41 int width, int height, int d_width, int d_height, | |
42 unsigned int flags, unsigned int outfmt){ | |
43 | |
44 if(width!=DV_WIDTH || (height!=DV_PAL_HEIGHT && height!=DV_NTSC_HEIGHT)){ | |
11261 | 45 mp_msg(MSGT_VFILTER,MSGL_ERR,"DV: only 720x480 (NTSC) and 720x576 (PAL) resolutions allowed! Try with -vf scale=720:480\n"); |
5577 | 46 } |
47 | |
48 vf->priv->enc->isPAL=(height==DV_PAL_HEIGHT); | |
49 vf->priv->enc->is16x9=(d_width/(float)d_height > 1.7); // 16:9=1.777777 | |
50 vf->priv->enc->vlc_encode_passes=3; | |
51 vf->priv->enc->static_qno=0; | |
52 vf->priv->enc->force_dct=0; | |
53 | |
54 mux_v->bih->biWidth=width; | |
55 mux_v->bih->biHeight=height; | |
56 mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8); | |
12061 | 57 mux_v->aspect = (float)d_width/d_height; |
5577 | 58 |
59 return 1; | |
60 } | |
61 | |
62 static int control(struct vf_instance_s* vf, int request, void* data){ | |
63 | |
64 return CONTROL_UNKNOWN; | |
65 } | |
66 | |
67 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
|
68 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
|
69 if(fmt==IMGFMT_RGB24) return VFCAP_CSP_SUPPORTED; |
5577 | 70 return 0; |
71 } | |
72 | |
17906
20aca9baf5d8
passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents:
17487
diff
changeset
|
73 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi, double pts){ |
5577 | 74 |
75 dv_encode_full_frame(vf->priv->enc, mpi->planes, | |
76 (mpi->flags&MP_IMGFLAG_YUV) ? e_dv_color_yuv : e_dv_color_rgb, | |
77 mux_v->buffer); | |
78 | |
17906
20aca9baf5d8
passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents:
17487
diff
changeset
|
79 muxer_write_chunk(mux_v, 480 * (vf->priv->enc->isPAL ? 300 : 250) , 0x10, pts, pts); |
7368 | 80 return 1; |
5577 | 81 } |
82 | |
83 //===========================================================================// | |
84 | |
85 static int vf_open(vf_instance_t *vf, char* args){ | |
86 vf->config=config; | |
14878 | 87 vf->default_caps=VFCAP_CONSTANT; |
5577 | 88 vf->control=control; |
89 vf->query_format=query_format; | |
90 vf->put_image=put_image; | |
91 vf->priv=malloc(sizeof(struct vf_priv_s)); | |
92 memset(vf->priv,0,sizeof(struct vf_priv_s)); | |
8585 | 93 vf->priv->mux=(muxer_stream_t*)args; |
5577 | 94 |
11811
30507afa1cf6
prevent the libdv decoder from adding "NTSC setup" on decode
attila
parents:
11261
diff
changeset
|
95 vf->priv->enc=dv_encoder_new(0,1,1); // FIXME, parse some options! |
5577 | 96 if(!vf->priv->enc) return 0; |
97 | |
14549
acf3241be19b
Initialized BITMAPINFOHEADER to 0 to avoid problems, esp. windows has problems
reimar
parents:
12061
diff
changeset
|
98 mux_v->bih=calloc(1, sizeof(BITMAPINFOHEADER)); |
5577 | 99 mux_v->bih->biSize=sizeof(BITMAPINFOHEADER); |
100 mux_v->bih->biWidth=0; | |
101 mux_v->bih->biHeight=0; | |
102 mux_v->bih->biCompression=mmioFOURCC('d','v','s','d'); | |
103 mux_v->bih->biPlanes=1; | |
104 mux_v->bih->biBitCount=24; | |
105 | |
106 return 1; | |
107 } | |
108 | |
109 vf_info_t ve_info_libdv = { | |
110 "DV encoder using libdv", | |
111 "libdv", | |
112 "A'rpi", | |
113 "for internal use by mencoder", | |
114 vf_open | |
115 }; | |
116 | |
117 //===========================================================================// |