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
7c4b3975
Commit
7c4b3975
authored
Jan 11, 2012
by
Paul B Mahol
Committed by
Michael Niedermayer
Jan 11, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bmpdec: support various bitfields for 32 bit depth
Fixes #740 Signed-off-by:
Michael Niedermayer
<
michaelni@gmx.at
>
parent
106f714d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
35 deletions
+13
-35
bmp.c
libavcodec/bmp.c
+13
-35
No files found.
libavcodec/bmp.c
View file @
7c4b3975
...
@@ -141,21 +141,21 @@ static int bmp_decode_frame(AVCodecContext *avctx,
...
@@ -141,21 +141,21 @@ static int bmp_decode_frame(AVCodecContext *avctx,
switch
(
depth
){
switch
(
depth
){
case
32
:
case
32
:
if
(
comp
==
BMP_BITFIELDS
){
if
(
comp
==
BMP_BITFIELDS
){
rgb
[
0
]
=
(
rgb
[
0
]
>>
15
)
&
3
;
if
(
rgb
[
0
]
==
0xFF000000
&&
rgb
[
1
]
==
0x00FF0000
&&
rgb
[
2
]
==
0x0000FF00
)
rgb
[
1
]
=
(
rgb
[
1
]
>>
15
)
&
3
;
avctx
->
pix_fmt
=
PIX_FMT_ABGR
;
rgb
[
2
]
=
(
rgb
[
2
]
>>
15
)
&
3
;
else
if
(
rgb
[
0
]
==
0x00FF0000
&&
rgb
[
1
]
==
0x0000FF00
&&
rgb
[
2
]
==
0x000000FF
)
avctx
->
pix_fmt
=
PIX_FMT_BGRA
;
if
(
rgb
[
0
]
+
rgb
[
1
]
+
rgb
[
2
]
!=
3
||
else
if
(
rgb
[
0
]
==
0x0000FF00
&&
rgb
[
1
]
==
0x00FF0000
&&
rgb
[
2
]
==
0xFF000000
)
rgb
[
0
]
==
rgb
[
1
]
||
rgb
[
0
]
==
rgb
[
2
]
||
rgb
[
1
]
==
rgb
[
2
]){
avctx
->
pix_fmt
=
PIX_FMT_ARGB
;
break
;
else
if
(
rgb
[
0
]
==
0x000000FF
&&
rgb
[
1
]
==
0x0000FF00
&&
rgb
[
2
]
==
0x00FF0000
)
avctx
->
pix_fmt
=
PIX_FMT_RGBA
;
else
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"Unknown bitfields %0X %0X %0X
\n
"
,
rgb
[
0
],
rgb
[
1
],
rgb
[
2
]);
return
AVERROR
(
EINVAL
);
}
}
}
else
{
}
else
{
rgb
[
0
]
=
2
;
avctx
->
pix_fmt
=
PIX_FMT_BGRA
;
rgb
[
1
]
=
1
;
rgb
[
2
]
=
0
;
}
}
avctx
->
pix_fmt
=
PIX_FMT_BGRA
;
break
;
break
;
case
24
:
case
24
:
avctx
->
pix_fmt
=
PIX_FMT_BGR24
;
avctx
->
pix_fmt
=
PIX_FMT_BGR24
;
...
@@ -292,6 +292,7 @@ static int bmp_decode_frame(AVCodecContext *avctx,
...
@@ -292,6 +292,7 @@ static int bmp_decode_frame(AVCodecContext *avctx,
break
;
break
;
case
8
:
case
8
:
case
24
:
case
24
:
case
32
:
for
(
i
=
0
;
i
<
avctx
->
height
;
i
++
){
for
(
i
=
0
;
i
<
avctx
->
height
;
i
++
){
memcpy
(
ptr
,
buf
,
n
);
memcpy
(
ptr
,
buf
,
n
);
buf
+=
n
;
buf
+=
n
;
...
@@ -321,29 +322,6 @@ static int bmp_decode_frame(AVCodecContext *avctx,
...
@@ -321,29 +322,6 @@ static int bmp_decode_frame(AVCodecContext *avctx,
ptr
+=
linesize
;
ptr
+=
linesize
;
}
}
break
;
break
;
case
32
:
for
(
i
=
0
;
i
<
avctx
->
height
;
i
++
){
const
uint8_t
*
src
=
buf
;
uint8_t
*
dst
=
ptr
;
for
(
j
=
0
;
j
<
avctx
->
width
;
j
++
){
dst
[
0
]
=
src
[
rgb
[
2
]];
dst
[
1
]
=
src
[
rgb
[
1
]];
dst
[
2
]
=
src
[
rgb
[
0
]];
/* The Microsoft documentation states:
* "The high byte in each DWORD is not used."
* Both GIMP and ImageMagick store the alpha transparency value
* in the high byte for 32bit bmp files.
*/
dst
[
3
]
=
src
[
3
];
dst
+=
4
;
src
+=
4
;
}
buf
+=
n
;
ptr
+=
linesize
;
}
break
;
default
:
default
:
av_log
(
avctx
,
AV_LOG_ERROR
,
"BMP decoder is broken
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"BMP decoder is broken
\n
"
);
return
-
1
;
return
-
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