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
c82a288f
Commit
c82a288f
authored
Aug 23, 2014
by
Muhammad Faiz
Committed by
Clément Bœsch
Aug 23, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avfilter/showcqt: add fontcolor option
parent
1fa35e43
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
98 additions
and
32 deletions
+98
-32
filters.texi
doc/filters.texi
+26
-0
avf_showcqt.c
libavfilter/avf_showcqt.c
+71
-31
version.h
libavfilter/version.h
+1
-1
No files found.
doc/filters.texi
View file @
c82a288f
...
@@ -10660,6 +10660,26 @@ Default value is @code{3.0}.
...
@@ -10660,6 +10660,26 @@ Default value is @code{3.0}.
@item fontfile
@item fontfile
Specify font file for use with freetype. If not specified, use embedded font.
Specify font file for use with freetype. If not specified, use embedded font.
@item fontcolor
Specify font color expression. This is arithmetic expression that should return
integer value 0xRRGGBB. The expression can contain variables:
@table @option
@item frequency, freq, f
the frequency where transform is evaluated
@item timeclamp, tc
value of timeclamp option
@end table
and functions:
@table @option
@item midi(f)
midi number of frequency f, some midi numbers: E0(16), C1(24), C2(36), A4(69)
@item r(x), g(x), b(x)
red, green, and blue value of intensity x
@end table
Default value is @code{st(0, (midi(f)-59.5)/12);
st(1, if(between(ld(0),0,1), 0.5-0.5*cos(2*PI*ld(0)), 0));
r(1-ld(1)) + b(ld(1))}
@item fullhd
@item fullhd
If set to 1 (the default), the video size is 1920x1080 (full HD),
If set to 1 (the default), the video size is 1920x1080 (full HD),
if set to 0, the video size is 960x540. Use this option to make CPU usage lower.
if set to 0, the video size is 960x540. Use this option to make CPU usage lower.
...
@@ -10721,6 +10741,12 @@ Lower Q factor
...
@@ -10721,6 +10741,12 @@ Lower Q factor
tlength=100/f*tc/(100/f+tc)
tlength=100/f*tc/(100/f+tc)
@end example
@end example
@item
Custom fontcolor, C-note is colored green, others are colored blue
@example
fontcolor='if(mod(floor(midi(f)+0.5),12), 0x0000FF, g(1))'
@end example
@end itemize
@end itemize
@section showspectrum
@section showspectrum
...
...
libavfilter/avf_showcqt.c
View file @
c82a288f
...
@@ -54,6 +54,9 @@
...
@@ -54,6 +54,9 @@
#define TLENGTH_DEFAULT "384/f*tc/(384/f+tc)"
#define TLENGTH_DEFAULT "384/f*tc/(384/f+tc)"
#define VOLUME_MIN 1e-10
#define VOLUME_MIN 1e-10
#define VOLUME_MAX 100.0
#define VOLUME_MAX 100.0
#define FONTCOLOR_DEFAULT "st(0, (midi(f)-59.5)/12);" \
"st(1, if(between(ld(0),0,1), 0.5-0.5*cos(2*PI*ld(0)), 0));" \
"r(1-ld(1)) + b(ld(1))"
typedef
struct
{
typedef
struct
{
FFTSample
value
;
FFTSample
value
;
...
@@ -73,7 +76,7 @@ typedef struct {
...
@@ -73,7 +76,7 @@ typedef struct {
uint8_t
*
font_alpha
;
uint8_t
*
font_alpha
;
char
*
fontfile
;
/* using freetype */
char
*
fontfile
;
/* using freetype */
int
coeffs_len
[
VIDEO_WIDTH
];
int
coeffs_len
[
VIDEO_WIDTH
];
uint8_t
font
_color
[
VIDEO_WIDTH
];
uint8_t
font
color_value
[
VIDEO_WIDTH
*
3
];
/* result of fontcolor option */
int64_t
frame_count
;
int64_t
frame_count
;
int
spectogram_count
;
int
spectogram_count
;
int
spectogram_index
;
int
spectogram_index
;
...
@@ -82,6 +85,7 @@ typedef struct {
...
@@ -82,6 +85,7 @@ typedef struct {
int
remaining_fill
;
int
remaining_fill
;
char
*
tlength
;
char
*
tlength
;
char
*
volume
;
char
*
volume
;
char
*
fontcolor
;
double
timeclamp
;
/* lower timeclamp, time-accurate, higher timeclamp, freq-accurate (at low freq)*/
double
timeclamp
;
/* lower timeclamp, time-accurate, higher timeclamp, freq-accurate (at low freq)*/
float
coeffclamp
;
/* lower coeffclamp, more precise, higher coeffclamp, faster */
float
coeffclamp
;
/* lower coeffclamp, more precise, higher coeffclamp, faster */
int
fullhd
;
/* if true, output video is at full HD resolution, otherwise it will be halved */
int
fullhd
;
/* if true, output video is at full HD resolution, otherwise it will be halved */
...
@@ -103,6 +107,7 @@ static const AVOption showcqt_options[] = {
...
@@ -103,6 +107,7 @@ static const AVOption showcqt_options[] = {
{
"fps"
,
"set video fps"
,
OFFSET
(
fps
),
AV_OPT_TYPE_INT
,
{
.
i64
=
25
},
10
,
100
,
FLAGS
},
{
"fps"
,
"set video fps"
,
OFFSET
(
fps
),
AV_OPT_TYPE_INT
,
{
.
i64
=
25
},
10
,
100
,
FLAGS
},
{
"count"
,
"set number of transform per frame"
,
OFFSET
(
count
),
AV_OPT_TYPE_INT
,
{
.
i64
=
6
},
1
,
30
,
FLAGS
},
{
"count"
,
"set number of transform per frame"
,
OFFSET
(
count
),
AV_OPT_TYPE_INT
,
{
.
i64
=
6
},
1
,
30
,
FLAGS
},
{
"fontfile"
,
"set font file"
,
OFFSET
(
fontfile
),
AV_OPT_TYPE_STRING
,
{
.
str
=
NULL
},
CHAR_MIN
,
CHAR_MAX
,
FLAGS
},
{
"fontfile"
,
"set font file"
,
OFFSET
(
fontfile
),
AV_OPT_TYPE_STRING
,
{
.
str
=
NULL
},
CHAR_MIN
,
CHAR_MAX
,
FLAGS
},
{
"fontcolor"
,
"set font color"
,
OFFSET
(
fontcolor
),
AV_OPT_TYPE_STRING
,
{
.
str
=
FONTCOLOR_DEFAULT
},
CHAR_MIN
,
CHAR_MAX
,
FLAGS
},
{
NULL
}
{
NULL
}
};
};
...
@@ -275,6 +280,29 @@ static double c_weighting(void *p, double f)
...
@@ -275,6 +280,29 @@ static double c_weighting(void *p, double f)
return
ret
;
return
ret
;
}
}
static
double
midi
(
void
*
p
,
double
f
)
{
return
log2
(
f
/
440
.
0
)
*
12
.
0
+
69
.
0
;
}
static
double
r_func
(
void
*
p
,
double
x
)
{
x
=
av_clipd
(
x
,
0
.
0
,
1
.
0
);
return
(
int
)(
x
*
255
.
0
+
0
.
5
)
<<
16
;
}
static
double
g_func
(
void
*
p
,
double
x
)
{
x
=
av_clipd
(
x
,
0
.
0
,
1
.
0
);
return
(
int
)(
x
*
255
.
0
+
0
.
5
)
<<
8
;
}
static
double
b_func
(
void
*
p
,
double
x
)
{
x
=
av_clipd
(
x
,
0
.
0
,
1
.
0
);
return
(
int
)(
x
*
255
.
0
+
0
.
5
);
}
static
inline
int
qsort_sparsecoeff
(
const
SparseCoeff
*
a
,
const
SparseCoeff
*
b
)
static
inline
int
qsort_sparsecoeff
(
const
SparseCoeff
*
a
,
const
SparseCoeff
*
b
)
{
{
if
(
fabsf
(
a
->
value
)
>=
fabsf
(
b
->
value
))
if
(
fabsf
(
a
->
value
)
>=
fabsf
(
b
->
value
))
...
@@ -288,10 +316,13 @@ static int config_output(AVFilterLink *outlink)
...
@@ -288,10 +316,13 @@ static int config_output(AVFilterLink *outlink)
AVFilterContext
*
ctx
=
outlink
->
src
;
AVFilterContext
*
ctx
=
outlink
->
src
;
AVFilterLink
*
inlink
=
ctx
->
inputs
[
0
];
AVFilterLink
*
inlink
=
ctx
->
inputs
[
0
];
ShowCQTContext
*
s
=
ctx
->
priv
;
ShowCQTContext
*
s
=
ctx
->
priv
;
AVExpr
*
tlength_expr
,
*
volume_expr
;
AVExpr
*
tlength_expr
=
NULL
,
*
volume_expr
=
NULL
,
*
fontcolor_expr
=
NULL
;
uint8_t
*
fontcolor_value
=
s
->
fontcolor_value
;
static
const
char
*
const
expr_vars
[]
=
{
"timeclamp"
,
"tc"
,
"frequency"
,
"freq"
,
"f"
,
NULL
};
static
const
char
*
const
expr_vars
[]
=
{
"timeclamp"
,
"tc"
,
"frequency"
,
"freq"
,
"f"
,
NULL
};
static
const
char
*
const
expr_func_names
[]
=
{
"a_weighting"
,
"b_weighting"
,
"c_weighting"
,
NULL
};
static
const
char
*
const
expr_func_names
[]
=
{
"a_weighting"
,
"b_weighting"
,
"c_weighting"
,
NULL
};
static
const
char
*
const
expr_fontcolor_func_names
[]
=
{
"midi"
,
"r"
,
"g"
,
"b"
,
NULL
};
static
double
(
*
const
expr_funcs
[])(
void
*
,
double
)
=
{
a_weighting
,
b_weighting
,
c_weighting
,
NULL
};
static
double
(
*
const
expr_funcs
[])(
void
*
,
double
)
=
{
a_weighting
,
b_weighting
,
c_weighting
,
NULL
};
static
double
(
*
const
expr_fontcolor_funcs
[])(
void
*
,
double
)
=
{
midi
,
r_func
,
g_func
,
b_func
,
NULL
};
int
fft_len
,
k
,
x
,
y
,
ret
;
int
fft_len
,
k
,
x
,
y
,
ret
;
int
num_coeffs
=
0
;
int
num_coeffs
=
0
;
int
rate
=
inlink
->
sample_rate
;
int
rate
=
inlink
->
sample_rate
;
...
@@ -319,17 +350,6 @@ static int config_output(AVFilterLink *outlink)
...
@@ -319,17 +350,6 @@ static int config_output(AVFilterLink *outlink)
if
(
!
s
->
fft_data
||
!
s
->
coeff_sort
||
!
s
->
fft_result_left
||
!
s
->
fft_result_right
||
!
s
->
fft_context
)
if
(
!
s
->
fft_data
||
!
s
->
coeff_sort
||
!
s
->
fft_result_left
||
!
s
->
fft_result_right
||
!
s
->
fft_context
)
return
AVERROR
(
ENOMEM
);
return
AVERROR
(
ENOMEM
);
/* initializing font */
for
(
x
=
0
;
x
<
video_width
;
x
++
)
{
if
(
x
>=
(
12
*
3
+
8
)
*
8
*
video_scale
&&
x
<
(
12
*
4
+
8
)
*
8
*
video_scale
)
{
float
fx
=
(
x
-
(
12
*
3
+
8
)
*
8
*
video_scale
)
*
(
2
.
0
f
/
(
192
.
0
f
*
video_scale
));
float
sv
=
sinf
(
M_PI
*
fx
);
s
->
font_color
[
x
]
=
sv
*
sv
*
255
.
0
f
+
0
.
5
f
;
}
else
{
s
->
font_color
[
x
]
=
0
;
}
}
#if CONFIG_LIBFREETYPE
#if CONFIG_LIBFREETYPE
load_freetype_font
(
ctx
);
load_freetype_font
(
ctx
);
#else
#else
...
@@ -342,13 +362,18 @@ static int config_output(AVFilterLink *outlink)
...
@@ -342,13 +362,18 @@ static int config_output(AVFilterLink *outlink)
start_time
=
av_gettime_relative
();
start_time
=
av_gettime_relative
();
ret
=
av_expr_parse
(
&
tlength_expr
,
s
->
tlength
,
expr_vars
,
NULL
,
NULL
,
NULL
,
NULL
,
0
,
ctx
);
ret
=
av_expr_parse
(
&
tlength_expr
,
s
->
tlength
,
expr_vars
,
NULL
,
NULL
,
NULL
,
NULL
,
0
,
ctx
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
goto
eval_error
;
ret
=
av_expr_parse
(
&
volume_expr
,
s
->
volume
,
expr_vars
,
expr_func_names
,
ret
=
av_expr_parse
(
&
volume_expr
,
s
->
volume
,
expr_vars
,
expr_func_names
,
expr_funcs
,
NULL
,
NULL
,
0
,
ctx
);
expr_funcs
,
NULL
,
NULL
,
0
,
ctx
);
if
(
ret
<
0
)
{
if
(
ret
<
0
)
av_expr_free
(
tlength_expr
);
goto
eval_error
;
return
ret
;
}
ret
=
av_expr_parse
(
&
fontcolor_expr
,
s
->
fontcolor
,
expr_vars
,
expr_fontcolor_func_names
,
expr_fontcolor_funcs
,
NULL
,
NULL
,
0
,
ctx
);
if
(
ret
<
0
)
goto
eval_error
;
for
(
k
=
0
;
k
<
VIDEO_WIDTH
;
k
++
)
{
for
(
k
=
0
;
k
<
VIDEO_WIDTH
;
k
++
)
{
int
hlen
=
fft_len
>>
1
;
int
hlen
=
fft_len
>>
1
;
float
total
=
0
;
float
total
=
0
;
...
@@ -390,6 +415,14 @@ static int config_output(AVFilterLink *outlink)
...
@@ -390,6 +415,14 @@ static int config_output(AVFilterLink *outlink)
volume
=
VOLUME_MAX
;
volume
=
VOLUME_MAX
;
}
}
if
(
s
->
fullhd
||
!
(
k
&
1
))
{
int
fontcolor
=
av_expr_eval
(
fontcolor_expr
,
expr_vars_val
,
NULL
);
fontcolor_value
[
0
]
=
(
fontcolor
>>
16
)
&
0xFF
;
fontcolor_value
[
1
]
=
(
fontcolor
>>
8
)
&
0xFF
;
fontcolor_value
[
2
]
=
fontcolor
&
0xFF
;
fontcolor_value
+=
3
;
}
tlen
=
tlength
*
rate
;
tlen
=
tlength
*
rate
;
s
->
fft_data
[
0
].
re
=
0
;
s
->
fft_data
[
0
].
re
=
0
;
s
->
fft_data
[
0
].
im
=
0
;
s
->
fft_data
[
0
].
im
=
0
;
...
@@ -445,9 +478,8 @@ static int config_output(AVFilterLink *outlink)
...
@@ -445,9 +478,8 @@ static int config_output(AVFilterLink *outlink)
num_coeffs
+=
s
->
coeffs_len
[
k
];
num_coeffs
+=
s
->
coeffs_len
[
k
];
s
->
coeffs
[
k
]
=
av_malloc_array
(
s
->
coeffs_len
[
k
],
sizeof
(
*
s
->
coeffs
[
k
]));
s
->
coeffs
[
k
]
=
av_malloc_array
(
s
->
coeffs_len
[
k
],
sizeof
(
*
s
->
coeffs
[
k
]));
if
(
!
s
->
coeffs
[
k
])
{
if
(
!
s
->
coeffs
[
k
])
{
av_expr_free
(
volume_expr
);
ret
=
AVERROR
(
ENOMEM
);
av_expr_free
(
tlength_expr
);
goto
eval_error
;
return
AVERROR
(
ENOMEM
);
}
}
for
(
y
=
0
;
y
<
s
->
coeffs_len
[
k
];
y
++
)
for
(
y
=
0
;
y
<
s
->
coeffs_len
[
k
];
y
++
)
s
->
coeffs
[
k
][
y
]
=
s
->
coeff_sort
[
x
+
y
];
s
->
coeffs
[
k
][
y
]
=
s
->
coeff_sort
[
x
+
y
];
...
@@ -455,6 +487,7 @@ static int config_output(AVFilterLink *outlink)
...
@@ -455,6 +487,7 @@ static int config_output(AVFilterLink *outlink)
}
}
}
}
}
}
av_expr_free
(
fontcolor_expr
);
av_expr_free
(
volume_expr
);
av_expr_free
(
volume_expr
);
av_expr_free
(
tlength_expr
);
av_expr_free
(
tlength_expr
);
end_time
=
av_gettime_relative
();
end_time
=
av_gettime_relative
();
...
@@ -482,6 +515,12 @@ static int config_output(AVFilterLink *outlink)
...
@@ -482,6 +515,12 @@ static int config_output(AVFilterLink *outlink)
outlink
->
time_base
=
av_make_q
(
1
,
s
->
fps
);
outlink
->
time_base
=
av_make_q
(
1
,
s
->
fps
);
outlink
->
frame_rate
=
av_make_q
(
s
->
fps
,
1
);
outlink
->
frame_rate
=
av_make_q
(
s
->
fps
,
1
);
return
0
;
return
0
;
eval_error:
av_expr_free
(
fontcolor_expr
);
av_expr_free
(
volume_expr
);
av_expr_free
(
tlength_expr
);
return
ret
;
}
}
static
int
plot_cqt
(
AVFilterLink
*
inlink
)
static
int
plot_cqt
(
AVFilterLink
*
inlink
)
...
@@ -597,12 +636,13 @@ static int plot_cqt(AVFilterLink *inlink)
...
@@ -597,12 +636,13 @@ static int plot_cqt(AVFilterLink *inlink)
for
(
y
=
0
;
y
<
font_height
;
y
++
)
{
for
(
y
=
0
;
y
<
font_height
;
y
++
)
{
uint8_t
*
lineptr
=
data
+
(
spectogram_height
+
y
)
*
linesize
;
uint8_t
*
lineptr
=
data
+
(
spectogram_height
+
y
)
*
linesize
;
uint8_t
*
spectogram_src
=
s
->
spectogram
+
s
->
spectogram_index
*
linesize
;
uint8_t
*
spectogram_src
=
s
->
spectogram
+
s
->
spectogram_index
*
linesize
;
uint8_t
*
fontcolor_value
=
s
->
fontcolor_value
;
for
(
x
=
0
;
x
<
video_width
;
x
++
)
{
for
(
x
=
0
;
x
<
video_width
;
x
++
)
{
uint8_t
alpha
=
s
->
font_alpha
[
y
*
video_width
+
x
];
uint8_t
alpha
=
s
->
font_alpha
[
y
*
video_width
+
x
];
uint8_t
color
=
s
->
font_color
[
x
]
;
lineptr
[
3
*
x
]
=
(
spectogram_src
[
3
*
x
]
*
(
255
-
alpha
)
+
fontcolor_value
[
0
]
*
alpha
+
255
)
>>
8
;
lineptr
[
3
*
x
]
=
(
spectogram_src
[
3
*
x
]
*
(
255
-
alpha
)
+
(
255
-
color
)
*
alpha
+
255
)
>>
8
;
lineptr
[
3
*
x
+
1
]
=
(
spectogram_src
[
3
*
x
+
1
]
*
(
255
-
alpha
)
+
fontcolor_value
[
1
]
*
alpha
+
255
)
>>
8
;
lineptr
[
3
*
x
+
1
]
=
(
spectogram_src
[
3
*
x
+
1
]
*
(
255
-
alpha
)
+
255
)
>>
8
;
lineptr
[
3
*
x
+
2
]
=
(
spectogram_src
[
3
*
x
+
2
]
*
(
255
-
alpha
)
+
fontcolor_value
[
2
]
*
alpha
+
255
)
>>
8
;
lineptr
[
3
*
x
+
2
]
=
(
spectogram_src
[
3
*
x
+
2
]
*
(
255
-
alpha
)
+
color
*
alpha
+
255
)
>>
8
;
fontcolor_value
+=
3
;
}
}
}
}
}
else
{
}
else
{
...
@@ -622,16 +662,16 @@ static int plot_cqt(AVFilterLink *inlink)
...
@@ -622,16 +662,16 @@ static int plot_cqt(AVFilterLink *inlink)
int
mask
;
int
mask
;
for
(
mask
=
0x80
;
mask
;
mask
>>=
1
)
{
for
(
mask
=
0x80
;
mask
;
mask
>>=
1
)
{
if
(
mask
&
avpriv_vga16_font
[
str
[
u
]
*
16
+
v
])
{
if
(
mask
&
avpriv_vga16_font
[
str
[
u
]
*
16
+
v
])
{
p
[
0
]
=
255
-
s
->
font_color
[
ux
];
p
[
0
]
=
s
->
fontcolor_value
[
3
*
ux
];
p
[
1
]
=
0
;
p
[
1
]
=
s
->
fontcolor_value
[
3
*
ux
+
1
]
;
p
[
2
]
=
s
->
font
_color
[
ux
];
p
[
2
]
=
s
->
font
color_value
[
3
*
ux
+
2
];
if
(
video_scale
==
2
)
{
if
(
video_scale
==
2
)
{
p
[
linesize
]
=
p
[
0
];
p
[
linesize
]
=
p
[
0
];
p
[
linesize
+
1
]
=
p
[
1
];
p
[
linesize
+
1
]
=
p
[
1
];
p
[
linesize
+
2
]
=
p
[
2
];
p
[
linesize
+
2
]
=
p
[
2
];
p
[
3
]
=
p
[
linesize
+
3
]
=
255
-
s
->
font_color
[
ux
+
1
];
p
[
3
]
=
p
[
linesize
+
3
]
=
s
->
fontcolor_value
[
3
*
ux
+
3
];
p
[
4
]
=
p
[
linesize
+
4
]
=
0
;
p
[
4
]
=
p
[
linesize
+
4
]
=
s
->
fontcolor_value
[
3
*
ux
+
4
]
;
p
[
5
]
=
p
[
linesize
+
5
]
=
s
->
font
_color
[
ux
+
1
];
p
[
5
]
=
p
[
linesize
+
5
]
=
s
->
font
color_value
[
3
*
ux
+
5
];
}
}
}
}
p
+=
3
*
video_scale
;
p
+=
3
*
video_scale
;
...
...
libavfilter/version.h
View file @
c82a288f
...
@@ -31,7 +31,7 @@
...
@@ -31,7 +31,7 @@
#define LIBAVFILTER_VERSION_MAJOR 5
#define LIBAVFILTER_VERSION_MAJOR 5
#define LIBAVFILTER_VERSION_MINOR 0
#define LIBAVFILTER_VERSION_MINOR 0
#define LIBAVFILTER_VERSION_MICRO 10
2
#define LIBAVFILTER_VERSION_MICRO 10
3
#define LIBAVFILTER_VERSION_INT AV_VERSION_INT(LIBAVFILTER_VERSION_MAJOR, \
#define LIBAVFILTER_VERSION_INT AV_VERSION_INT(LIBAVFILTER_VERSION_MAJOR, \
LIBAVFILTER_VERSION_MINOR, \
LIBAVFILTER_VERSION_MINOR, \
...
...
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