annotate libmpcodecs/vf.c @ 7966:a03235a5f395

new video filter: unsharp - does image (l/c/l+c) sharping/bluring by Rmi Guyomarch <rguyom@pobox.com>
author arpi
date Tue, 29 Oct 2002 22:37:11 +0000
parents b8acdbfd0882
children 64f468cbedcd
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;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
49
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
50 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
51
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
52 // list of available filters:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
53 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
54 &vf_info_rectangle,
7855
fe88f7403d64 -vop bmovl - BitMap OVerLay videofilter for MPlayer
arpi
parents: 7755
diff changeset
55 &vf_info_bmovl,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
56 &vf_info_crop,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
57 &vf_info_expand,
5512
4ccfa77d8e86 postprocessing filter (fixme: -pp 0)
arpi
parents: 5508
diff changeset
58 &vf_info_pp,
5522
545c13161589 swscale filter
arpi
parents: 5512
diff changeset
59 &vf_info_scale,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
60 // &vf_info_osd,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
61 &vf_info_vo,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
62 #ifdef USE_LIBFAME
5536
3cd118559307 vf_fame added - yv12->mpes converter
arpi
parents: 5529
diff changeset
63 &vf_info_fame,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
64 #endif
5539
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
65 &vf_info_format,
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
66 &vf_info_yuy2,
5557
2d0b4090497f new filter: flip
arpi
parents: 5550
diff changeset
67 &vf_info_flip,
5594
dc8ebd9736f4 rgb2bgr converter
arpi
parents: 5565
diff changeset
68 &vf_info_rgb2bgr,
5696
4a042adc5bd1 rotation/mirror filter
arpi
parents: 5668
diff changeset
69 &vf_info_rotate,
5763
e9fb293c53d2 Complement existing filters - rotate and flip.
eyck
parents: 5737
diff changeset
70 &vf_info_mirror,
5774
a300966abeb6 8bpp paletted -> 15/16/24/32 converter
arpi
parents: 5763
diff changeset
71 &vf_info_palette,
5874
arpi
parents: 5873
diff changeset
72 #ifdef USE_LIBAVCODEC
5873
74cbaabeaa33 realtime yv12->mpeg1 with libavcodec qscale=1
arpi
parents: 5845
diff changeset
73 &vf_info_lavc,
6859
ed26b2d781e9 new filter to use libavcodec's deinterlacer
arpi
parents: 6820
diff changeset
74 &vf_info_lavcdeint,
5874
arpi
parents: 5873
diff changeset
75 #endif
6000
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
76 &vf_info_dvbscale,
6061
5343ef6b8c23 new filter, to detect best crop size
arpi
parents: 6000
diff changeset
77 &vf_info_cropdetect,
6278
a88b82461c17 test pattern filter
michael
parents: 6188
diff changeset
78 &vf_info_test,
6424
83032783f65d noise generating filter
michael
parents: 6278
diff changeset
79 &vf_info_noise,
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
80 &vf_info_yvu9,
7062
9eae15166ebb soft video equalizer filter, currently supports brightness and
rfelker
parents: 6997
diff changeset
81 &vf_info_eq,
7517
9d433771b6d0 -vf eq2, LUT-based brightness/contrast/gamma correction (Y-only)
arpi
parents: 7369
diff changeset
82 &vf_info_eq2,
7155
66019eb62edc "halfpack" (yuv planar 4:2:0 -> packed 4:2:2, half height) video filter
rfelker
parents: 7127
diff changeset
83 &vf_info_halfpack,
7369
b34b005ab4f8 drop-deinterlace (dint) filter by Andriy N. Gritsenko <andrej@lucky.net>
arpi
parents: 7368
diff changeset
84 &vf_info_dint,
7755
7637b72ef1f9 new filter: 1bpp - converts 1bpp image to yuv/rgb 8/16/32 bpp
arpi
parents: 7697
diff changeset
85 &vf_info_1bpp,
7919
b8acdbfd0882 2xSai filter... just for fun, imho useless
arpi
parents: 7855
diff changeset
86 &vf_info_2xsai,
7966
a03235a5f395 new video filter: unsharp - does image (l/c/l+c) sharping/bluring
arpi
parents: 7919
diff changeset
87 &vf_info_unsharp,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
88 NULL
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
89 };
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
90
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
91 //============================================================================
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
92 // mpi stuff:
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
93
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
94 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
95 int y;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
96 if(mpi->flags&MP_IMGFLAG_PLANAR){
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
97 y0&=~1;h+=h&1;
5663
arpi
parents: 5661
diff changeset
98 if(x0==0 && w==mpi->width){
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
99 // full width clear:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
100 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
101 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
102 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
103 } else
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
104 for(y=y0;y<y0+h;y+=2){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
105 memset(mpi->planes[0]+x0+mpi->stride[0]*y,0,w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
106 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
107 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
108 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
109 }
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
110 return;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
111 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
112 // packed:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
113 for(y=y0;y<y0+h;y++){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
114 unsigned char* dst=mpi->planes[0]+mpi->stride[0]*y+(mpi->bpp>>3)*x0;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
115 if(mpi->flags&MP_IMGFLAG_YUV){
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
116 unsigned int* p=(unsigned int*) dst;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
117 int size=(mpi->bpp>>3)*w/4;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
118 int i;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
119 if(mpi->flags&MP_IMGFLAG_SWAPPED){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
120 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
121 for(;i<size;i++) p[i]=0x00800080;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
122 } else {
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
123 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
124 for(;i<size;i++) p[i]=0x80008000;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
125 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
126 } else
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
127 memset(dst,0,(mpi->bpp>>3)*w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
128 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
129 }
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
130
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
131 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
132 mp_image_t* mpi=NULL;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
133 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
134
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
135 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
136 // 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
137 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
138 }
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
139
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
140 // 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
141 // 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
142 switch(mp_imgtype){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
143 case MP_IMGTYPE_EXPORT:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
144 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
145 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
146 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
147 case MP_IMGTYPE_STATIC:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
148 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
149 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
150 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
151 case MP_IMGTYPE_TEMP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
152 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
153 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
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_IPB:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
156 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
157 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
158 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
159 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
160 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
161 case MP_IMGTYPE_IP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
162 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
163 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
164 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
165 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
166 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
167 if(mpi){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
168 mpi->type=mp_imgtype;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
169 // keep buffer allocation status & color flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
170 // mpi->flags&=~(MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE|MP_IMGFLAG_DIRECT);
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
171 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
172 // accept restrictions & draw_slice flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
173 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
174 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
175 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
176 mpi->width=w2; mpi->chroma_width=w2>>mpi->chroma_x_shift;
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
177 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
178 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
179 // 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
180 free(mpi->planes[0]);
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
181 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
182 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
183 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
184 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
185 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
186
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
187 // check libvo first!
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
188 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
189
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
190 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
191 // non-direct and not yet allocated image. allocate it!
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
192
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
193 // check if codec prefer aligned stride:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
194 if(mp_imgflag&MP_IMGFLAG_PREFER_ALIGNED_STRIDE){
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
195 int align=(mpi->flags&MP_IMGFLAG_PLANAR &&
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
196 mpi->flags&MP_IMGFLAG_YUV) ?
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
197 (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
198 w2=((w+align)&(~align));
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
199 if(mpi->width!=w2){
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
200 // 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
201 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
202 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
203 // 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
204 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
205 mpi->width=w2;
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
206 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
207 }
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
208 }
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
209 }
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
210
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
211 // 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
212 if (mpi->imgfmt == IMGFMT_IF09)
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
213 {
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
214 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
215 mpi->chroma_width*mpi->chroma_height);
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
216 /* delta table, just for fun ;) */
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
217 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
218 }
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
219 else
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
220 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
221 if(mpi->flags&MP_IMGFLAG_PLANAR){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
222 // 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
223 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
224 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
225 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
226 // 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
227 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
228 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
229 } else {
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
230 // 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
231 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
232 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
233 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
234 } else {
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
235 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
236 }
5663
arpi
parents: 5661
diff changeset
237 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
238 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
239 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
240 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
241 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
242 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
243 vf->info->name,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
244 (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
245 ((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
246 mpi->width,mpi->height,mpi->bpp,
6708
8058078f1248 support for external pp by divx4. some fixes/cosmetics?
alex
parents: 6539
diff changeset
247 (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
248 (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
249 mpi->bpp*mpi->width*mpi->height/8);
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
250 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
251 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
252 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
253 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
254 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
255 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
256
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
257 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
258 return mpi;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
259 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
260
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
261 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
262
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
263 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
264 vf_instance_t* vf;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
265 int i;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
266 for(i=0;;i++){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
267 if(!filter_list[i]){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
268 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
269 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
270 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
271 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
272 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
273 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
274 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
275 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
276 vf->next=next;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
277 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
278 vf->control=vf_next_control;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
279 vf->query_format=vf_next_query_format;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
280 vf->put_image=vf_next_put_image;
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
281 vf->default_caps=VFCAP_ACCEPT_STRIDE;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
282 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
283 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
284 free(vf);
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
285 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
286 return NULL;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
287 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
288
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
289 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
290 if(strcmp(name,"vo"))
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
291 mp_msg(MSGT_VFILTER,MSGL_INFO,
6997
85fc65e6667f arpi told me ...
jaf
parents: 6994
diff changeset
292 args ? MSGTR_OpeningVideoFilter "[%s=%s]\n"
85fc65e6667f arpi told me ...
jaf
parents: 6994
diff changeset
293 : MSGTR_OpeningVideoFilter "[%s]\n",name,args);
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
294 return vf_open_plugin(filter_list,next,name,args);
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
295 }
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
296
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
297 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
298
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
299 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
300 vf_instance_t* vf=*vfp;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
301 unsigned int* p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
302 unsigned int best=0;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
303 int ret;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
304 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
305 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
306 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
307 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
308 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
309 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
310 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
311 if(best) return best; // bingo, they have common csp!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
312 // ok, then try with scale:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
313 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
314 vf=vf_open_filter(vf,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
315 if(!vf) return 0; // failed to init "scale"
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
316 // try the preferred csp first:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
317 if(preferred && vf->query_format(vf,preferred)) best=preferred; else
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
318 // try the list again, now with "scaler" :
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
319 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
320 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
321 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
322 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
323 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
324 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
325 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
326 if(best) *vfp=vf; // else uninit vf !FIXME!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
327 return best;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
328 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
329
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
330 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
331 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
332 unsigned int voflags, unsigned int outfmt){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
333 int miss;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
334 int flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
335 if(!flags){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
336 // hmm. colorspace mismatch!!!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
337 // 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
338 vf_instance_t* vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
339 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
340 vf2=vf_open_filter(vf->next,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
341 if(!vf2) return 0; // shouldn't happen!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
342 vf->next=vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
343 flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
344 if(!flags){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
345 mp_msg(MSGT_VFILTER,MSGL_ERR,MSGTR_CannotFindColorspace);
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
346 return 0; // FAIL
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
347 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
348 }
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
349 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
350 miss=vf->default_reqs - (flags&vf->default_reqs);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
351 if(miss&VFCAP_ACCEPT_STRIDE){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
352 // 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
353 // 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
354 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
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 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
358 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
359 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
360
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
361 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
362 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
363 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
364
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
365 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
366 int flags=vf->next->query_format(vf->next,fmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
367 if(flags) flags|=vf->default_caps;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
368 return flags;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
369 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
370
7368
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 7155
diff changeset
371 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
372 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
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 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
376
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
377 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
378 vf_instance_t* vf;
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
379 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
380 if(!vo_plugin_args) return last;
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
381 while(*plugin_args){
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
382 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
383 char* args=strchr(name,'=');
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
384 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
385 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
386 if(vf) last=vf;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
387 free(name);
5843
1092c4fc8b24 Don't break the pointer for the next file.
albeu
parents: 5840
diff changeset
388 ++plugin_args;
5507
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 return last;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
391 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
392
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
393 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
394
5737
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
395 void vf_uninit_filter(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
396 if(vf->uninit) vf->uninit(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
397 free_mp_image(vf->imgctx.static_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
398 free_mp_image(vf->imgctx.static_images[1]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
399 free_mp_image(vf->imgctx.temp_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
400 free_mp_image(vf->imgctx.export_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
401 free(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
402 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
403
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
404 void vf_uninit_filter_chain(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
405 while(vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
406 vf_instance_t* next=vf->next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
407 vf_uninit_filter(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
408 vf=next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
409 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
410 }
6081
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
411
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
412 void vf_list_plugins(){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
413 int i=0;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
414 while(filter_list[i]){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
415 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
416 i++;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
417 }
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
418 }