Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-gpu
Commits
06f934e9
Commit
06f934e9
authored
May 14, 2010
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Used vlc_fourcc_GetChromaDescription in gradfun.
parent
8bfc50dd
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
42 deletions
+12
-42
modules/video_filter/gradfun.c
modules/video_filter/gradfun.c
+12
-42
No files found.
modules/video_filter/gradfun.c
View file @
06f934e9
...
@@ -102,8 +102,7 @@ struct filter_sys_t {
...
@@ -102,8 +102,7 @@ struct filter_sys_t {
vlc_mutex_t
lock
;
vlc_mutex_t
lock
;
float
strength
;
float
strength
;
int
radius
;
int
radius
;
int
h_shift
;
const
vlc_chroma_description_t
*
chroma
;
int
v_shift
;
void
*
base_buf
;
void
*
base_buf
;
struct
vf_priv_s
cfg
;
struct
vf_priv_s
cfg
;
};
};
...
@@ -111,36 +110,11 @@ struct filter_sys_t {
...
@@ -111,36 +110,11 @@ struct filter_sys_t {
static
int
Open
(
vlc_object_t
*
object
)
static
int
Open
(
vlc_object_t
*
object
)
{
{
filter_t
*
filter
=
(
filter_t
*
)
object
;
filter_t
*
filter
=
(
filter_t
*
)
object
;
const
vlc_fourcc_t
fourcc
=
filter
->
fmt_in
.
video
.
i_chroma
;
int
h_shift
;
const
vlc_chroma_description_t
*
chroma
=
vlc_fourcc_GetChromaDescription
(
fourcc
);
int
v_shift
;
if
(
!
chroma
||
chroma
->
plane_count
<
3
)
{
switch
(
filter
->
fmt_in
.
video
.
i_chroma
)
{
msg_Err
(
filter
,
"Unsupported chroma (%4.4s)"
,
(
char
*
)
&
fourcc
);
case
VLC_CODEC_I410
:
case
VLC_CODEC_YV9
:
h_shift
=
2
;
v_shift
=
2
;
break
;
case
VLC_CODEC_I411
:
h_shift
=
2
;
v_shift
=
0
;
break
;
case
VLC_CODEC_I420
:
case
VLC_CODEC_J420
:
case
VLC_CODEC_YV12
:
h_shift
=
1
;
v_shift
=
1
;
break
;
case
VLC_CODEC_I422
:
case
VLC_CODEC_J422
:
h_shift
=
1
;
v_shift
=
0
;
break
;
case
VLC_CODEC_I444
:
case
VLC_CODEC_J444
:
case
VLC_CODEC_YUVA
:
h_shift
=
0
;
v_shift
=
0
;
break
;
case
VLC_CODEC_I440
:
case
VLC_CODEC_J440
:
h_shift
=
0
;
v_shift
=
1
;
break
;
default:
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
...
@@ -149,8 +123,7 @@ static int Open(vlc_object_t *object)
...
@@ -149,8 +123,7 @@ static int Open(vlc_object_t *object)
return
VLC_ENOMEM
;
return
VLC_ENOMEM
;
vlc_mutex_init
(
&
sys
->
lock
);
vlc_mutex_init
(
&
sys
->
lock
);
sys
->
h_shift
=
h_shift
;
sys
->
chroma
=
chroma
;
sys
->
v_shift
=
v_shift
;
sys
->
strength
=
var_CreateGetFloatCommand
(
filter
,
CFG_PREFIX
"strength"
);
sys
->
strength
=
var_CreateGetFloatCommand
(
filter
,
CFG_PREFIX
"strength"
);
sys
->
radius
=
var_CreateGetIntegerCommand
(
filter
,
CFG_PREFIX
"radius"
);
sys
->
radius
=
var_CreateGetIntegerCommand
(
filter
,
CFG_PREFIX
"radius"
);
var_AddCallback
(
filter
,
CFG_PREFIX
"strength"
,
Callback
,
NULL
);
var_AddCallback
(
filter
,
CFG_PREFIX
"strength"
,
Callback
,
NULL
);
...
@@ -221,15 +194,12 @@ static picture_t *Filter(filter_t *filter, picture_t *src)
...
@@ -221,15 +194,12 @@ static picture_t *Filter(filter_t *filter, picture_t *src)
const
plane_t
*
srcp
=
&
src
->
p
[
i
];
const
plane_t
*
srcp
=
&
src
->
p
[
i
];
plane_t
*
dstp
=
&
dst
->
p
[
i
];
plane_t
*
dstp
=
&
dst
->
p
[
i
];
int
w
=
fmt
->
i_width
;
const
vlc_chroma_description_t
*
chroma
=
sys
->
chroma
;
int
h
=
fmt
->
i_height
;
int
w
=
fmt
->
i_width
*
chroma
->
p
[
i
].
w
.
num
/
chroma
->
p
[
i
].
w
.
den
;
int
r
=
cfg
->
radius
;
int
h
=
fmt
->
i_height
*
chroma
->
p
[
i
].
h
.
num
/
chroma
->
p
[
i
].
h
.
den
;
if
(
i
>
0
)
{
int
r
=
(
cfg
->
radius
*
chroma
->
p
[
i
].
w
.
num
/
chroma
->
p
[
i
].
w
.
den
+
w
>>=
sys
->
h_shift
;
cfg
->
radius
*
chroma
->
p
[
i
].
h
.
num
/
chroma
->
p
[
i
].
h
.
den
)
/
2
;
h
>>=
sys
->
v_shift
;
r
=
__MIN
(
__MAX
((
r
+
1
)
&
~
1
,
RADIUS_MIN
),
RADIUS_MAX
);
r
=
((
r
>>
sys
->
h_shift
)
+
(
r
>>
sys
->
v_shift
))
/
2
;
r
=
__MIN
(
__MAX
((
r
+
1
)
&
~
1
,
RADIUS_MIN
),
RADIUS_MAX
);
}
if
(
__MIN
(
w
,
h
)
>
2
*
r
&&
cfg
->
buf
)
{
if
(
__MIN
(
w
,
h
)
>
2
*
r
&&
cfg
->
buf
)
{
filter_plane
(
cfg
,
dstp
->
p_pixels
,
srcp
->
p_pixels
,
filter_plane
(
cfg
,
dstp
->
p_pixels
,
srcp
->
p_pixels
,
w
,
h
,
dstp
->
i_pitch
,
srcp
->
i_pitch
,
r
);
w
,
h
,
dstp
->
i_pitch
,
srcp
->
i_pitch
,
r
);
...
...
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