Mercurial > libpostproc.hg
annotate postprocess.h @ 135:0397ed4317ef libpostproc
Remove explicit filename from Doxygen @file commands.
Passing an explicit filename to this command is only necessary if the
documentation in the @file block refers to a file different from the
one the block resides in.
| author | diego |
|---|---|
| date | Tue, 20 Apr 2010 14:45:34 +0000 |
| parents | 63eddcff3509 |
| children | fe0bf26c4c81 |
| rev | line source |
|---|---|
| 0 | 1 /* |
|
22
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
2 * Copyright (C) 2001-2003 Michael Niedermayer (michaelni@gmx.at) |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
3 * |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
4 * This file is part of FFmpeg. |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
5 * |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
6 * FFmpeg is free software; you can redistribute it and/or modify |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
7 * it under the terms of the GNU General Public License as published by |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
8 * the Free Software Foundation; either version 2 of the License, or |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
9 * (at your option) any later version. |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
10 * |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
11 * FFmpeg is distributed in the hope that it will be useful, |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
14 * GNU General Public License for more details. |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
15 * |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
16 * You should have received a copy of the GNU General Public License |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
17 * along with FFmpeg; if not, write to the Free Software |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
|
da3bfee1fa67
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
0
diff
changeset
|
19 */ |
| 0 | 20 |
|
123
674bd232c0e1
Use directory name as multiple inclusion guard prefix.
diego
parents:
122
diff
changeset
|
21 #ifndef POSTPROC_POSTPROCESS_H |
|
674bd232c0e1
Use directory name as multiple inclusion guard prefix.
diego
parents:
122
diff
changeset
|
22 #define POSTPROC_POSTPROCESS_H |
| 0 | 23 |
| 24 /** | |
|
135
0397ed4317ef
Remove explicit filename from Doxygen @file commands.
diego
parents:
131
diff
changeset
|
25 * @file |
| 0 | 26 * @brief |
| 87 | 27 * external postprocessing API |
| 0 | 28 */ |
| 29 | |
| 81 | 30 #include "libavutil/avutil.h" |
| 80 | 31 |
| 82 | 32 #define LIBPOSTPROC_VERSION_MAJOR 51 |
| 111 | 33 #define LIBPOSTPROC_VERSION_MINOR 2 |
| 82 | 34 #define LIBPOSTPROC_VERSION_MICRO 0 |
| 79 | 35 |
| 82 | 36 #define LIBPOSTPROC_VERSION_INT AV_VERSION_INT(LIBPOSTPROC_VERSION_MAJOR, \ |
| 37 LIBPOSTPROC_VERSION_MINOR, \ | |
| 38 LIBPOSTPROC_VERSION_MICRO) | |
| 39 #define LIBPOSTPROC_VERSION AV_VERSION(LIBPOSTPROC_VERSION_MAJOR, \ | |
| 40 LIBPOSTPROC_VERSION_MINOR, \ | |
| 41 LIBPOSTPROC_VERSION_MICRO) | |
| 0 | 42 #define LIBPOSTPROC_BUILD LIBPOSTPROC_VERSION_INT |
| 43 | |
| 44 #define LIBPOSTPROC_IDENT "postproc" AV_STRINGIFY(LIBPOSTPROC_VERSION) | |
| 45 | |
| 111 | 46 /** |
| 47 * Returns the LIBPOSTPROC_VERSION_INT constant. | |
| 48 */ | |
| 49 unsigned postproc_version(void); | |
| 50 | |
|
130
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
51 /** |
|
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
52 * Returns the libpostproc build-time configuration. |
|
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
53 */ |
|
131
63eddcff3509
Prefer "*FUNC_NAME(" over "* FUNC_NAME(" for XXX_configuration() and
stefano
parents:
130
diff
changeset
|
54 const char *postproc_configuration(void); |
|
130
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
55 |
|
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
56 /** |
|
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
57 * Returns the libpostproc license. |
|
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
58 */ |
|
131
63eddcff3509
Prefer "*FUNC_NAME(" over "* FUNC_NAME(" for XXX_configuration() and
stefano
parents:
130
diff
changeset
|
59 const char *postproc_license(void); |
|
130
885c7548fb5e
Add functions to return library license and library configuration.
diego
parents:
123
diff
changeset
|
60 |
| 0 | 61 #define PP_QUALITY_MAX 6 |
| 62 | |
| 63 #define QP_STORE_T int8_t | |
| 64 | |
| 53 | 65 #include <inttypes.h> |
| 66 | |
| 115 | 67 typedef void pp_context; |
| 68 typedef void pp_mode; | |
| 0 | 69 |
|
70
6539cfc12739
Make pp_help a constant array of characters to move it to .rodata.
benoit
parents:
66
diff
changeset
|
70 #if LIBPOSTPROC_VERSION_INT < (52<<16) |
|
116
a4769eff95f0
Add backwards-compatibility typedef for removed _t names under appropriate
diego
parents:
115
diff
changeset
|
71 typedef pp_context pp_context_t; |
|
a4769eff95f0
Add backwards-compatibility typedef for removed _t names under appropriate
diego
parents:
115
diff
changeset
|
72 typedef pp_mode pp_mode_t; |
|
66
7737e39e74f3
Make pp_help a constant pointer to constant characters, moves it partially
benoit
parents:
65
diff
changeset
|
73 extern const char *const pp_help; ///< a simple help text |
|
70
6539cfc12739
Make pp_help a constant array of characters to move it to .rodata.
benoit
parents:
66
diff
changeset
|
74 #else |
|
6539cfc12739
Make pp_help a constant array of characters to move it to .rodata.
benoit
parents:
66
diff
changeset
|
75 extern const char pp_help[]; ///< a simple help text |
|
6539cfc12739
Make pp_help a constant array of characters to move it to .rodata.
benoit
parents:
66
diff
changeset
|
76 #endif |
| 0 | 77 |
| 78 | 78 void pp_postprocess(const uint8_t * src[3], const int srcStride[3], |
|
95
c24dab9bca80
cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents:
94
diff
changeset
|
79 uint8_t * dst[3], const int dstStride[3], |
|
c24dab9bca80
cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents:
94
diff
changeset
|
80 int horizontalSize, int verticalSize, |
|
c24dab9bca80
cosmetics: Fix indentation to be 4 spaces and consistently place {}.
diego
parents:
94
diff
changeset
|
81 const QP_STORE_T *QP_store, int QP_stride, |
| 115 | 82 pp_mode *mode, pp_context *ppContext, int pict_type); |
| 0 | 83 |
| 84 | |
| 85 /** | |
| 115 | 86 * returns a pp_mode or NULL if an error occurred |
| 0 | 87 * name is the string after "-pp" on the command line |
| 88 * quality is a number from 0 to PP_QUALITY_MAX | |
| 89 */ | |
| 115 | 90 pp_mode *pp_get_mode_by_name_and_quality(const char *name, int quality); |
| 91 void pp_free_mode(pp_mode *mode); | |
| 0 | 92 |
| 115 | 93 pp_context *pp_get_context(int width, int height, int flags); |
| 94 void pp_free_context(pp_context *ppContext); | |
| 0 | 95 |
| 96 #define PP_CPU_CAPS_MMX 0x80000000 | |
| 97 #define PP_CPU_CAPS_MMX2 0x20000000 | |
| 98 #define PP_CPU_CAPS_3DNOW 0x40000000 | |
| 99 #define PP_CPU_CAPS_ALTIVEC 0x10000000 | |
| 100 | |
| 101 #define PP_FORMAT 0x00000008 | |
| 102 #define PP_FORMAT_420 (0x00000011|PP_FORMAT) | |
| 103 #define PP_FORMAT_422 (0x00000001|PP_FORMAT) | |
| 104 #define PP_FORMAT_411 (0x00000002|PP_FORMAT) | |
| 105 #define PP_FORMAT_444 (0x00000000|PP_FORMAT) | |
| 106 | |
| 107 #define PP_PICT_TYPE_QP2 0x00000010 ///< MPEG2 style QScale | |
| 108 | |
|
123
674bd232c0e1
Use directory name as multiple inclusion guard prefix.
diego
parents:
122
diff
changeset
|
109 #endif /* POSTPROC_POSTPROCESS_H */ |
