Mercurial > mplayer.hg
annotate libmpcodecs/vd.c @ 36402:2c9356ac0d01
af_volume: optimize for common case where all channels
have same volume.
author | reimar |
---|---|
date | Tue, 29 Oct 2013 19:24:16 +0000 |
parents | 56f576e4a49d |
children | ee46a4670903 |
rev | line source |
---|---|
30421
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
1 /* |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
2 * This file is part of MPlayer. |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
3 * |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
4 * MPlayer is free software; you can redistribute it and/or modify |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
5 * it under the terms of the GNU General Public License as published by |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
6 * the Free Software Foundation; either version 2 of the License, or |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
7 * (at your option) any later version. |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
8 * |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
9 * MPlayer is distributed in the hope that it will be useful, |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
12 * GNU General Public License for more details. |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
13 * |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
14 * You should have received a copy of the GNU General Public License along |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
15 * with MPlayer; if not, write to the Free Software Foundation, Inc., |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
17 */ |
bbb6ebec87a0
Add missing license headers to all files in the libmpcodecs directory.
diego
parents:
30349
diff
changeset
|
18 |
4878 | 19 #include <stdio.h> |
20 #include <stdlib.h> | |
21 #include <string.h> | |
22 | |
23 #include "config.h" | |
24 #include "mp_msg.h" | |
5075 | 25 #include "help_mp.h" |
4878 | 26 |
27 #include "codec-cfg.h" | |
28 | |
5607 | 29 #include "img_format.h" |
4878 | 30 |
22599
4faee1254928
Add explicit location for headers from the stream/ directory.
diego
parents:
21145
diff
changeset
|
31 #include "stream/stream.h" |
22601
ed8f90096c65
Add explicit location for headers from the libmpdemux/ directory.
diego
parents:
22599
diff
changeset
|
32 #include "libmpdemux/demuxer.h" |
ed8f90096c65
Add explicit location for headers from the libmpdemux/ directory.
diego
parents:
22599
diff
changeset
|
33 #include "libmpdemux/stheader.h" |
6057
31e465fda59c
various openbsd and general warning fixes - patch by Bj«Órn Sandell <biorn@dce.chalmers.se>
arpi
parents:
5925
diff
changeset
|
34 #include "dec_video.h" |
4878 | 35 |
36 #include "vd.h" | |
5507
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5483
diff
changeset
|
37 #include "vf.h" |
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5483
diff
changeset
|
38 |
30519 | 39 extern const vd_functions_t mpcodecs_vd_null; |
35155 | 40 extern const vd_functions_t mpcodecs_vd_black; |
30519 | 41 extern const vd_functions_t mpcodecs_vd_ffmpeg; |
42 extern const vd_functions_t mpcodecs_vd_theora; | |
43 extern const vd_functions_t mpcodecs_vd_dshow; | |
44 extern const vd_functions_t mpcodecs_vd_dmo; | |
45 extern const vd_functions_t mpcodecs_vd_vfw; | |
46 extern const vd_functions_t mpcodecs_vd_vfwex; | |
47 extern const vd_functions_t mpcodecs_vd_raw; | |
48 extern const vd_functions_t mpcodecs_vd_hmblck; | |
49 extern const vd_functions_t mpcodecs_vd_xanim; | |
50 extern const vd_functions_t mpcodecs_vd_mpng; | |
51 extern const vd_functions_t mpcodecs_vd_ijpg; | |
52 extern const vd_functions_t mpcodecs_vd_mtga; | |
53 extern const vd_functions_t mpcodecs_vd_sgi; | |
54 extern const vd_functions_t mpcodecs_vd_libmpeg2; | |
55 extern const vd_functions_t mpcodecs_vd_mpegpes; | |
56 extern const vd_functions_t mpcodecs_vd_zrmjpeg; | |
57 extern const vd_functions_t mpcodecs_vd_realvid; | |
58 extern const vd_functions_t mpcodecs_vd_xvid; | |
59 extern const vd_functions_t mpcodecs_vd_libdv; | |
60 extern const vd_functions_t mpcodecs_vd_lzo; | |
61 extern const vd_functions_t mpcodecs_vd_qtvideo; | |
4878 | 62 |
25876
edfe8baed49f
copy note on new demuxers and codecs to the top of the array as well to be
ivo
parents:
25872
diff
changeset
|
63 /* Please do not add any new decoders here. If you want to implement a new |
25880
4df11ac927fc
clarify comments/docs about lav* being the preferred place to implement new
ivo
parents:
25876
diff
changeset
|
64 * decoder, add it to libavcodec, except for wrappers around external |
4df11ac927fc
clarify comments/docs about lav* being the preferred place to implement new
ivo
parents:
25876
diff
changeset
|
65 * libraries and decoders requiring binary support. */ |
25876
edfe8baed49f
copy note on new demuxers and codecs to the top of the array as well to be
ivo
parents:
25872
diff
changeset
|
66 |
28826 | 67 const vd_functions_t * const mpcodecs_vd_drivers[] = { |
31170 | 68 &mpcodecs_vd_null, |
35155 | 69 &mpcodecs_vd_black, |
32142
4614728cab25
build system: Merge all FFmpeg library checks into a single FFmpeg check.
diego
parents:
31198
diff
changeset
|
70 #ifdef CONFIG_FFMPEG |
31170 | 71 &mpcodecs_vd_ffmpeg, |
4951 | 72 #endif |
27363
40057010b1fa
Change a bunch of codec-specific preprocessor directives from a HAVE_
diego
parents:
27341
diff
changeset
|
73 #ifdef CONFIG_OGGTHEORA |
31170 | 74 &mpcodecs_vd_theora, |
10095
51da0282b302
Theora demuxer/codec support, patch by David Kuehling <dvdkhlng@gmx.de>
arpi
parents:
9534
diff
changeset
|
75 #endif |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26206
diff
changeset
|
76 #ifdef CONFIG_WIN32DLL |
31170 | 77 &mpcodecs_vd_dshow, |
78 &mpcodecs_vd_dmo, | |
79 &mpcodecs_vd_vfw, | |
80 &mpcodecs_vd_vfwex, | |
4968 | 81 #endif |
31170 | 82 &mpcodecs_vd_lzo, |
83 &mpcodecs_vd_raw, | |
84 &mpcodecs_vd_hmblck, | |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26206
diff
changeset
|
85 #ifdef CONFIG_XANIM |
31170 | 86 &mpcodecs_vd_xanim, |
4969 | 87 #endif |
27385
2113bd9c6bd9
Rename preprocessor directives related to image libraries.
diego
parents:
27370
diff
changeset
|
88 #ifdef CONFIG_PNG |
31170 | 89 &mpcodecs_vd_mpng, |
4998 | 90 #endif |
27385
2113bd9c6bd9
Rename preprocessor directives related to image libraries.
diego
parents:
27370
diff
changeset
|
91 #ifdef CONFIG_JPEG |
31170 | 92 &mpcodecs_vd_ijpg, |
5029 | 93 #endif |
31170 | 94 &mpcodecs_vd_mtga, |
95 &mpcodecs_vd_sgi, | |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26206
diff
changeset
|
96 #ifdef CONFIG_LIBMPEG2 |
31170 | 97 &mpcodecs_vd_libmpeg2, |
8026
b465ba5897a3
usage of libmpeg2, liba52, mp3lib & svq1 can be disabled
arpi
parents:
7978
diff
changeset
|
98 #endif |
31170 | 99 &mpcodecs_vd_mpegpes, |
27370
14c5017f40d2
Change a bunch of video/audio-output-specific preprocessor directives from
diego
parents:
27363
diff
changeset
|
100 #ifdef CONFIG_ZR |
31170 | 101 &mpcodecs_vd_zrmjpeg, |
11386
229079491864
addition of special image formats for Zoran MJPEG, and vd_zrmjpeg.c
rik
parents:
11261
diff
changeset
|
102 #endif |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26206
diff
changeset
|
103 #ifdef CONFIG_REALCODECS |
31170 | 104 &mpcodecs_vd_realvid, |
6343
d253cf4f43a9
realvideo support by Florian Schneider <flo-mplayer-dev@gmx.net>
arpi
parents:
6234
diff
changeset
|
105 #endif |
27363
40057010b1fa
Change a bunch of codec-specific preprocessor directives from a HAVE_
diego
parents:
27341
diff
changeset
|
106 #ifdef CONFIG_XVID4 |
31170 | 107 &mpcodecs_vd_xvid, |
6701
522713337297
Support for Xvid using their new api. If divx4 compatiblity is disabeled
albeu
parents:
6506
diff
changeset
|
108 #endif |
27363
40057010b1fa
Change a bunch of codec-specific preprocessor directives from a HAVE_
diego
parents:
27341
diff
changeset
|
109 #ifdef CONFIG_LIBDV095 |
31170 | 110 &mpcodecs_vd_libdv, |
6927 | 111 #endif |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26206
diff
changeset
|
112 #ifdef CONFIG_QTX_CODECS |
31170 | 113 &mpcodecs_vd_qtvideo, |
8160 | 114 #endif |
25872
3eeaf9d4c65a
note on new demuxers and codecs, add them to lav* instead of libmp*
ivo
parents:
25597
diff
changeset
|
115 /* Please do not add any new decoders here. If you want to implement a new |
25880
4df11ac927fc
clarify comments/docs about lav* being the preferred place to implement new
ivo
parents:
25876
diff
changeset
|
116 * decoder, add it to libavcodec, except for wrappers around external |
4df11ac927fc
clarify comments/docs about lav* being the preferred place to implement new
ivo
parents:
25876
diff
changeset
|
117 * libraries and decoders requiring binary support. */ |
31170 | 118 NULL |
4878 | 119 }; |
120 | |
4971 | 121 #include "libvo/video_out.h" |
122 | |
5075 | 123 // libvo opts: |
31170 | 124 int fullscreen = 0; |
125 int vidmode = 0; | |
126 int softzoom = 0; | |
127 int flip = -1; | |
128 int opt_screen_size_x = 0; | |
129 int opt_screen_size_y = 0; | |
130 float screen_size_xy = 0; | |
131 float movie_aspect = -1.0; | |
132 int vo_flags = 0; | |
33032
dba2e7218893
Disable the combination of slices and multithreaded decode by default, it
reimar
parents:
32142
diff
changeset
|
133 int vd_use_slices = -1; |
5075 | 134 |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29087
diff
changeset
|
135 /** global variables for gamma, brightness, contrast, saturation and hue |
23077 | 136 modified by mplayer.c and gui/mplayer/gtk/eq.c: |
13341
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
137 ranges -100 - 100 |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
138 1000 if the vo default should be used |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29087
diff
changeset
|
139 */ |
13341
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
140 int vo_gamma_gamma = 1000; |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
141 int vo_gamma_brightness = 1000; |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
142 int vo_gamma_contrast = 1000; |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
143 int vo_gamma_saturation = 1000; |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
144 int vo_gamma_hue = 1000; |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
145 |
31170 | 146 extern const vd_functions_t *mpvdec; // FIXME! |
5180 | 147 |
27751
d120b2951b37
Move SCREEN_SIZE_X/Y definition to libmpcodecs/vd.c where it is used.
diego
parents:
27385
diff
changeset
|
148 #define SCREEN_SIZE_X 1 |
d120b2951b37
Move SCREEN_SIZE_X/Y definition to libmpcodecs/vd.c where it is used.
diego
parents:
27385
diff
changeset
|
149 #define SCREEN_SIZE_Y 1 |
d120b2951b37
Move SCREEN_SIZE_X/Y definition to libmpcodecs/vd.c where it is used.
diego
parents:
27385
diff
changeset
|
150 |
31170 | 151 int mpcodecs_config_vo(sh_video_t *sh, int w, int h, |
152 unsigned int preferred_outfmt) | |
153 { | |
154 int i, j; | |
155 unsigned int out_fmt = 0; | |
156 int screen_size_x = 0; //SCREEN_SIZE_X; | |
157 int screen_size_y = 0; //SCREEN_SIZE_Y; | |
158 vf_instance_t *vf = sh->vfilter, *sc = NULL; | |
159 int palette = 0; | |
160 int vocfg_flags = 0; | |
5075 | 161 |
31170 | 162 if (w) |
163 sh->disp_w = w; | |
164 if (h) | |
165 sh->disp_h = h; | |
8579
8f6e84a2a431
do not config video out system if input dimensions are invalid (triggered a segfault in vop_expand due to missing dimension checks, which bug was reported by gabucino)
alex
parents:
8295
diff
changeset
|
166 |
31170 | 167 if (!sh->disp_w || !sh->disp_h) |
168 return 0; | |
5365
b87743434e1f
Issue a warning in VDec if disp_w and disp_h weren't set by codec and try workaround.
atmos4
parents:
5315
diff
changeset
|
169 |
29700
cd5b4ddc9546
Reduce console output verbosity: Move colorspace information to verbose mode.
diego
parents:
29263
diff
changeset
|
170 mp_msg(MSGT_DECVIDEO, MSGL_V, |
31170 | 171 "VDec: vo config request - %d x %d (preferred colorspace: %s)\n", w, |
172 h, vo_format_name(preferred_outfmt)); | |
5075 | 173 |
5925
3f17793b2cea
setting vf_inited flag, some printf->mp_msg, some MSGL_FATAL->MSGL_WARN
arpi
parents:
5903
diff
changeset
|
174 // if(!vf) return 1; // temp hack |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29087
diff
changeset
|
175 |
31170 | 176 if (get_video_quality_max(sh) <= 0 && divx_quality) { |
177 // user wants postprocess but no pp filter yet: | |
178 sh->vfilter = vf = vf_open_filter(vf, "pp", NULL); | |
5565
0b301fec999a
capabilities support -> automatic insertion of scale, expand, pp
arpi
parents:
5549
diff
changeset
|
179 } |
5131
cff03e88d331
prefer outfmt with no conversion (see vo's query flags)
arpi
parents:
5077
diff
changeset
|
180 // check if libvo and codec has common outfmt (no conversion): |
31170 | 181 csp_again: |
9275
d29f03d5763c
- append the 'palette' filter if the codec supports RGB8/BGR8 and no csp
arpi
parents:
8579
diff
changeset
|
182 |
31170 | 183 if (mp_msg_test(MSGT_DECVIDEO, MSGL_V)) { |
184 vf_instance_t *f = vf; | |
185 mp_msg(MSGT_DECVIDEO, MSGL_V, "Trying filter chain:"); | |
186 for (f = vf; f; f = f->next) | |
187 mp_msg(MSGT_DECVIDEO, MSGL_V, " %s", f->info->name); | |
188 mp_msg(MSGT_DECVIDEO, MSGL_V, "\n"); | |
9275
d29f03d5763c
- append the 'palette' filter if the codec supports RGB8/BGR8 and no csp
arpi
parents:
8579
diff
changeset
|
189 } |
d29f03d5763c
- append the 'palette' filter if the codec supports RGB8/BGR8 and no csp
arpi
parents:
8579
diff
changeset
|
190 |
31170 | 191 j = -1; |
192 for (i = 0; i < CODECS_MAX_OUTFMT; i++) { | |
193 int flags; | |
194 out_fmt = sh->codec->outfmt[i]; | |
195 if (out_fmt == (unsigned int) 0xFFFFFFFF) | |
196 continue; | |
197 flags = vf->query_format(vf, out_fmt); | |
198 mp_msg(MSGT_CPLAYER, MSGL_DBG2, | |
199 "vo_debug: query(%s) returned 0x%X (i=%d) \n", | |
200 vo_format_name(out_fmt), flags, i); | |
201 if ((flags & VFCAP_CSP_SUPPORTED_BY_HW) | |
202 || (flags & VFCAP_CSP_SUPPORTED && j < 0)) { | |
203 // check (query) if codec really support this outfmt... | |
204 sh->outfmtidx = j; // pass index to the control() function this way | |
205 if (mpvdec->control(sh, VDCTRL_QUERY_FORMAT, &out_fmt) == | |
206 CONTROL_FALSE) { | |
207 mp_msg(MSGT_CPLAYER, MSGL_DBG2, | |
208 "vo_debug: codec query_format(%s) returned FALSE\n", | |
209 vo_format_name(out_fmt)); | |
210 continue; | |
211 } | |
212 j = i; | |
213 vo_flags = flags; | |
214 if (flags & VFCAP_CSP_SUPPORTED_BY_HW) | |
215 break; | |
216 } else if (!palette | |
217 && !(flags & | |
218 (VFCAP_CSP_SUPPORTED_BY_HW | VFCAP_CSP_SUPPORTED)) | |
219 && (out_fmt == IMGFMT_RGB8 || out_fmt == IMGFMT_BGR8)) { | |
220 sh->outfmtidx = j; // pass index to the control() function this way | |
221 if (mpvdec->control(sh, VDCTRL_QUERY_FORMAT, &out_fmt) != | |
222 CONTROL_FALSE) | |
223 palette = 1; | |
224 } | |
5075 | 225 } |
36074
fbbf13706c50
Do not try with scale filter etc. when the format is a HWACCEL format.
reimar
parents:
35155
diff
changeset
|
226 if (j < 0 && !IMGFMT_IS_HWACCEL(preferred_outfmt)) { |
31170 | 227 // TODO: no match - we should use conversion... |
228 if (strcmp(vf->info->name, "scale") && palette != -1) { | |
229 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_CouldNotFindColorspace); | |
230 sc = vf = vf_open_filter(vf, "scale", NULL); | |
231 goto csp_again; | |
232 } else if (palette == 1) { | |
233 mp_msg(MSGT_DECVIDEO, MSGL_V, "vd: Trying -vf palette...\n"); | |
234 palette = -1; | |
235 vf = vf_open_filter(vf, "palette", NULL); | |
236 goto csp_again; | |
237 } else { // sws failed, if the last filter (vf_vo) support MPEGPES try to append vf_lavc | |
238 vf_instance_t *vo, *vp = NULL, *ve, *vpp = NULL; | |
31198
f9719a497f8e
cosmetics: Remove some commented-out #includes, fix a comment grammar error.
diego
parents:
31170
diff
changeset
|
239 // Remove the scale filter if we added it ourselves |
31170 | 240 if (vf == sc) { |
241 ve = vf; | |
242 vf = vf->next; | |
243 vf_uninit_filter(ve); | |
244 } | |
245 // Find the last filter (vf_vo) | |
246 for (vo = vf; vo->next; vo = vo->next) { | |
247 vpp = vp; | |
248 vp = vo; | |
249 } | |
250 if (vo->query_format(vo, IMGFMT_MPEGPES) | |
251 && (!vp || (vp && strcmp(vp->info->name, "lavc")))) { | |
252 ve = vf_open_filter(vo, "lavc", NULL); | |
253 if (vp) | |
254 vp->next = ve; | |
255 else | |
256 vf = ve; | |
257 goto csp_again; | |
258 } | |
259 if (vp && !strcmp(vp->info->name, "lavc")) { | |
260 if (vpp) | |
261 vpp->next = vo; | |
262 else | |
263 vf = vo; | |
264 vf_uninit_filter(vp); | |
265 } | |
266 } | |
36074
fbbf13706c50
Do not try with scale filter etc. when the format is a HWACCEL format.
reimar
parents:
35155
diff
changeset
|
267 } |
fbbf13706c50
Do not try with scale filter etc. when the format is a HWACCEL format.
reimar
parents:
35155
diff
changeset
|
268 if (j < 0) { |
31170 | 269 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_VOincompCodec); |
270 sh->vf_initialized = -1; | |
271 return 0; // failed | |
5075 | 272 } |
31170 | 273 out_fmt = sh->codec->outfmt[j]; |
29700
cd5b4ddc9546
Reduce console output verbosity: Move colorspace information to verbose mode.
diego
parents:
29263
diff
changeset
|
274 mp_msg(MSGT_CPLAYER, MSGL_V, "VDec: using %s as output csp (no %d)\n", |
cd5b4ddc9546
Reduce console output verbosity: Move colorspace information to verbose mode.
diego
parents:
29263
diff
changeset
|
275 vo_format_name(out_fmt), j); |
31170 | 276 sh->outfmtidx = j; |
277 sh->vfilter = vf; | |
5075 | 278 |
279 // autodetect flipping | |
31170 | 280 if (flip == -1) { |
281 flip = 0; | |
282 if (sh->codec->outflags[j] & CODECS_FLAG_FLIP) | |
283 if (!(sh->codec->outflags[j] & CODECS_FLAG_NOFLIP)) | |
284 flip = 1; | |
5075 | 285 } |
31170 | 286 if (vo_flags & VFCAP_FLIPPED) |
287 flip ^= 1; | |
288 if (flip && !(vo_flags & VFCAP_FLIP)) { | |
289 // we need to flip, but no flipping filter avail. | |
290 vf_add_before_vo(&vf, "flip", NULL); | |
291 sh->vfilter = vf; | |
5565
0b301fec999a
capabilities support -> automatic insertion of scale, expand, pp
arpi
parents:
5549
diff
changeset
|
292 } |
36316
139f2b064ef9
Don't subsequently calculate original_aspect from last movie_aspect.
ib
parents:
36305
diff
changeset
|
293 // time to do aspect ratio corrections... |
36295
0bd0297b073a
Handle special argument -1 to switch_ratio as intended.
ib
parents:
36074
diff
changeset
|
294 |
36316
139f2b064ef9
Don't subsequently calculate original_aspect from last movie_aspect.
ib
parents:
36305
diff
changeset
|
295 if (movie_aspect > -1.0) |
31170 | 296 sh->aspect = movie_aspect; // cmdline overrides autodetect |
297 else if (sh->stream_aspect != 0.0) | |
36316
139f2b064ef9
Don't subsequently calculate original_aspect from last movie_aspect.
ib
parents:
36305
diff
changeset
|
298 sh->aspect = sh->stream_aspect; |
36305
d8a13d907c61
Enable switch_ratio -1 with videos with aspect changes.
ib
parents:
36304
diff
changeset
|
299 else |
36316
139f2b064ef9
Don't subsequently calculate original_aspect from last movie_aspect.
ib
parents:
36305
diff
changeset
|
300 sh->aspect = sh->original_aspect; |
36305
d8a13d907c61
Enable switch_ratio -1 with videos with aspect changes.
ib
parents:
36304
diff
changeset
|
301 |
31170 | 302 if (opt_screen_size_x || opt_screen_size_y) { |
303 screen_size_x = opt_screen_size_x; | |
304 screen_size_y = opt_screen_size_y; | |
305 if (!vidmode) { | |
306 if (!screen_size_x) | |
307 screen_size_x = SCREEN_SIZE_X; | |
308 if (!screen_size_y) | |
309 screen_size_y = SCREEN_SIZE_Y; | |
310 if (screen_size_x <= 8) | |
311 screen_size_x *= sh->disp_w; | |
312 if (screen_size_y <= 8) | |
313 screen_size_y *= sh->disp_h; | |
314 } | |
315 } else { | |
316 // check source format aspect, calculate prescale ::atmos | |
317 screen_size_x = sh->disp_w; | |
318 screen_size_y = sh->disp_h; | |
319 if (screen_size_xy >= 0.001) { | |
320 if (screen_size_xy <= 8) { | |
321 // -xy means x+y scale | |
322 screen_size_x *= screen_size_xy; | |
323 screen_size_y *= screen_size_xy; | |
324 } else { | |
325 // -xy means forced width while keeping correct aspect | |
326 screen_size_x = screen_size_xy; | |
327 screen_size_y = screen_size_xy * sh->disp_h / sh->disp_w; | |
328 } | |
329 } | |
36317
56f576e4a49d
Be more consistent with movie aspect setting and check.
ib
parents:
36316
diff
changeset
|
330 if (sh->aspect >= 0.01) { |
31170 | 331 int w; |
332 mp_msg(MSGT_CPLAYER, MSGL_INFO, MSGTR_MovieAspectIsSet, | |
333 sh->aspect); | |
334 mp_msg(MSGT_IDENTIFY, MSGL_INFO, "ID_VIDEO_ASPECT=%1.4f\n", | |
335 sh->aspect); | |
336 w = (int) ((float) screen_size_y * sh->aspect); | |
337 w += w % 2; // round | |
338 // we don't like horizontal downscale || user forced width: | |
339 if (w < screen_size_x || screen_size_xy > 8) { | |
340 screen_size_y = | |
341 (int) ((float) screen_size_x * (1.0 / sh->aspect)); | |
342 screen_size_y += screen_size_y % 2; // round | |
343 } else | |
344 screen_size_x = w; // keep new width | |
345 } else { | |
346 mp_msg(MSGT_CPLAYER, MSGL_INFO, MSGTR_MovieAspectUndefined); | |
347 } | |
5903 | 348 } |
5075 | 349 |
31170 | 350 vocfg_flags = (fullscreen ? VOFLAG_FULLSCREEN : 0) |
351 | (vidmode ? VOFLAG_MODESWITCHING : 0) | |
352 | (softzoom ? VOFLAG_SWSCALE : 0) | |
353 | (flip ? VOFLAG_FLIPPING : 0); | |
15212
05aa13cdf92f
replace VO and VF numeric flags with #defined identifiers
henry
parents:
14878
diff
changeset
|
354 |
5075 | 355 // Time to config libvo! |
31170 | 356 mp_msg(MSGT_CPLAYER, MSGL_V, |
357 "VO Config (%dx%d->%dx%d,flags=%d,'%s',0x%X)\n", sh->disp_w, | |
358 sh->disp_h, screen_size_x, screen_size_y, vocfg_flags, "MPlayer", | |
359 out_fmt); | |
5075 | 360 |
14073 | 361 vf->w = sh->disp_w; |
362 vf->h = sh->disp_h; | |
31170 | 363 if (vf_config_wrapper |
364 (vf, sh->disp_w, sh->disp_h, screen_size_x, screen_size_y, vocfg_flags, | |
365 out_fmt) == 0) { | |
7124
eca7dbad0166
finally removed query_vaa, bes_da and vo_tune_info - the obsoleted libvo api
alex
parents:
6993
diff
changeset
|
366 // "MPlayer",out_fmt)){ |
31170 | 367 mp_msg(MSGT_CPLAYER, MSGL_WARN, MSGTR_CannotInitVO); |
368 sh->vf_initialized = -1; | |
369 return 0; | |
5075 | 370 } |
371 | |
31170 | 372 sh->vf_initialized = 1; |
13341
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
373 |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
374 if (vo_gamma_gamma != 1000) |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
375 set_video_colors(sh, "gamma", vo_gamma_gamma); |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
376 if (vo_gamma_brightness != 1000) |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
377 set_video_colors(sh, "brightness", vo_gamma_brightness); |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
378 if (vo_gamma_contrast != 1000) |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
379 set_video_colors(sh, "contrast", vo_gamma_contrast); |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
380 if (vo_gamma_saturation != 1000) |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
381 set_video_colors(sh, "saturation", vo_gamma_saturation); |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
382 if (vo_gamma_hue != 1000) |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
383 set_video_colors(sh, "hue", vo_gamma_hue); |
0c41c3728568
fix ineffectual video equalizer command line options, patch by kiriuja <mplayer-bugs at en-directo.net>, closes #37, some more variable docu by me
faust3
parents:
12827
diff
changeset
|
384 |
4878 | 385 return 1; |
386 } | |
387 | |
388 // mp_imgtype: buffering type, see mp_image.h | |
389 // mp_imgflag: buffer requirements (read/write, preserve, stride limits), see mp_image.h | |
390 // returns NULL or allocated mp_image_t* | |
391 // Note: buffer allocation may be moved to mpcodecs_config_vo() later... | |
31170 | 392 mp_image_t *mpcodecs_get_image(sh_video_t *sh, int mp_imgtype, int mp_imgflag, |
393 int w, int h) | |
394 { | |
395 mp_image_t *mpi = | |
396 vf_get_image(sh->vfilter, sh->codec->outfmt[sh->outfmtidx], mp_imgtype, | |
397 mp_imgflag, w, h); | |
398 if (mpi) | |
399 mpi->x = mpi->y = 0; | |
400 return mpi; | |
4878 | 401 } |
402 | |
31170 | 403 void mpcodecs_draw_slice(sh_video_t *sh, unsigned char **src, int *stride, |
404 int w, int h, int x, int y) | |
405 { | |
406 struct vf_instance *vf = sh->vfilter; | |
6709 | 407 |
31170 | 408 if (vf->draw_slice) |
409 vf->draw_slice(vf, src, stride, w, h, x, y); | |
6709 | 410 } |