annotate libmpcodecs/vf.c @ 10064:b4aaa64d6354

Error in the aspect ratio calculation, plus typos and rewordings. Noticed by Jason Tackaberry <tack@auc.ca>.
author diego
date Sun, 04 May 2003 23:21:24 +0000
parents 6293e6f02fe3
children 30cad6ad9dbc
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"
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
12 #include "../m_option.h"
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
13 #include "../m_struct.h"
6994
c7d6b72b6fc0 messages moved from vf.c and vd.c
jaf
parents: 6993
diff changeset
14
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
15
5607
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5594
diff changeset
16 #include "img_format.h"
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5594
diff changeset
17 #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
18 #include "vf.h"
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
19
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
20 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
21 extern vf_info_t vf_info_rectangle;
9832
298e261aecd7 disable vf_bmovl for systems without posix select
faust3
parents: 9593
diff changeset
22 #ifndef HAVE_NO_POSIX_SELECT
7855
fe88f7403d64 -vop bmovl - BitMap OVerLay videofilter for MPlayer
arpi
parents: 7755
diff changeset
23 extern vf_info_t vf_info_bmovl;
9832
298e261aecd7 disable vf_bmovl for systems without posix select
faust3
parents: 9593
diff changeset
24 #endif
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
25 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
26 extern vf_info_t vf_info_expand;
5512
4ccfa77d8e86 postprocessing filter (fixme: -pp 0)
arpi
parents: 5508
diff changeset
27 extern vf_info_t vf_info_pp;
5522
545c13161589 swscale filter
arpi
parents: 5512
diff changeset
28 extern vf_info_t vf_info_scale;
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
29 #ifdef USE_LIBFAME
5536
3cd118559307 vf_fame added - yv12->mpes converter
arpi
parents: 5529
diff changeset
30 extern vf_info_t vf_info_fame;
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
31 #endif
5539
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
32 extern vf_info_t vf_info_format;
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
33 extern vf_info_t vf_info_yuy2;
5557
2d0b4090497f new filter: flip
arpi
parents: 5550
diff changeset
34 extern vf_info_t vf_info_flip;
5594
dc8ebd9736f4 rgb2bgr converter
arpi
parents: 5565
diff changeset
35 extern vf_info_t vf_info_rgb2bgr;
5696
4a042adc5bd1 rotation/mirror filter
arpi
parents: 5668
diff changeset
36 extern vf_info_t vf_info_rotate;
5763
e9fb293c53d2 Complement existing filters - rotate and flip.
eyck
parents: 5737
diff changeset
37 extern vf_info_t vf_info_mirror;
5774
a300966abeb6 8bpp paletted -> 15/16/24/32 converter
arpi
parents: 5763
diff changeset
38 extern vf_info_t vf_info_palette;
5873
74cbaabeaa33 realtime yv12->mpeg1 with libavcodec qscale=1
arpi
parents: 5845
diff changeset
39 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
40 extern vf_info_t vf_info_dvbscale;
6061
5343ef6b8c23 new filter, to detect best crop size
arpi
parents: 6000
diff changeset
41 extern vf_info_t vf_info_cropdetect;
6278
a88b82461c17 test pattern filter
michael
parents: 6188
diff changeset
42 extern vf_info_t vf_info_test;
6424
83032783f65d noise generating filter
michael
parents: 6278
diff changeset
43 extern vf_info_t vf_info_noise;
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
44 extern vf_info_t vf_info_yvu9;
6859
ed26b2d781e9 new filter to use libavcodec's deinterlacer
arpi
parents: 6820
diff changeset
45 extern vf_info_t vf_info_lavcdeint;
7062
9eae15166ebb soft video equalizer filter, currently supports brightness and
rfelker
parents: 6997
diff changeset
46 extern vf_info_t vf_info_eq;
7517
9d433771b6d0 -vf eq2, LUT-based brightness/contrast/gamma correction (Y-only)
arpi
parents: 7369
diff changeset
47 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
48 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
49 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
50 extern vf_info_t vf_info_1bpp;
7919
b8acdbfd0882 2xSai filter... just for fun, imho useless
arpi
parents: 7855
diff changeset
51 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
52 extern vf_info_t vf_info_unsharp;
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents: 7979
diff changeset
53 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
54 extern vf_info_t vf_info_il;
8010
329e9a5a154f boxblur, another useless filter
michael
parents: 8004
diff changeset
55 extern vf_info_t vf_info_boxblur;
8100
fd0da9a7d2e3 shape adaptive blur (slightly slow though)
michael
parents: 8010
diff changeset
56 extern vf_info_t vf_info_sab;
8106
7aa3dba949f1 smartblur
michael
parents: 8100
diff changeset
57 extern vf_info_t vf_info_smartblur;
8112
6d97e935a071 perspective correcture filter
michael
parents: 8106
diff changeset
58 extern vf_info_t vf_info_perspective;
9404
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents: 9179
diff changeset
59 extern vf_info_t vf_info_down3dright;
9072
d7237ee9db7f new video filter to extract a single field using stride arithmetic,
rfelker
parents: 8631
diff changeset
60 extern vf_info_t vf_info_field;
9179
e93a0dd3ed56 new video filter: denoise3d - temporal&spatial noise reduction
arpi
parents: 9072
diff changeset
61 extern vf_info_t vf_info_denoise3d;
9441
85fa92f14e99 vf_hqdn3d: High-Quality version of the denoise3d filter
arpi
parents: 9404
diff changeset
62 extern vf_info_t vf_info_hqdn3d;
9467
9fae4150ec43 experimental de-telecine filter. not documented or configurable yet,
rfelker
parents: 9441
diff changeset
63 extern vf_info_t vf_info_detc;
9468
356963ad4784 filter for applying 3:2 telecine to 23.976 fps progressive material.
rfelker
parents: 9467
diff changeset
64 extern vf_info_t vf_info_telecine;
9514
08264c647f46 new filter
rfelker
parents: 9490
diff changeset
65 extern vf_info_t vf_info_tfields;
9933
3548701a13fe 1. new alternate approach to inverse telecine! much better!
rfelker
parents: 9832
diff changeset
66 extern vf_info_t vf_info_ivtc;
3548701a13fe 1. new alternate approach to inverse telecine! much better!
rfelker
parents: 9832
diff changeset
67 extern vf_info_t vf_info_ilpack;
10006
6293e6f02fe3 display size/aspect adjusting filter
rfelker
parents: 9934
diff changeset
68 extern vf_info_t vf_info_dsize;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
69
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
70 // list of available filters:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
71 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
72 &vf_info_rectangle,
9832
298e261aecd7 disable vf_bmovl for systems without posix select
faust3
parents: 9593
diff changeset
73 #ifndef HAVE_NO_POSIX_SELECT
7855
fe88f7403d64 -vop bmovl - BitMap OVerLay videofilter for MPlayer
arpi
parents: 7755
diff changeset
74 &vf_info_bmovl,
9832
298e261aecd7 disable vf_bmovl for systems without posix select
faust3
parents: 9593
diff changeset
75 #endif
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
76 &vf_info_crop,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
77 &vf_info_expand,
9531
46340b0f5a91 fix for a couple of linking problems patch by (Ambrose Li <a.c.li at ieee dot org>)
michael
parents: 9514
diff changeset
78 #ifdef USE_LIBAVCODEC
5512
4ccfa77d8e86 postprocessing filter (fixme: -pp 0)
arpi
parents: 5508
diff changeset
79 &vf_info_pp,
9531
46340b0f5a91 fix for a couple of linking problems patch by (Ambrose Li <a.c.li at ieee dot org>)
michael
parents: 9514
diff changeset
80 #endif
5522
545c13161589 swscale filter
arpi
parents: 5512
diff changeset
81 &vf_info_scale,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
82 // &vf_info_osd,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
83 &vf_info_vo,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
84 #ifdef USE_LIBFAME
5536
3cd118559307 vf_fame added - yv12->mpes converter
arpi
parents: 5529
diff changeset
85 &vf_info_fame,
5845
265acdb8542d Correct my half reverse commit. Sorry Atmos.
albeu
parents: 5843
diff changeset
86 #endif
5539
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
87 &vf_info_format,
eefc339440bc 2 new simple filters: yuy2 and format
arpi
parents: 5536
diff changeset
88 &vf_info_yuy2,
5557
2d0b4090497f new filter: flip
arpi
parents: 5550
diff changeset
89 &vf_info_flip,
5594
dc8ebd9736f4 rgb2bgr converter
arpi
parents: 5565
diff changeset
90 &vf_info_rgb2bgr,
5696
4a042adc5bd1 rotation/mirror filter
arpi
parents: 5668
diff changeset
91 &vf_info_rotate,
5763
e9fb293c53d2 Complement existing filters - rotate and flip.
eyck
parents: 5737
diff changeset
92 &vf_info_mirror,
5774
a300966abeb6 8bpp paletted -> 15/16/24/32 converter
arpi
parents: 5763
diff changeset
93 &vf_info_palette,
5874
arpi
parents: 5873
diff changeset
94 #ifdef USE_LIBAVCODEC
5873
74cbaabeaa33 realtime yv12->mpeg1 with libavcodec qscale=1
arpi
parents: 5845
diff changeset
95 &vf_info_lavc,
6859
ed26b2d781e9 new filter to use libavcodec's deinterlacer
arpi
parents: 6820
diff changeset
96 &vf_info_lavcdeint,
5874
arpi
parents: 5873
diff changeset
97 #endif
6000
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
98 &vf_info_dvbscale,
6061
5343ef6b8c23 new filter, to detect best crop size
arpi
parents: 6000
diff changeset
99 &vf_info_cropdetect,
6278
a88b82461c17 test pattern filter
michael
parents: 6188
diff changeset
100 &vf_info_test,
6424
83032783f65d noise generating filter
michael
parents: 6278
diff changeset
101 &vf_info_noise,
6486
c0d84f46d349 yvu9 support
alex
parents: 6424
diff changeset
102 &vf_info_yvu9,
7062
9eae15166ebb soft video equalizer filter, currently supports brightness and
rfelker
parents: 6997
diff changeset
103 &vf_info_eq,
7517
9d433771b6d0 -vf eq2, LUT-based brightness/contrast/gamma correction (Y-only)
arpi
parents: 7369
diff changeset
104 &vf_info_eq2,
7155
66019eb62edc "halfpack" (yuv planar 4:2:0 -> packed 4:2:2, half height) video filter
rfelker
parents: 7127
diff changeset
105 &vf_info_halfpack,
7369
b34b005ab4f8 drop-deinterlace (dint) filter by Andriy N. Gritsenko <andrej@lucky.net>
arpi
parents: 7368
diff changeset
106 &vf_info_dint,
7755
7637b72ef1f9 new filter: 1bpp - converts 1bpp image to yuv/rgb 8/16/32 bpp
arpi
parents: 7697
diff changeset
107 &vf_info_1bpp,
7919
b8acdbfd0882 2xSai filter... just for fun, imho useless
arpi
parents: 7855
diff changeset
108 &vf_info_2xsai,
7966
a03235a5f395 new video filter: unsharp - does image (l/c/l+c) sharping/bluring
arpi
parents: 7919
diff changeset
109 &vf_info_unsharp,
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents: 7979
diff changeset
110 &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
111 &vf_info_il,
8010
329e9a5a154f boxblur, another useless filter
michael
parents: 8004
diff changeset
112 &vf_info_boxblur,
8100
fd0da9a7d2e3 shape adaptive blur (slightly slow though)
michael
parents: 8010
diff changeset
113 &vf_info_sab,
8106
7aa3dba949f1 smartblur
michael
parents: 8100
diff changeset
114 &vf_info_smartblur,
8112
6d97e935a071 perspective correcture filter
michael
parents: 8106
diff changeset
115 &vf_info_perspective,
9404
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents: 9179
diff changeset
116 &vf_info_down3dright,
9072
d7237ee9db7f new video filter to extract a single field using stride arithmetic,
rfelker
parents: 8631
diff changeset
117 &vf_info_field,
9179
e93a0dd3ed56 new video filter: denoise3d - temporal&spatial noise reduction
arpi
parents: 9072
diff changeset
118 &vf_info_denoise3d,
9441
85fa92f14e99 vf_hqdn3d: High-Quality version of the denoise3d filter
arpi
parents: 9404
diff changeset
119 &vf_info_hqdn3d,
9467
9fae4150ec43 experimental de-telecine filter. not documented or configurable yet,
rfelker
parents: 9441
diff changeset
120 &vf_info_detc,
9468
356963ad4784 filter for applying 3:2 telecine to 23.976 fps progressive material.
rfelker
parents: 9467
diff changeset
121 &vf_info_telecine,
9514
08264c647f46 new filter
rfelker
parents: 9490
diff changeset
122 &vf_info_tfields,
9933
3548701a13fe 1. new alternate approach to inverse telecine! much better!
rfelker
parents: 9832
diff changeset
123 &vf_info_ivtc,
3548701a13fe 1. new alternate approach to inverse telecine! much better!
rfelker
parents: 9832
diff changeset
124 &vf_info_ilpack,
10006
6293e6f02fe3 display size/aspect adjusting filter
rfelker
parents: 9934
diff changeset
125 &vf_info_dsize,
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
126 NULL
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
127 };
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
128
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
129 // For the vf option
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
130 m_obj_settings_t* vf_settings = NULL;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
131 // For the vop option
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
132 m_obj_settings_t* vo_plugin_args = NULL;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
133 m_obj_list_t vf_obj_list = {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
134 (void**)filter_list,
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
135 M_ST_OFF(vf_info_t,name),
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
136 M_ST_OFF(vf_info_t,info),
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
137 M_ST_OFF(vf_info_t,opts)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
138 };
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
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 //============================================================================
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
141 // mpi stuff:
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
142
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
143 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
144 int y;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
145 if(mpi->flags&MP_IMGFLAG_PLANAR){
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
146 y0&=~1;h+=h&1;
5663
arpi
parents: 5661
diff changeset
147 if(x0==0 && w==mpi->width){
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
148 // full width clear:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
149 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
150 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
151 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
152 } else
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
153 for(y=y0;y<y0+h;y+=2){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
154 memset(mpi->planes[0]+x0+mpi->stride[0]*y,0,w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
155 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
156 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
157 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
158 }
5668
978c6f78022e align yuv 4:2:0 y position by 2
arpi
parents: 5663
diff changeset
159 return;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
160 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
161 // packed:
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
162 for(y=y0;y<y0+h;y++){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
163 unsigned char* dst=mpi->planes[0]+mpi->stride[0]*y+(mpi->bpp>>3)*x0;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
164 if(mpi->flags&MP_IMGFLAG_YUV){
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
165 unsigned int* p=(unsigned int*) dst;
5661
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
166 int size=(mpi->bpp>>3)*w/4;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
167 int i;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
168 if(mpi->flags&MP_IMGFLAG_SWAPPED){
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
169 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
170 for(;i<size;i++) p[i]=0x00800080;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
171 } else {
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
172 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
173 for(;i<size;i++) p[i]=0x80008000;
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
174 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
175 } else
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
176 memset(dst,0,(mpi->bpp>>3)*w);
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
177 }
42e002c565cf mpi clear func
arpi
parents: 5607
diff changeset
178 }
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
179
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
180 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
181 mp_image_t* mpi=NULL;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
182 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
183
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
184 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
185 // 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
186 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
187 }
34e396477d36 passthru mode for filters which don't alter image just config parameters (query_format/control/config)
arpi
parents: 5874
diff changeset
188
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
189 // 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
190 // 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
191 switch(mp_imgtype){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
192 case MP_IMGTYPE_EXPORT:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
193 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
194 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
195 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
196 case MP_IMGTYPE_STATIC:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
197 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
198 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
199 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
200 case MP_IMGTYPE_TEMP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
201 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
202 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
203 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
204 case MP_IMGTYPE_IPB:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
205 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
206 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
207 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
208 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
209 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
210 case MP_IMGTYPE_IP:
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
211 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
212 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
213 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
214 break;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
215 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
216 if(mpi){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
217 mpi->type=mp_imgtype;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
218 // keep buffer allocation status & color flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
219 // mpi->flags&=~(MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE|MP_IMGFLAG_DIRECT);
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
220 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
221 // accept restrictions & draw_slice flags only:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
222 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
223 if(!vf->draw_slice) mpi->flags&=~MP_IMGFLAG_DRAW_CALLBACK;
8631
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
224 if(mpi->width!=w2 || mpi->height!=h){
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
225 // printf("vf.c: MPI parameters changed! %dx%d -> %dx%d \n", mpi->width,mpi->height,w2,h);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
226 if(mpi->flags&MP_IMGFLAG_ALLOCATED){
8631
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
227 if(mpi->width<w2 || mpi->height<h){
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
228 // need to re-allocate buffer memory:
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
229 free(mpi->planes[0]);
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
230 mpi->flags&=~MP_IMGFLAG_ALLOCATED;
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
231 printf("vf.c: have to REALLOCATE buffer memory :(\n");
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
232 }
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
233 } else {
9532
0b4c387ddd4f hmm found this in my local tree ;)
michael
parents: 9531
diff changeset
234 mpi->width=w2; mpi->chroma_width=(w2 + (1<<mpi->chroma_x_shift) - 1)>>mpi->chroma_x_shift;
0b4c387ddd4f hmm found this in my local tree ;)
michael
parents: 9531
diff changeset
235 mpi->height=h; mpi->chroma_height=(h + (1<<mpi->chroma_y_shift) - 1)>>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
236 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
237 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
238 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
239 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
240
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
241 // check libvo first!
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
242 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
243
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
244 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
245 // non-direct and not yet allocated image. allocate it!
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
246
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
247 // check if codec prefer aligned stride:
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
248 if(mp_imgflag&MP_IMGFLAG_PREFER_ALIGNED_STRIDE){
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
249 int align=(mpi->flags&MP_IMGFLAG_PLANAR &&
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
250 mpi->flags&MP_IMGFLAG_YUV) ?
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
251 (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
252 w2=((w+align)&(~align));
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
253 if(mpi->width!=w2){
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
254 // 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
255 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
256 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
257 // 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
258 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
259 mpi->width=w2;
9532
0b4c387ddd4f hmm found this in my local tree ;)
michael
parents: 9531
diff changeset
260 mpi->chroma_width=(w2 + (1<<mpi->chroma_x_shift) - 1)>>mpi->chroma_x_shift;
7697
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
261 }
a3c57c0c4ae2 don't honor stride hints if the next filter(chain) doesn't support stride
arpi
parents: 7517
diff changeset
262 }
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
263 }
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6859
diff changeset
264
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
265 // 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
266 if (mpi->imgfmt == IMGFMT_IF09)
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
267 {
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
268 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
269 mpi->chroma_width*mpi->chroma_height);
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
270 /* delta table, just for fun ;) */
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
271 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
272 }
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
273 else
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
274 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
275 if(mpi->flags&MP_IMGFLAG_PLANAR){
6524
05cd2cf758e4 if09 support
alex
parents: 6523
diff changeset
276 // 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
277 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
278 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
279 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
280 // 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
281 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
282 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
283 } else {
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
284 // 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
285 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
286 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
287 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
288 } else {
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
289 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
290 }
8631
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
291 // printf("clearing img!\n");
5663
arpi
parents: 5661
diff changeset
292 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
293 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
294 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
295 }
9490
48ac3ce565ab start_slice() added - similar to get_image(), but is called when using slices
arpi
parents: 9468
diff changeset
296 if(mpi->flags&MP_IMGFLAG_DRAW_CALLBACK)
48ac3ce565ab start_slice() added - similar to get_image(), but is called when using slices
arpi
parents: 9468
diff changeset
297 if(vf->start_slice) vf->start_slice(vf,mpi);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
298 if(!(mpi->flags&MP_IMGFLAG_TYPE_DISPLAYED)){
9490
48ac3ce565ab start_slice() added - similar to get_image(), but is called when using slices
arpi
parents: 9468
diff changeset
299 mp_msg(MSGT_DECVIDEO,MSGL_V,"*** [%s] %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
300 vf->info->name,
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
301 (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
302 ((mpi->flags&MP_IMGFLAG_DIRECT)?"Direct Rendering":"Allocating"),
9490
48ac3ce565ab start_slice() added - similar to get_image(), but is called when using slices
arpi
parents: 9468
diff changeset
303 (mpi->flags&MP_IMGFLAG_DRAW_CALLBACK)?" (slices)":"",
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
304 mpi->width,mpi->height,mpi->bpp,
6708
8058078f1248 support for external pp by divx4. some fixes/cosmetics?
alex
parents: 6539
diff changeset
305 (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
306 (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
307 mpi->bpp*mpi->width*mpi->height/8);
6539
79b536a37e40 better planar support, chroma subsampling support and Y8/Y800 support
alex
parents: 6524
diff changeset
308 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
309 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
310 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
311 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
312 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
313 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
314
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
315 }
8631
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
316 // printf("\rVF_MPI: %p %p %p %d %d %d \n",
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
317 // mpi->planes[0],mpi->planes[1],mpi->planes[2],
3edba4a36c81 (temporary?) fix for redundant buffer re-allocation
arpi
parents: 8367
diff changeset
318 // mpi->stride[0],mpi->stride[1],mpi->stride[2]);
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
319 return mpi;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
320 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
321
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
322 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
323
7979
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
324 // By default vf doesn't accept MPEGPES
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
325 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
326 if(fmt == IMGFMT_MPEGPES) return 0;
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
327 return vf_next_query_format(vf,fmt);
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
328 }
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
329
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
330 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
331 vf_instance_t* vf;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
332 int i;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
333 for(i=0;;i++){
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
334 if(!filter_list[i]){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
335 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
336 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
337 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
338 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
339 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
340 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
341 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
342 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
343 vf->next=next;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
344 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
345 vf->control=vf_next_control;
7979
64f468cbedcd The default query_format shouldn't accept IMGFMT_MPEGPES
albeu
parents: 7966
diff changeset
346 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
347 vf->put_image=vf_next_put_image;
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
348 vf->default_caps=VFCAP_ACCEPT_STRIDE;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
349 vf->default_reqs=0;
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
350 if(vf->info->opts) { // vf_vo get some special argument
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
351 m_struct_t* st = vf->info->opts;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
352 void* vf_priv = m_struct_alloc(st);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
353 int n;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
354 for(n = 0 ; args && args[2*n] ; n++)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
355 m_struct_set(st,vf_priv,args[2*n],args[2*n+1]);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
356 vf->priv = vf_priv;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
357 args = NULL;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
358 } else // Otherwise we should have the '_oldargs_'
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
359 if(args && !strcmp(args[0],"_oldargs_"))
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
360 args = (char**)args[1];
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
361 else
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
362 args = NULL;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
363 if(vf->info->open(vf,(char*)args)>0) return vf; // Success!
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
364 free(vf);
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
365 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
366 return NULL;
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
367 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
368
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
369 vf_instance_t* vf_open_filter(vf_instance_t* next, char *name, char **args){
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
370 if(args && strcmp(args[0],"_oldargs_")) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
371 int i,l = 0;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
372 for(i = 0 ; args && args[2*i] ; i++)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
373 l += 1 + strlen(args[2*i]) + 1 + strlen(args[2*i+1]);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
374 l += strlen(name);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
375 {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
376 char str[l+1];
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
377 char* p = str;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
378 p += sprintf(str,"%s",name);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
379 for(i = 0 ; args && args[2*i] ; i++)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
380 p += sprintf(p," %s=%s",args[2*i],args[2*i+1]);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
381 mp_msg(MSGT_VFILTER,MSGL_INFO,MSGTR_OpeningVideoFilter "[%s]\n",str);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
382 }
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
383 } else if(strcmp(name,"vo")) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
384 if(args && strcmp(args[0],"_oldargs_") == 0)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
385 mp_msg(MSGT_VFILTER,MSGL_INFO,MSGTR_OpeningVideoFilter
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
386 "[%s=%s]\n", name,args[1]);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
387 else
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
388 mp_msg(MSGT_VFILTER,MSGL_INFO,MSGTR_OpeningVideoFilter
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
389 "[%s]\n", name);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
390 }
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
391 return vf_open_plugin(filter_list,next,name,args);
5550
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
392 }
7d1dfb59c6c0 encoders
arpi
parents: 5539
diff changeset
393
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
394 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
395
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
396 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
397 vf_instance_t* vf=*vfp;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
398 unsigned int* p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
399 unsigned int best=0;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
400 int ret;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
401 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
402 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
403 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
404 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
405 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
406 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
407 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
408 if(best) return best; // bingo, they have common csp!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
409 // ok, then try with scale:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
410 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
411 vf=vf_open_filter(vf,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
412 if(!vf) return 0; // failed to init "scale"
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
413 // try the preferred csp first:
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
414 if(preferred && vf->query_format(vf,preferred)) best=preferred; else
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
415 // try the list again, now with "scaler" :
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
416 if((p=list)) while(*p){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
417 ret=vf->query_format(vf,*p);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
418 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
419 if(ret&2){ best=*p; break;} // no conversion -> bingo!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
420 if(ret&1 && !best) best=*p; // best with conversion
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
421 ++p;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
422 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
423 if(best) *vfp=vf; // else uninit vf !FIXME!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
424 return best;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
425 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
426
9934
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
427 void vf_clone_mpi_attributes(mp_image_t* dst, mp_image_t* src){
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
428 dst->pict_type= src->pict_type;
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
429 dst->qscale_type= src->qscale_type;
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
430 if(dst->width == src->width && dst->height == src->height){
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
431 dst->qstride= src->qstride;
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
432 dst->qscale= src->qscale;
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
433 }
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
434 }
89da8ec89558 vf_clone_mpi_attributes()
michael
parents: 9933
diff changeset
435
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
436 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
437 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
438 unsigned int voflags, unsigned int outfmt){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
439 int miss;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
440 int flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
441 if(!flags){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
442 // hmm. colorspace mismatch!!!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
443 // 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
444 vf_instance_t* vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
445 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
446 vf2=vf_open_filter(vf->next,"scale",NULL);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
447 if(!vf2) return 0; // shouldn't happen!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
448 vf->next=vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
449 flags=vf->next->query_format(vf->next,outfmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
450 if(!flags){
6993
c167153136b8 messages moved from vf.c and vd.c
jaf
parents: 6875
diff changeset
451 mp_msg(MSGT_VFILTER,MSGL_ERR,MSGTR_CannotFindColorspace);
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
452 return 0; // FAIL
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
453 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
454 }
6138
523014df7d32 big cosmetics patch, cleanup of messages printed by mplayer and libs.
arpi
parents: 6081
diff changeset
455 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
456 miss=vf->default_reqs - (flags&vf->default_reqs);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
457 if(miss&VFCAP_ACCEPT_STRIDE){
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
458 // 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
459 // 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
460 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
461 if(!vf2) return 0; // shouldn't happen!
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
462 vf->next=vf2;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
463 }
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
464 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
465 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
466
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
467 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
468 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
469 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
470
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
471 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
472 int flags=vf->next->query_format(vf->next,fmt);
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
473 if(flags) flags|=vf->default_caps;
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5557
diff changeset
474 return flags;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
475 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
476
7368
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 7155
diff changeset
477 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
478 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
479 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
480
8367
14af7d96df34 Fix draw_slice() in passthrough mode.
arpi
parents: 8112
diff changeset
481 void vf_next_draw_slice(struct vf_instance_s* vf,unsigned char** src, int * stride,int w, int h, int x, int y){
14af7d96df34 Fix draw_slice() in passthrough mode.
arpi
parents: 8112
diff changeset
482 vf->next->draw_slice(vf->next,src,stride,w,h,x,y);
14af7d96df34 Fix draw_slice() in passthrough mode.
arpi
parents: 8112
diff changeset
483 }
14af7d96df34 Fix draw_slice() in passthrough mode.
arpi
parents: 8112
diff changeset
484
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
485 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
486
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
487 vf_instance_t* append_filters(vf_instance_t* last){
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
488 vf_instance_t* vf;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
489 int i;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
490
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
491 // -vf take precedence over -vop
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
492 if(vf_settings) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
493 // We want to add them in the 'right order'
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
494 for(i = 0 ; vf_settings[i].name ; i++)
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
495 /* NOP */;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
496 for(i-- ; i >= 0 ; i--) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
497 //printf("Open filter %s\n",vf_settings[i].name);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
498 vf = vf_open_filter(last,vf_settings[i].name,vf_settings[i].attribs);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
499 if(vf) last=vf;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
500 }
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
501 } else if(vo_plugin_args) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
502 for(i = 0 ; vo_plugin_args[i].name ; i++) {
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
503 vf = vf_open_filter(last,vo_plugin_args[i].name,
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
504 vo_plugin_args[i].attribs);
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
505 if(vf) last=vf;
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
506 }
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
507 }
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9532
diff changeset
508 return last;
5507
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
509 }
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
510
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
511 //============================================================================
d0d029fda134 video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
diff changeset
512
5737
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
513 void vf_uninit_filter(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
514 if(vf->uninit) vf->uninit(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
515 free_mp_image(vf->imgctx.static_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
516 free_mp_image(vf->imgctx.static_images[1]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
517 free_mp_image(vf->imgctx.temp_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
518 free_mp_image(vf->imgctx.export_images[0]);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
519 free(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
520 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
521
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
522 void vf_uninit_filter_chain(vf_instance_t* vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
523 while(vf){
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
524 vf_instance_t* next=vf->next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
525 vf_uninit_filter(vf);
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
526 vf=next;
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
527 }
de47aebf654c filters uninit
arpi
parents: 5696
diff changeset
528 }
6081
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
529
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
530 void vf_list_plugins(){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
531 int i=0;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
532 while(filter_list[i]){
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
533 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
534 i++;
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
535 }
47d6a4b0f971 -vop help, patch by Julian J. M. <bandit@telecable.es>
arpi
parents: 6061
diff changeset
536 }