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
d43c4059
Commit
d43c4059
authored
Nov 28, 2002
by
Simon Latapie
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* a few bugfixes/enhancements/clean up
parent
e1c7565e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
66 additions
and
72 deletions
+66
-72
modules/video_filter/adjust.c
modules/video_filter/adjust.c
+66
-72
No files found.
modules/video_filter/adjust.c
View file @
d43c4059
...
...
@@ -2,7 +2,7 @@
* adjust.c : Contrast/Hue/Saturation/Brightness video plugin for vlc
*****************************************************************************
* Copyright (C) 2000, 2001 VideoLAN
* $Id: adjust.c,v 1.
2 2002/11/28 17:35:00 sam
Exp $
* $Id: adjust.c,v 1.
3 2002/11/28 21:49:04 garf
Exp $
*
* Authors: Simon Latapie <garf@via.ecp.fr>, Samuel Hocevar <sam@zoy.org>
*
...
...
@@ -34,6 +34,9 @@
#include "filter_common.h"
#define eight_times( x ) x x x x x x x x
/*****************************************************************************
* Local prototypes
*****************************************************************************/
...
...
@@ -81,7 +84,9 @@ struct vout_sys_t
vout_thread_t
*
p_vout
;
};
static
int32_t
maxmin
(
int32_t
a
)
static
int
p_lum_func
[
256
];
inline
static
int32_t
maxmin
(
int32_t
a
)
{
if
(
a
>
255
)
return
255
;
...
...
@@ -205,6 +210,7 @@ cleaner :) */
int
i_sat
;
int
i_Sin
;
int
i_Cos
;
int
i
;
/* This is a new frame. Get a structure from the video_output. */
...
...
@@ -245,18 +251,18 @@ cleaner :) */
p_out
=
p_outpic
->
p
[
i_index
].
p_pixels
;
for
(
i
=
0
;
i
<
256
;
i
++
)
{
p_lum_func
[
i
]
=
maxmin
(
((
i
*
cont
)
>>
8
)
+
lum
+
dec
);
}
for
(
;
p_in
<
p_in_end
;
)
{
/* Do 8 pixels at a time */
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
);
p_out
++
;
p_in
++
;
eight_times
(
*
p_out
=
p_lum_func
[
*
p_in
];
p_out
++
;
p_in
++
;
)
}
p_in_end
+=
8
;
...
...
@@ -264,7 +270,7 @@ cleaner :) */
for
(
;
p_in
<
p_in_end
;
)
{
/* Do 1 pixel at a time */
*
p_out
=
maxmin
(
((
*
p_in
*
cont
)
>>
8
)
+
lum
+
dec
)
;
p_out
++
;
p_in
++
;
*
p_out
=
p_lum_func
[
*
p_in
]
;
p_out
++
;
p_in
++
;
}
}
else
...
...
@@ -273,6 +279,7 @@ cleaner :) */
{
u8
*
p_in_u
,
*
p_in_v
,
*
p_in_end
,
*
p_out_u
,
*
p_out_v
,
i_u
,
i_v
;
s32
cospsin
,
cosmsin
;
p_in_u
=
p_pic
->
p
[
i_index
].
p_pixels
;
p_in_v
=
p_pic
->
p
[
i_index
+
1
].
p_pixels
;
...
...
@@ -282,76 +289,63 @@ cleaner :) */
p_out_u
=
p_outpic
->
p
[
i_index
].
p_pixels
;
p_out_v
=
p_outpic
->
p
[
i_index
+
1
].
p_pixels
;
cospsin
=
128
*
(
i_Cos
+
i_Sin
);
cosmsin
=
128
*
(
i_Cos
-
i_Sin
);
for
(
;
p_in_u
<
p_in_end
;
)
if
(
i_sat
>
256
)
{
/* Do 8 pixels at a time */
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
for
(
;
p_in_u
<
p_in_end
;
)
{
/* Do 8 pixels at a time */
eight_times
(
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
((
((
i_u
*
i_Cos
+
i_v
*
i_Sin
-
cospsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
((
((
i_v
*
i_Cos
-
i_u
*
i_Sin
-
cosmsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
)
}
p_in_end
+=
8
;
}
for
(
;
p_in_u
<
p_in_end
;
)
{
/* Do 1 pixel at a time */
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
((
((
i_u
*
i_Cos
+
i_v
*
i_Sin
-
cospsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
((
((
i_v
*
i_Cos
-
i_u
*
i_Sin
-
cosmsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
p_in_end
+=
8
;
for
(
;
p_in_u
<
p_in_end
;
)
}
}
else
{
/* Do 1 pixel at a time */
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
maxmin
(
(((((
i_u
*
i_Cos
+
i_v
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
*
p_out_v
=
maxmin
(
(((((
i_v
*
i_Cos
-
i_u
*
i_Sin
)
>>
8
)
-
128
)
*
i_sat
)
>>
8
)
+
128
);
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
for
(
;
p_in_u
<
p_in_end
;
)
{
/* Do 8 pixels at a time */
eight_times
(
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
((
((
i_u
*
i_Cos
+
i_v
*
i_Sin
-
cospsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
;
*
p_out_v
=
((
((
i_v
*
i_Cos
-
i_u
*
i_Sin
-
cosmsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
;
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
)
}
p_in_end
+=
8
;
for
(
;
p_in_u
<
p_in_end
;
)
{
/* Do 1 pixel at a time */
i_u
=
*
p_in_u
;
i_v
=
*
p_in_v
;
*
p_out_u
=
((
((
i_u
*
i_Cos
+
i_v
*
i_Sin
-
cospsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
;
*
p_out_v
=
((
((
i_v
*
i_Cos
-
i_u
*
i_Sin
-
cosmsin
)
>>
8
)
*
i_sat
)
>>
8
)
+
128
;
p_out_u
++
;
p_in_u
++
;
p_out_v
++
;
p_in_v
++
;
}
}
}
...
...
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