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
6ec82b01
Commit
6ec82b01
authored
Apr 16, 2007
by
Antoine Cellerier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* erase.c: add bluring effect, fix a bunch of bugs and compile warnings. It now looks good.
* deinterlace.c: compile warning fix.
parent
c7bcb180
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
46 additions
and
21 deletions
+46
-21
modules/video_filter/deinterlace.c
modules/video_filter/deinterlace.c
+2
-1
modules/video_filter/erase.c
modules/video_filter/erase.c
+44
-20
No files found.
modules/video_filter/deinterlace.c
View file @
6ec82b01
...
@@ -369,7 +369,8 @@ static int Init( vout_thread_t *p_vout )
...
@@ -369,7 +369,8 @@ static int Init( vout_thread_t *p_vout )
static
vout_thread_t
*
SpawnRealVout
(
vout_thread_t
*
p_vout
)
static
vout_thread_t
*
SpawnRealVout
(
vout_thread_t
*
p_vout
)
{
{
vout_thread_t
*
p_real_vout
=
NULL
;
vout_thread_t
*
p_real_vout
=
NULL
;
video_format_t
fmt
=
{
0
};
video_format_t
fmt
;
memset
(
&
fmt
,
0
,
sizeof
(
video_format_t
)
);
msg_Dbg
(
p_vout
,
"spawning the real video output"
);
msg_Dbg
(
p_vout
,
"spawning the real video output"
);
...
...
modules/video_filter/erase.c
View file @
6ec82b01
...
@@ -94,7 +94,9 @@ struct filter_sys_t
...
@@ -94,7 +94,9 @@ struct filter_sys_t
static
void
LoadMask
(
filter_t
*
p_filter
,
const
char
*
psz_filename
)
static
void
LoadMask
(
filter_t
*
p_filter
,
const
char
*
psz_filename
)
{
{
image_handler_t
*
p_image
;
image_handler_t
*
p_image
;
video_format_t
fmt_in
=
{
0
},
fmt_out
=
{
0
};
video_format_t
fmt_in
,
fmt_out
;
memset
(
&
fmt_in
,
0
,
sizeof
(
video_format_t
)
);
memset
(
&
fmt_out
,
0
,
sizeof
(
video_format_t
)
);
fmt_out
.
i_chroma
=
VLC_FOURCC
(
'Y'
,
'U'
,
'V'
,
'A'
);
fmt_out
.
i_chroma
=
VLC_FOURCC
(
'Y'
,
'U'
,
'V'
,
'A'
);
if
(
p_filter
->
p_sys
->
p_mask
)
if
(
p_filter
->
p_sys
->
p_mask
)
p_filter
->
p_sys
->
p_mask
->
pf_release
(
p_filter
->
p_sys
->
p_mask
);
p_filter
->
p_sys
->
p_mask
->
pf_release
(
p_filter
->
p_sys
->
p_mask
);
...
@@ -238,35 +240,32 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
...
@@ -238,35 +240,32 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
uint8_t
*
p_outpix
=
p_outpic
->
p
[
i_plane
].
p_pixels
;
uint8_t
*
p_outpix
=
p_outpic
->
p
[
i_plane
].
p_pixels
;
uint8_t
*
p_mask
=
p_sys
->
p_mask
->
A_PIXELS
;
uint8_t
*
p_mask
=
p_sys
->
p_mask
->
A_PIXELS
;
int
i_x
=
p_sys
->
i_x
,
i_y
=
p_sys
->
i_y
;
int
x
,
y
;
int
x
,
y
;
int
i_height
=
i_mask_visible_lines
;
int
i_height
=
i_mask_visible_lines
;
int
i_width
=
i_mask_visible_pitch
;
int
i_width
=
i_mask_visible_pitch
;
if
(
i_plane
)
if
(
i_plane
)
/* U_PLANE or V_PLANE */
{
{
i_height
/=
2
;
i_width
/=
2
;
i_width
/=
2
;
i_height
/=
2
;
i_x
/=
2
;
i_y
/=
2
;
}
}
i_height
=
__MIN
(
i_visible_lines
-
(
i_plane
?
p_sys
->
i_y
/
2
:
p_sys
->
i_y
)
,
i_height
);
i_height
=
__MIN
(
i_visible_lines
-
i_y
,
i_height
);
i_width
=
__MIN
(
i_visible_pitch
-
(
i_plane
?
p_sys
->
i_x
/
2
:
p_sys
->
i_x
),
i_width
);
i_width
=
__MIN
(
i_visible_pitch
-
i_x
,
i_width
);
p_filter
->
p_libvlc
->
pf_memcpy
(
p_outpix
,
p_inpix
,
i_pitch
*
i_lines
);
p_filter
->
p_libvlc
->
pf_memcpy
(
p_outpix
,
p_inpix
,
i_pitch
*
i_lines
);
for
(
y
=
0
;
y
<
i_height
;
for
(
y
=
0
;
y
<
i_height
;
y
++
,
p_mask
+=
i_mask_pitch
)
y
++
,
p_mask
+=
i_plane
?
2
*
i_mask_pitch
:
i_mask_pitch
)
{
{
uint8_t
prev
,
next
;
uint8_t
prev
,
next
=
0
;
int
prev_x
=
0
,
next_x
=
-
1
;
int
prev_x
=
-
1
,
next_x
=
-
2
;
p_outpix
=
i_plane
?
p_outpix
=
p_outpic
->
p
[
i_plane
].
p_pixels
+
(
i_y
+
y
)
*
i_pitch
+
i_x
;
p_outpic
->
p
[
i_plane
].
p_pixels
if
(
i_x
)
+
(
p_sys
->
i_y
/
2
+
y
)
*
i_pitch
+
(
p_sys
->
i_x
/
2
)
:
p_outpic
->
p
[
i_plane
].
p_pixels
+
(
p_sys
->
i_y
+
y
)
*
i_pitch
+
p_sys
->
i_x
;
if
(
p_sys
->
i_x
)
{
{
prev
=
*
(
p_outpix
-
1
);
prev
=
*
(
p_outpix
-
1
);
}
}
else
if
(
y
||
p_sys
->
i_y
)
else
if
(
y
||
i_y
)
{
{
prev
=
*
(
p_outpix
-
i_pitch
);
prev
=
*
(
p_outpix
-
i_pitch
);
}
}
...
@@ -293,7 +292,7 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
...
@@ -293,7 +292,7 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
if
(
next_x
<=
prev_x
)
if
(
next_x
<=
prev_x
)
{
{
if
(
x0
==
x
)
x0
++
;
if
(
x0
==
x
)
x0
++
;
if
(
(
i_plane
?
p_sys
->
i_x
/
2
:
p_sys
->
i_x
)
+
i_width
>=
i_visible_pitch
)
if
(
x0
>=
i_visible_pitch
)
{
{
next_x
=
x0
;
next_x
=
x0
;
next
=
prev
;
next
=
prev
;
...
@@ -304,9 +303,11 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
...
@@ -304,9 +303,11 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
next
=
p_outpix
[
x0
];
next
=
p_outpix
[
x0
];
}
}
}
}
if
(
!
(
i_x
||
y
||
i_y
)
)
prev
=
next
;
}
}
/* interpolate new value */
/* interpolate new value */
p_outpix
[
x
]
=
prev
+
(
x
-
prev_x
)
*
(
next
-
prev
)
/
(
next_x
-
prev_x
);
p_outpix
[
x
]
=
prev
;
//
+ (x-prev_x)*(next-prev)/(next_x-prev_x);
}
}
else
else
{
{
...
@@ -315,6 +316,29 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
...
@@ -315,6 +316,29 @@ static void FilterErase( filter_t *p_filter, picture_t *p_inpic,
}
}
}
}
}
}
/* Vertical bluring */
p_mask
=
p_sys
->
p_mask
->
A_PIXELS
;
i_height
=
i_mask_visible_lines
/
(
i_plane
?
2
:
1
);
i_height
=
__MIN
(
i_visible_lines
-
i_y
-
2
,
i_height
);
for
(
y
=
__MAX
(
i_y
-
2
,
0
);
y
<
i_height
;
y
++
,
p_mask
+=
i_mask_pitch
)
{
p_outpix
=
p_outpic
->
p
[
i_plane
].
p_pixels
+
(
i_y
+
y
)
*
i_pitch
+
i_x
;
for
(
x
=
0
;
x
<
i_width
;
x
++
)
{
if
(
p_mask
[
i_plane
?
2
*
x
:
x
]
>
127
)
{
p_outpix
[
x
]
=
(
(
p_outpix
[
x
-
2
*
i_pitch
]
<<
1
)
/* 2 */
+
(
p_outpix
[
x
-
i_pitch
]
<<
2
)
/* 4 */
+
(
p_outpix
[
x
]
<<
2
)
/* 4 */
+
(
p_outpix
[
x
+
i_pitch
]
<<
2
)
/* 4 */
+
(
p_outpix
[
x
+
2
*
i_pitch
]
<<
1
)
)
>>
4
;
/* 2 */
}
}
}
}
}
}
}
...
...
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