annotate libmpcodecs/vf.c @ 8100:fd0da9a7d2e3

shape adaptive blur (slightly slow though)
author michael
date Mon, 04 Nov 2002 16:42:17 +0000
parents 329e9a5a154f
children 7aa3dba949f1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
1 #include <stdio.h>
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
2 #include <stdlib.h>
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
3 #include <string.h>
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
4
7127
1e47c2e7aa8e mostly compiler warning fixes, some small bugfix
arpi
parents: 7062
diff changeset
5 #include "../config.h"
6188
39a9515c633a warning fixes, patch by Ulrich Hecht <uli@suse.de>
arpi
parents: 6138
diff changeset
6 #ifdef HAVE_MALLOC_H
39a9515c633a warning fixes, patch by Ulrich Hecht <uli@suse.de>
arpi
parents: 6138
diff changeset
7 #include <malloc.h>
39a9515c633a warning fixes, patch by Ulrich Hecht <uli@suse.de>
arpi
parents: 6138
diff changeset
8 #endif
39a9515c633a warning fixes, patch by Ulrich Hecht <uli@suse.de>
arpi
parents: 6138
diff changeset
9
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
10 #include "../mp_msg.h"
6994
c7d6b72b6fc0 messages moved from vf.c and vd.c
jaf
parents: 6993
diff changeset
11 #include "../help_mp.h"
c7d6b72b6fc0 messages moved from vf.c and vd.c
jaf
parents: 6993
diff changeset
12
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
13
5607
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5594
diff changeset
14 #include "img_format.h"
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5594
diff changeset
15 #include "mp_image.h"
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
16 #include "vf.h"
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
17
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
18 extern vf_info_t vf_info_vo;
6820
a99c7700e4f1 New plugin to test crop parameters. Arguments are the same as for the
kmkaplan
parents: 6708
diff changeset
19 extern vf_info_t vf_info_rectangle;
7855
fe88f7403d64 -vop bmovl - BitMap OVerLay videofilter for MPlayer
arpi
parents: 7755
diff changeset
20 extern vf_info_t vf_info_bmovl;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
21 extern vf_info_t vf_info_crop;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
22 extern vf_info_t vf_info_expand;
5512
4ccfa77d8e86 postprocessing filter (fixme: -pp 0)
arpi
parents: 5508
diff changeset
23 extern vf_info_t vf_info_pp;
5522
545c13161589 swscale filter
arpi
parents: 5512
diff changeset
24 extern vf_info_t vf_info_scale;
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
25 #ifdef USE_LIBFAME
5536
3cd118559307 vf_fame added - yv12->mpes converter
arpi
parents: 5529
diff changeset
26 extern vf_info_t vf_info_fame;
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
27 #endif
5539
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
28 extern vf_info_t vf_info_format;
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
29 extern vf_info_t vf_info_yuy2;
5557
2d0b4090497f new filter: flip
arpi
parents: 5550
diff changeset
30 extern vf_info_t vf_info_flip;
5594
dc8ebd9736f4 rgb2bgr converter
arpi
parents: 5565
diff changeset
31 extern vf_info_t vf_info_rgb2bgr;
5696
4a042adc5bd1 rotation/mirror filter
arpi
parents: 5668
diff changeset
32 extern vf_info_t vf_info_rotate;
5763
e9fb293c53d2 Complement existing filters - rotate and flip.
eyck
parents: 5737
diff changeset
33 extern vf_info_t vf_info_mirror;
5774
a300966abeb6 8bpp paletted -> 15/16/24/32 converter
arpi
parents: 5763
diff changeset
34 extern vf_info_t vf_info_palette;
5873
74cbaabeaa33 realtime yv12->mpeg1 with libavcodec qscale=1
arpi
parents: 5845
diff changeset
35 extern vf_info_t vf_info_lavc;
6000
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
36 extern vf_info_t vf_info_dvbscale;
6061
5343ef6b8c23 new filter, to detect best crop size
arpi
parents: 6000
diff changeset
37 extern vf_info_t vf_info_cropdetect;
6278
a88b82461c17 test pattern filter
michael
parents: 6188
diff changeset
38 extern vf_info_t vf_info_test;
6424
83032783f65d noise generating filter
michael
parents: 6278
diff changeset
39 extern vf_info_t vf_info_noise;
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
40 extern vf_info_t vf_info_yvu9;
6859
ed26b2d781e9 new filter to use libavcodec's deinterlacer
arpi
parents: 6820
diff changeset
41 extern vf_info_t vf_info_lavcdeint;
7062
9eae15166ebb soft video equalizer filter, currently supports brightness and
rfelker
parents: 6997
diff changeset
42 extern vf_info_t vf_info_eq;
7517
9d433771b6d0 -vf eq2, LUT-based brightness/contrast/gamma correction (Y-only)
arpi
parents: 7369
diff changeset
43 extern vf_info_t vf_info_eq2;
7155
66019eb62edc "halfpack" (yuv planar 4:2:0 -> packed 4:2:2, half height) video filter
rfelker
parents: 7127
diff changeset
44 extern vf_info_t vf_info_halfpack;
7369
b34b005ab4f8 drop-deinterlace (dint) filter by Andriy N. Gritsenko <andrej@lucky.net>
arpi
parents: 7368
diff changeset
45 extern vf_info_t vf_info_dint;
7755
7637b72ef1f9 new filter: 1bpp - converts 1bpp image to yuv/rgb 8/16/32 bpp
arpi
parents: 7697
diff changeset
46 extern vf_info_t vf_info_1bpp;
7919
b8acdbfd0882 2xSai filter... just for fun, imho useless
arpi
parents: 7855
diff changeset
47 extern vf_info_t vf_info_2xsai;
7966
a03235a5f395 new video filter: unsharp - does image (l/c/l+c) sharping/bluring
arpi
parents: 7919
diff changeset
48 extern vf_info_t vf_info_unsharp;
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents: 7979
diff changeset
49 extern vf_info_t vf_info_swapuv;
8004
30789258ca66 (de)interleave filter (can be used to split/merge an interlaced image so other non interlaced filters an be used with idividual fields)
michael
parents: 8002
diff changeset
50 extern vf_info_t vf_info_il;
8010
329e9a5a154f boxblur, another useless filter
michael
parents: 8004
diff changeset
51 extern vf_info_t vf_info_boxblur;
8100
fd0da9a7d2e3 shape adaptive blur (slightly slow though)
michael
parents: 8010
diff changeset
52 extern vf_info_t vf_info_sab;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
53
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
54 char** vo_plugin_args=(char**) NULL;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
55
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
56 // list of available filters:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
57 static vf_info_t* filter_list[]={
6820
a99c7700e4f1 New plugin to test crop parameters. Arguments are the same as for the
kmkaplan
parents: 6708
diff changeset
58 &vf_info_rectangle,
7855
fe88f7403d64 -vop bmovl - BitMap OVerLay videofilter for MPlayer
arpi
parents: 7755
diff changeset
59 &vf_info_bmovl,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
60 &vf_info_crop,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
61 &vf_info_expand,
5512
4ccfa77d8e86 postprocessing filter (fixme: -pp 0)
arpi
parents: 5508
diff changeset
62 &vf_info_pp,
5522
545c13161589 swscale filter
arpi
parents: 5512
diff changeset
63 &vf_info_scale,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
64 // &vf_info_osd,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
65 &vf_info_vo,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
66 #ifdef USE_LIBFAME
5536
3cd118559307 vf_fame added - yv12->mpes converter
arpi
parents: 5529
diff changeset
67 &vf_info_fame,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
68 #endif
5539
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
69 &vf_info_format,
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
70 &vf_info_yuy2,
5557
2d0b4090497f new filter: flip
arpi
parents: 5550
diff changeset
71 &vf_info_flip,
5594
dc8ebd9736f4 rgb2bgr converter
arpi
parents: 5565
diff changeset
72 &vf_info_rgb2bgr,
5696
4a042adc5bd1 rotation/mirror filter
arpi
parents: 5668
diff changeset
73 &vf_info_rotate,
5763
e9fb293c53d2 Complement existing filters - rotate and flip.
eyck
parents: 5737
diff changeset
74 &vf_info_mirror,
5774
a300966abeb6 8bpp paletted -> 15/16/24/32 converter
arpi
parents: 5763
diff changeset
75 &vf_info_palette,
5874
arpi
parents: 5873
diff changeset
76 #ifdef USE_LIBAVCODEC
5873
74cbaabeaa33 realtime yv12->mpeg1 with libavcodec qscale=1
arpi
parents: 5845
diff changeset
77 &vf_info_lavc,
6859
ed26b2d781e9 new filter to use libavcodec's deinterlacer
arpi
parents: 6820
diff changeset
78 &vf_info_lavcdeint,
5874
arpi
parents: 5873
diff changeset
79 #endif
6000
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
80 &vf_info_dvbscale,
6061
5343ef6b8c23 new filter, to detect best crop size
arpi
parents: 6000
diff changeset
81 &vf_info_cropdetect,
6278
a88b82461c17 test pattern filter
michael
parents: 6188
diff changeset
82 &vf_info_test,
6424
83032783f65d noise generating filter
michael
parents: 6278
diff changeset
83 &vf_info_noise,
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
84 &vf_info_yvu9,
7062
9eae15166ebb soft video equalizer filter, currently supports brightness and
rfelker
parents: 6997
diff changeset
85 &vf_info_eq,
7517
9d433771b6d0 -vf eq2, LUT-based brightness/contrast/gamma correction (Y-only)
arpi
parents: 7369
diff changeset
86 &vf_info_eq2,
7155
66019eb62edc "halfpack" (yuv planar 4:2:0 -> packed 4:2:2, half height) video filter
rfelker
parents: 7127
diff changeset
87 &vf_info_halfpack,
7369
b34b005ab4f8 drop-deinterlace (dint) filter by Andriy N. Gritsenko <andrej@lucky.net>
arpi
parents: 7368
diff changeset
88 &vf_info_dint,
7755
7637b72ef1f9 new filter: 1bpp - converts 1bpp image to yuv/rgb 8/16/32 bpp
arpi
parents: 7697
diff changeset
89 &vf_info_1bpp,
7919
b8acdbfd0882 2xSai filter... just for fun, imho useless
arpi
parents: 7855
diff changeset
90 &vf_info_2xsai,
7966
a03235a5f395 new video filter: unsharp - does image (l/c/l+c) sharping/bluring
arpi
parents: 7919
diff changeset
91 &vf_info_unsharp,
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents: 7979
diff changeset
92 &vf_info_swapuv,
8004
30789258ca66 (de)interleave filter (can be used to split/merge an interlaced image so other non interlaced filters an be used with idividual fields)
michael
parents: 8002
diff changeset
93 &vf_info_il,
8010
329e9a5a154f boxblur, another useless filter
michael
parents: 8004
diff changeset
94 &vf_info_boxblur,
8100
fd0da9a7d2e3 shape adaptive blur (slightly slow though)
michael
parents: 8010
diff changeset
95 &vf_info_sab,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
96 NULL
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
97 };
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
98
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
99 //============================================================================
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
100 // mpi stuff:
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
101
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
102 void vf_mpi_clear(mp_image_t* mpi,int x0,int y0,int w,int h){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
103 int y;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
104 if(mpi->flags&MP_IMGFLAG_PLANAR){
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
105 y0&=~1;h+=h&1;
5663
arpi
parents: 5661
diff changeset
106 if(x0==0 && w==mpi->width){
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
107 // full width clear:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
108 memset(mpi->planes[0]+mpi->stride[0]*y0,0,mpi->stride[0]*h);
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
109 memset(mpi->planes[1]+mpi->stride[1]*(y0>>mpi->chroma_y_shift),128,mpi->stride[1]*(h>>mpi->chroma_y_shift));
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
110 memset(mpi->planes[2]+mpi->stride[2]*(y0>>mpi->chroma_y_shift),128,mpi->stride[2]*(h>>mpi->chroma_y_shift));
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
111 } else
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
112 for(y=y0;y<y0+h;y+=2){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
113 memset(mpi->planes[0]+x0+mpi->stride[0]*y,0,w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
114 memset(mpi->planes[0]+x0+mpi->stride[0]*(y+1),0,w);
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
115 memset(mpi->planes[1]+(x0>>mpi->chroma_x_shift)+mpi->stride[1]*(y>>mpi->chroma_y_shift),128,(w>>mpi->chroma_x_shift));
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
116 memset(mpi->planes[2]+(x0>>mpi->chroma_x_shift)+mpi->stride[2]*(y>>mpi->chroma_y_shift),128,(w>>mpi->chroma_x_shift));
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
117 }
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
118 return;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
119 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
120 // packed:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
121 for(y=y0;y<y0+h;y++){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
122 unsigned char* dst=mpi->planes[0]+mpi->stride[0]*y+(mpi->bpp>>3)*x0;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
123 if(mpi->flags&MP_IMGFLAG_YUV){
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
124 unsigned int* p=(unsigned int*) dst;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
125 int size=(mpi->bpp>>3)*w/4;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
126 int i;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
127 if(mpi->flags&MP_IMGFLAG_SWAPPED){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
128 for(i=0;i<size;i+=4) p[i]=p[i+1]=p[i+2]=p[i+3]=0x00800080;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
129 for(;i<size;i++) p[i]=0x00800080;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
130 } else {
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
131 for(i=0;i<size;i+=4) p[i]=p[i+1]=p[i+2]=p[i+3]=0x80008000;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
132 for(;i<size;i++) p[i]=0x80008000;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
133 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
134 } else
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
135 memset(dst,0,(mpi->bpp>>3)*w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
136 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
137 }
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
138
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
139 mp_image_t* vf_get_image(vf_instance_t* vf, unsigned int outfmt, int mp_imgtype, int mp_imgflag, int w, int h){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
140 mp_image_t* mpi=NULL;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
141 int w2=(mp_imgflag&MP_IMGFLAG_ACCEPT_ALIGNED_STRIDE)?((w+15)&(~15)):w;
6000
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
142
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
143 if(vf->put_image==vf_next_put_image){
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
144 // passthru mode, if the plugin uses the fallback/default put_image() code
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
145 return vf_get_image(vf->next,outfmt,mp_imgtype,mp_imgflag,w,h);
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
146 }
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
147
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
148 // Note: we should call libvo first to check if it supports direct rendering
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
149 // and if not, then fallback to software buffers:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
150 switch(mp_imgtype){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
151 case MP_IMGTYPE_EXPORT:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
152 if(!vf->imgctx.export_images[0]) vf->imgctx.export_images[0]=new_mp_image(w2,h);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
153 mpi=vf->imgctx.export_images[0];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
154 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
155 case MP_IMGTYPE_STATIC:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
156 if(!vf->imgctx.static_images[0]) vf->imgctx.static_images[0]=new_mp_image(w2,h);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
157 mpi=vf->imgctx.static_images[0];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
158 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
159 case MP_IMGTYPE_TEMP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
160 if(!vf->imgctx.temp_images[0]) vf->imgctx.temp_images[0]=new_mp_image(w2,h);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
161 mpi=vf->imgctx.temp_images[0];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
162 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
163 case MP_IMGTYPE_IPB:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
164 if(!(mp_imgflag&MP_IMGFLAG_READABLE)){ // B frame:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
165 if(!vf->imgctx.temp_images[0]) vf->imgctx.temp_images[0]=new_mp_image(w2,h);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
166 mpi=vf->imgctx.temp_images[0];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
167 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
168 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
169 case MP_IMGTYPE_IP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
170 if(!vf->imgctx.static_images[vf->imgctx.static_idx]) vf->imgctx.static_images[vf->imgctx.static_idx]=new_mp_image(w2,h);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
171 mpi=vf->imgctx.static_images[vf->imgctx.static_idx];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
172 vf->imgctx.static_idx^=1;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
173 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
174 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
175 if(mpi){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
176 mpi->type=mp_imgtype;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
177 // keep buffer allocation status & color flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
178 // mpi->flags&=~(MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE|MP_IMGFLAG_DIRECT);
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
179 mpi->flags&=MP_IMGFLAG_ALLOCATED|MP_IMGFLAG_TYPE_DISPLAYED|MP_IMGFLAGMASK_COLORS;
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
180 // accept restrictions & draw_slice flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
181 mpi->flags|=mp_imgflag&(MP_IMGFLAGMASK_RESTRICTIONS|MP_IMGFLAG_DRAW_CALLBACK);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
182 if(!vf->draw_slice) mpi->flags&=~MP_IMGFLAG_DRAW_CALLBACK;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
183 if((mpi->width!=w2 || mpi->height!=h) && !(mpi->flags&MP_IMGFLAG_DIRECT)){
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
184 mpi->width=w2; mpi->chroma_width=w2>>mpi->chroma_x_shift;
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
185 mpi->height=h; mpi->chroma_height=h>>mpi->chroma_y_shift;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
186 if(mpi->flags&MP_IMGFLAG_ALLOCATED){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
187 // need to re-allocate buffer memory:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
188 free(mpi->planes[0]);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
189 mpi->flags&=~MP_IMGFLAG_ALLOCATED;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
190 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
191 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
192 if(!mpi->bpp) mp_image_setfmt(mpi,outfmt);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
193 if(!(mpi->flags&MP_IMGFLAG_ALLOCATED) && mpi->type>MP_IMGTYPE_EXPORT){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
194
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
195 // check libvo first!
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
196 if(vf->get_image) vf->get_image(vf,mpi);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
197
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
198 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
199 // non-direct and not yet allocated image. allocate it!
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
200
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
201 // check if codec prefer aligned stride:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
202 if(mp_imgflag&MP_IMGFLAG_PREFER_ALIGNED_STRIDE){
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
203 int align=(mpi->flags&MP_IMGFLAG_PLANAR &&
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
204 mpi->flags&MP_IMGFLAG_YUV) ?
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
205 (8<<mpi->chroma_x_shift)-1 : 15; // -- maybe FIXME
7697
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
206 w2=((w+align)&(~align));
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
207 if(mpi->width!=w2){
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
208 // we have to change width... check if we CAN co it:
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
209 int flags=vf->query_format(vf,outfmt); // should not fail
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
210 if(!(flags&3)) mp_msg(MSGT_DECVIDEO,MSGL_WARN,"??? vf_get_image{vf->query_format(outfmt)} failed!\n");
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
211 // printf("query -> 0x%X \n",flags);
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
212 if(flags&VFCAP_ACCEPT_STRIDE){
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
213 mpi->width=w2;
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
214 mpi->chroma_width=w2>>mpi->chroma_x_shift;
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
215 }
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
216 }
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
217 }
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
218
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
219 // IF09 - allocate space for 4. plane delta info - unused
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
220 if (mpi->imgfmt == IMGFMT_IF09)
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
221 {
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
222 mpi->planes[0]=memalign(64, mpi->bpp*mpi->width*(mpi->height+2)/8+
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
223 mpi->chroma_width*mpi->chroma_height);
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
224 /* delta table, just for fun ;) */
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
225 mpi->planes[3]=mpi->planes[0]+2*(mpi->chroma_width*mpi->chroma_height);
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
226 }
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
227 else
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
228 mpi->planes[0]=memalign(64, mpi->bpp*mpi->width*(mpi->height+2)/8);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
229 if(mpi->flags&MP_IMGFLAG_PLANAR){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
230 // YV12/I420/YVU9/IF09. feel free to add other planar formats here...
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
231 if(!mpi->stride[0]) mpi->stride[0]=mpi->width;
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
232 if(!mpi->stride[1]) mpi->stride[1]=mpi->stride[2]=mpi->chroma_width;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
233 if(mpi->flags&MP_IMGFLAG_SWAPPED){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
234 // I420/IYUV (Y,U,V)
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
235 mpi->planes[1]=mpi->planes[0]+mpi->width*mpi->height;
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
236 mpi->planes[2]=mpi->planes[1]+mpi->chroma_width*mpi->chroma_height;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
237 } else {
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
238 // YV12,YVU9,IF09 (Y,V,U)
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
239 mpi->planes[2]=mpi->planes[0]+mpi->width*mpi->height;
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
240 mpi->planes[1]=mpi->planes[2]+mpi->chroma_width*mpi->chroma_height;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
241 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
242 } else {
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
243 if(!mpi->stride[0]) mpi->stride[0]=mpi->width*mpi->bpp/8;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
244 }
5663
arpi
parents: 5661
diff changeset
245 vf_mpi_clear(mpi,0,0,mpi->width,mpi->height);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
246 mpi->flags|=MP_IMGFLAG_ALLOCATED;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
247 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
248 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
249 if(!(mpi->flags&MP_IMGFLAG_TYPE_DISPLAYED)){
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
250 mp_msg(MSGT_DECVIDEO,MSGL_V,"*** [%s] %s mp_image_t, %dx%dx%dbpp %s %s, %d bytes\n",
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
251 vf->info->name,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
252 (mpi->type==MP_IMGTYPE_EXPORT)?"Exporting":
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
253 ((mpi->flags&MP_IMGFLAG_DIRECT)?"Direct Rendering":"Allocating"),
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
254 mpi->width,mpi->height,mpi->bpp,
6708
8058078f1248 support for external pp by divx4. some fixes/cosmetics?
alex
parents: 6539
diff changeset
255 (mpi->flags&MP_IMGFLAG_YUV)?"YUV":((mpi->flags&MP_IMGFLAG_SWAPPED)?"BGR":"RGB"),
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
256 (mpi->flags&MP_IMGFLAG_PLANAR)?"planar":"packed",
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
257 mpi->bpp*mpi->width*mpi->height/8);
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
258 mp_msg(MSGT_DECVIDEO,MSGL_DBG2,"(imgfmt: %x, planes: %x,%x,%x strides: %d,%d,%d, chroma: %dx%d, shift: h:%d,v:%d)\n",
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
259 mpi->imgfmt, mpi->planes[0], mpi->planes[1], mpi->planes[2],
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
260 mpi->stride[0], mpi->stride[1], mpi->stride[2],
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
261 mpi->chroma_width, mpi->chroma_height, mpi->chroma_x_shift, mpi->chroma_y_shift);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
262 mpi->flags|=MP_IMGFLAG_TYPE_DISPLAYED;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
263 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
264
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
265 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
266 return mpi;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
267 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
268
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
269 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
270
7979
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
271 // By default vf doesn't accept MPEGPES
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
272 static int vf_default_query_format(struct vf_instance_s* vf, unsigned int fmt){
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
273 if(fmt == IMGFMT_MPEGPES) return 0;
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
274 return vf_next_query_format(vf,fmt);
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
275 }
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
276
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
277 vf_instance_t* vf_open_plugin(vf_info_t** filter_list, vf_instance_t* next, char *name, char *args){
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
278 vf_instance_t* vf;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
279 int i;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
280 for(i=0;;i++){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
281 if(!filter_list[i]){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
282 mp_msg(MSGT_VFILTER,MSGL_ERR,MSGTR_CouldNotFindVideoFilter,name);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
283 return NULL; // no such filter!
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
284 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
285 if(!strcmp(filter_list[i]->name,name)) break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
286 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
287 vf=malloc(sizeof(vf_instance_t));
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
288 memset(vf,0,sizeof(vf_instance_t));
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
289 vf->info=filter_list[i];
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
290 vf->next=next;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
291 vf->config=vf_next_config;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
292 vf->control=vf_next_control;
7979
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
293 vf->query_format=vf_default_query_format;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
294 vf->put_image=vf_next_put_image;
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
295 vf->default_caps=VFCAP_ACCEPT_STRIDE;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
296 vf->default_reqs=0;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
297 if(vf->info->open(vf,args)>0) return vf; // Success!
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
298 free(vf);
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
299 mp_msg(MSGT_VFILTER,MSGL_ERR,MSGTR_CouldNotOpenVideoFilter,name);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
300 return NULL;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
301 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
302
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
303 vf_instance_t* vf_open_filter(vf_instance_t* next, char *name, char *args){
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
304 if(strcmp(name,"vo"))
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
305 mp_msg(MSGT_VFILTER,MSGL_INFO,
6997
85fc65e6667f arpi told me ...
jaf
parents: 6994
diff changeset
306 args ? MSGTR_OpeningVideoFilter "[%s=%s]\n"
85fc65e6667f arpi told me ...
jaf
parents: 6994
diff changeset
307 : MSGTR_OpeningVideoFilter "[%s]\n",name,args);
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
308 return vf_open_plugin(filter_list,next,name,args);
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
309 }
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
310
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
311 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
312
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
313 unsigned int vf_match_csp(vf_instance_t** vfp,unsigned int* list,unsigned int preferred){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
314 vf_instance_t* vf=*vfp;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
315 unsigned int* p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
316 unsigned int best=0;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
317 int ret;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
318 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
319 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
320 mp_msg(MSGT_VFILTER,MSGL_V,"[%s] query(%s) -> %d\n",vf->info->name,vo_format_name(*p),ret&3);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
321 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
322 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
323 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
324 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
325 if(best) return best; // bingo, they have common csp!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
326 // ok, then try with scale:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
327 if(vf->info == &vf_info_scale) return 0; // avoid infinite recursion!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
328 vf=vf_open_filter(vf,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
329 if(!vf) return 0; // failed to init "scale"
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
330 // try the preferred csp first:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
331 if(preferred && vf->query_format(vf,preferred)) best=preferred; else
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
332 // try the list again, now with "scaler" :
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
333 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
334 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
335 mp_msg(MSGT_VFILTER,MSGL_V,"[%s] query(%s) -> %d\n",vf->info->name,vo_format_name(*p),ret&3);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
336 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
337 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
338 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
339 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
340 if(best) *vfp=vf; // else uninit vf !FIXME!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
341 return best;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
342 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
343
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
344 int vf_next_config(struct vf_instance_s* vf,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
345 int width, int height, int d_width, int d_height,
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
346 unsigned int voflags, unsigned int outfmt){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
347 int miss;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
348 int flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
349 if(!flags){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
350 // hmm. colorspace mismatch!!!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
351 // let's insert the 'scale' filter, it does the job for us:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
352 vf_instance_t* vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
353 if(vf->next->info==&vf_info_scale) return 0; // scale->scale
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
354 vf2=vf_open_filter(vf->next,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
355 if(!vf2) return 0; // shouldn't happen!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
356 vf->next=vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
357 flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
358 if(!flags){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
359 mp_msg(MSGT_VFILTER,MSGL_ERR,MSGTR_CannotFindColorspace);
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
360 return 0; // FAIL
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
361 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
362 }
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
363 mp_msg(MSGT_VFILTER,MSGL_V,"REQ: flags=0x%X req=0x%X \n",flags,vf->default_reqs);
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
364 miss=vf->default_reqs - (flags&vf->default_reqs);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
365 if(miss&VFCAP_ACCEPT_STRIDE){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
366 // vf requires stride support but vf->next doesn't support it!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
367 // let's insert the 'expand' filter, it does the job for us:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
368 vf_instance_t* vf2=vf_open_filter(vf->next,"expand",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
369 if(!vf2) return 0; // shouldn't happen!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
370 vf->next=vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
371 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
372 return vf->next->config(vf->next,width,height,d_width,d_height,voflags,outfmt);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
373 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
374
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
375 int vf_next_control(struct vf_instance_s* vf, int request, void* data){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
376 return vf->next->control(vf->next,request,data);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
377 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
378
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
379 int vf_next_query_format(struct vf_instance_s* vf, unsigned int fmt){
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
380 int flags=vf->next->query_format(vf->next,fmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
381 if(flags) flags|=vf->default_caps;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
382 return flags;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
383 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
384
7368
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 7155
diff changeset
385 int vf_next_put_image(struct vf_instance_s* vf,mp_image_t *mpi){
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 7155
diff changeset
386 return vf->next->put_image(vf->next,mpi);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
387 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
388
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
389 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
390
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
391 vf_instance_t* append_filters(vf_instance_t* last){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
392 vf_instance_t* vf;
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
393 char** plugin_args = vo_plugin_args;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
394 if(!vo_plugin_args) return last;
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
395 while(*plugin_args){
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
396 char* name=strdup(*plugin_args);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
397 char* args=strchr(name,'=');
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
398 if(args){args[0]=0;++args;}
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
399 vf=vf_open_filter(last,name,args);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
400 if(vf) last=vf;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
401 free(name);
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
402 ++plugin_args;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
403 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
404 return last;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
405 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
406
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
407 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
408
5737
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
409 void vf_uninit_filter(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
410 if(vf->uninit) vf->uninit(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
411 free_mp_image(vf->imgctx.static_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
412 free_mp_image(vf->imgctx.static_images[1]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
413 free_mp_image(vf->imgctx.temp_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
414 free_mp_image(vf->imgctx.export_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
415 free(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
416 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
417
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
418 void vf_uninit_filter_chain(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
419 while(vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
420 vf_instance_t* next=vf->next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
421 vf_uninit_filter(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
422 vf=next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
423 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
424 }
6081
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
425
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
426 void vf_list_plugins(){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
427 int i=0;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
428 while(filter_list[i]){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
429 mp_msg(MSGT_VFILTER,MSGL_INFO,"\t%-10s: %s\n",filter_list[i]->name,filter_list[i]->info);
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
430 i++;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
431 }
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
432 }