Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
09250e34
Commit
09250e34
authored
Apr 25, 2013
by
Paul B Mahol
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
lavfi/curves: add support for more rgb formats
Signed-off-by:
Paul B Mahol
<
onemda@gmail.com
>
parent
1a530f9e
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
53 additions
and
19 deletions
+53
-19
vf_curves.c
libavfilter/vf_curves.c
+53
-19
No files found.
libavfilter/vf_curves.c
View file @
09250e34
...
@@ -24,11 +24,18 @@
...
@@ -24,11 +24,18 @@
#include "libavutil/file.h"
#include "libavutil/file.h"
#include "libavutil/intreadwrite.h"
#include "libavutil/intreadwrite.h"
#include "libavutil/avassert.h"
#include "libavutil/avassert.h"
#include "libavutil/pixdesc.h"
#include "avfilter.h"
#include "avfilter.h"
#include "drawutils.h"
#include "formats.h"
#include "formats.h"
#include "internal.h"
#include "internal.h"
#include "video.h"
#include "video.h"
#define R 0
#define G 1
#define B 2
#define A 3
struct
keypoint
{
struct
keypoint
{
double
x
,
y
;
double
x
,
y
;
struct
keypoint
*
next
;
struct
keypoint
*
next
;
...
@@ -58,6 +65,8 @@ typedef struct {
...
@@ -58,6 +65,8 @@ typedef struct {
char
*
comp_points_str_all
;
char
*
comp_points_str_all
;
uint8_t
graph
[
NB_COMP
+
1
][
256
];
uint8_t
graph
[
NB_COMP
+
1
][
256
];
char
*
psfile
;
char
*
psfile
;
uint8_t
rgba_map
[
4
];
int
step
;
}
CurvesContext
;
}
CurvesContext
;
#define OFFSET(x) offsetof(CurvesContext, x)
#define OFFSET(x) offsetof(CurvesContext, x)
...
@@ -242,27 +251,27 @@ static int interpolate(AVFilterContext *ctx, uint8_t *y, const struct keypoint *
...
@@ -242,27 +251,27 @@ static int interpolate(AVFilterContext *ctx, uint8_t *y, const struct keypoint *
point
=
point
->
next
;
point
=
point
->
next
;
}
}
#define B 0
/* sub diagonal (below main) */
#define B
D
0
/* sub diagonal (below main) */
#define M 1
/* main diagonal (center) */
#define M
D
1
/* main diagonal (center) */
#define A 2
/* sup diagonal (above main) */
#define A
D
2
/* sup diagonal (above main) */
/* left side of the polynomials into a tridiagonal matrix. */
/* left side of the polynomials into a tridiagonal matrix. */
matrix
[
0
][
M
]
=
matrix
[
n
-
1
][
M
]
=
1
;
matrix
[
0
][
M
D
]
=
matrix
[
n
-
1
][
MD
]
=
1
;
for
(
i
=
1
;
i
<
n
-
1
;
i
++
)
{
for
(
i
=
1
;
i
<
n
-
1
;
i
++
)
{
matrix
[
i
][
B
]
=
h
[
i
-
1
];
matrix
[
i
][
B
D
]
=
h
[
i
-
1
];
matrix
[
i
][
M
]
=
2
*
(
h
[
i
-
1
]
+
h
[
i
]);
matrix
[
i
][
M
D
]
=
2
*
(
h
[
i
-
1
]
+
h
[
i
]);
matrix
[
i
][
A
]
=
h
[
i
];
matrix
[
i
][
A
D
]
=
h
[
i
];
}
}
/* tridiagonal solving of the linear system */
/* tridiagonal solving of the linear system */
for
(
i
=
1
;
i
<
n
;
i
++
)
{
for
(
i
=
1
;
i
<
n
;
i
++
)
{
double
den
=
matrix
[
i
][
M
]
-
matrix
[
i
][
B
]
*
matrix
[
i
-
1
][
A
];
double
den
=
matrix
[
i
][
M
D
]
-
matrix
[
i
][
BD
]
*
matrix
[
i
-
1
][
AD
];
double
k
=
den
?
1
.
/
den
:
1
.;
double
k
=
den
?
1
.
/
den
:
1
.;
matrix
[
i
][
A
]
*=
k
;
matrix
[
i
][
A
D
]
*=
k
;
r
[
i
]
=
(
r
[
i
]
-
matrix
[
i
][
B
]
*
r
[
i
-
1
])
*
k
;
r
[
i
]
=
(
r
[
i
]
-
matrix
[
i
][
B
D
]
*
r
[
i
-
1
])
*
k
;
}
}
for
(
i
=
n
-
2
;
i
>=
0
;
i
--
)
for
(
i
=
n
-
2
;
i
>=
0
;
i
--
)
r
[
i
]
=
r
[
i
]
-
matrix
[
i
][
A
]
*
r
[
i
+
1
];
r
[
i
]
=
r
[
i
]
-
matrix
[
i
][
A
D
]
*
r
[
i
+
1
];
/* compute the graph with x=[0..255] */
/* compute the graph with x=[0..255] */
i
=
0
;
i
=
0
;
...
@@ -441,20 +450,43 @@ static av_cold int init(AVFilterContext *ctx)
...
@@ -441,20 +450,43 @@ static av_cold int init(AVFilterContext *ctx)
static
int
query_formats
(
AVFilterContext
*
ctx
)
static
int
query_formats
(
AVFilterContext
*
ctx
)
{
{
static
const
enum
AVPixelFormat
pix_fmts
[]
=
{
AV_PIX_FMT_RGB24
,
AV_PIX_FMT_NONE
};
static
const
enum
AVPixelFormat
pix_fmts
[]
=
{
AV_PIX_FMT_RGB24
,
AV_PIX_FMT_BGR24
,
AV_PIX_FMT_RGBA
,
AV_PIX_FMT_BGRA
,
AV_PIX_FMT_ARGB
,
AV_PIX_FMT_ABGR
,
AV_PIX_FMT_0RGB
,
AV_PIX_FMT_0BGR
,
AV_PIX_FMT_RGB0
,
AV_PIX_FMT_BGR0
,
AV_PIX_FMT_NONE
};
ff_set_common_formats
(
ctx
,
ff_make_format_list
(
pix_fmts
));
ff_set_common_formats
(
ctx
,
ff_make_format_list
(
pix_fmts
));
return
0
;
return
0
;
}
}
static
int
config_input
(
AVFilterLink
*
inlink
)
{
CurvesContext
*
curves
=
inlink
->
dst
->
priv
;
const
AVPixFmtDescriptor
*
desc
=
av_pix_fmt_desc_get
(
inlink
->
format
);
ff_fill_rgba_map
(
curves
->
rgba_map
,
inlink
->
format
);
curves
->
step
=
av_get_padded_bits_per_pixel
(
desc
)
>>
3
;
return
0
;
}
static
int
filter_frame
(
AVFilterLink
*
inlink
,
AVFrame
*
in
)
static
int
filter_frame
(
AVFilterLink
*
inlink
,
AVFrame
*
in
)
{
{
int
x
,
y
,
i
,
direct
=
0
;
int
x
,
y
,
direct
=
0
;
AVFilterContext
*
ctx
=
inlink
->
dst
;
AVFilterContext
*
ctx
=
inlink
->
dst
;
CurvesContext
*
curves
=
ctx
->
priv
;
CurvesContext
*
curves
=
ctx
->
priv
;
AVFilterLink
*
outlink
=
inlink
->
dst
->
outputs
[
0
];
AVFilterLink
*
outlink
=
inlink
->
dst
->
outputs
[
0
];
AVFrame
*
out
;
AVFrame
*
out
;
uint8_t
*
dst
;
uint8_t
*
dst
;
const
uint8_t
*
src
;
const
uint8_t
*
src
;
const
int
step
=
curves
->
step
;
const
uint8_t
r
=
curves
->
rgba_map
[
R
];
const
uint8_t
g
=
curves
->
rgba_map
[
G
];
const
uint8_t
b
=
curves
->
rgba_map
[
B
];
const
uint8_t
a
=
curves
->
rgba_map
[
A
];
if
(
av_frame_is_writable
(
in
))
{
if
(
av_frame_is_writable
(
in
))
{
direct
=
1
;
direct
=
1
;
...
@@ -472,12 +504,13 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
...
@@ -472,12 +504,13 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
src
=
in
->
data
[
0
];
src
=
in
->
data
[
0
];
for
(
y
=
0
;
y
<
inlink
->
h
;
y
++
)
{
for
(
y
=
0
;
y
<
inlink
->
h
;
y
++
)
{
uint8_t
*
dstp
=
dst
;
for
(
x
=
0
;
x
<
inlink
->
w
*
step
;
x
+=
step
)
{
const
uint8_t
*
srcp
=
src
;
dst
[
x
+
r
]
=
curves
->
graph
[
R
][
src
[
x
+
r
]];
dst
[
x
+
g
]
=
curves
->
graph
[
G
][
src
[
x
+
g
]];
for
(
x
=
0
;
x
<
inlink
->
w
;
x
++
)
dst
[
x
+
b
]
=
curves
->
graph
[
B
][
src
[
x
+
b
]];
for
(
i
=
0
;
i
<
NB_COMP
;
i
++
,
dstp
++
,
srcp
++
)
if
(
!
direct
&&
step
==
4
)
*
dstp
=
curves
->
graph
[
i
][
*
srcp
];
dst
[
x
+
a
]
=
src
[
x
+
a
];
}
dst
+=
out
->
linesize
[
0
];
dst
+=
out
->
linesize
[
0
];
src
+=
in
->
linesize
[
0
];
src
+=
in
->
linesize
[
0
];
}
}
...
@@ -493,6 +526,7 @@ static const AVFilterPad curves_inputs[] = {
...
@@ -493,6 +526,7 @@ static const AVFilterPad curves_inputs[] = {
.
name
=
"default"
,
.
name
=
"default"
,
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
filter_frame
=
filter_frame
,
.
filter_frame
=
filter_frame
,
.
config_props
=
config_input
,
},
},
{
NULL
}
{
NULL
}
};
};
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment