Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
11ddc8cb
Commit
11ddc8cb
authored
Jun 03, 2015
by
Steve Lhomme
Committed by
Jean-Baptiste Kempf
Jun 11, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
direct3d9: optimize the region copy of RGBA buffers
Signed-off-by:
Jean-Baptiste Kempf
<
jb@videolan.org
>
parent
bdc8dd67
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
5 deletions
+11
-5
modules/video_output/msw/direct3d9.c
modules/video_output/msw/direct3d9.c
+11
-5
No files found.
modules/video_output/msw/direct3d9.c
View file @
11ddc8cb
...
...
@@ -1650,12 +1650,18 @@ static void Direct3D9ImportSubpicture(vout_display_t *vd,
r
->
fmt
.
i_x_offset
*
r
->
p_picture
->
p
->
i_pixel_pitch
;
uint8_t
*
src_data
=
&
r
->
p_picture
->
p
->
p_pixels
[
src_offset
];
int
src_pitch
=
r
->
p_picture
->
p
->
i_pitch
;
for
(
unsigned
y
=
0
;
y
<
r
->
fmt
.
i_visible_height
;
y
++
)
{
int
copy_pitch
=
__MIN
(
dst_pitch
,
r
->
p_picture
->
p
->
i_visible_pitch
);
if
(
d3dr
->
format
==
D3DFMT_A8B8G8R8
)
{
memcpy
(
&
dst_data
[
y
*
dst_pitch
],
&
src_data
[
y
*
src_pitch
],
copy
_pitch
);
if
(
dst_pitch
==
r
->
p_picture
->
p
->
i_visible_pitch
)
{
memcpy
(
dst_data
,
src_data
,
r
->
fmt
.
i_visible_height
*
dst
_pitch
);
}
else
{
int
copy_pitch
=
__MIN
(
dst_pitch
,
r
->
p_picture
->
p
->
i_visible_pitch
);
for
(
unsigned
y
=
0
;
y
<
r
->
fmt
.
i_visible_height
;
y
++
)
{
memcpy
(
&
dst_data
[
y
*
dst_pitch
],
&
src_data
[
y
*
src_pitch
],
copy_pitch
);
}
}
}
else
{
int
copy_pitch
=
__MIN
(
dst_pitch
,
r
->
p_picture
->
p
->
i_visible_pitch
);
for
(
unsigned
y
=
0
;
y
<
r
->
fmt
.
i_visible_height
;
y
++
)
{
for
(
int
x
=
0
;
x
<
copy_pitch
;
x
+=
4
)
{
dst_data
[
y
*
dst_pitch
+
x
+
0
]
=
src_data
[
y
*
src_pitch
+
x
+
2
];
dst_data
[
y
*
dst_pitch
+
x
+
1
]
=
src_data
[
y
*
src_pitch
+
x
+
1
];
...
...
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