Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_25606643
ijkplayer
提交
7491f77c
I
ijkplayer
项目概览
qq_25606643
/
ijkplayer
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
I
ijkplayer
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7491f77c
编写于
12月 16, 2015
作者:
Z
Zhang Rui
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
android/MediaCodec: replace getInputBuffer with writeInputData
上级
071724c2
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
34 addition
and
64 deletion
+34
-64
ijkmedia/ijkplayer/android/pipeline/ffpipenode_android_mediacodec_vdec.c
...yer/android/pipeline/ffpipenode_android_mediacodec_vdec.c
+4
-9
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.c
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.c
+3
-9
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.h
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.h
+2
-4
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec_java.c
...dia/ijksdl/android/ijksdl_codec_android_mediacodec_java.c
+25
-42
未找到文件。
ijkmedia/ijkplayer/android/pipeline/ffpipenode_android_mediacodec_vdec.c
浏览文件 @
7491f77c
...
...
@@ -312,9 +312,7 @@ static int feed_input_buffer(JNIEnv *env, IJKFF_Pipenode *node, int64_t timeUs,
sdl_amedia_status_t
amc_ret
=
0
;
int
ret
=
0
;
ssize_t
input_buffer_index
=
0
;
uint8_t
*
input_buffer_ptr
=
NULL
;
size_t
input_buffer_size
=
0
;
size_t
copy_size
=
0
;
ssize_t
copy_size
=
0
;
int64_t
time_stamp
=
0
;
if
(
enqueue_count
)
...
...
@@ -506,16 +504,13 @@ static int feed_input_buffer(JNIEnv *env, IJKFF_Pipenode *node, int64_t timeUs,
ffp_packet_queue_flush
(
&
opaque
->
fake_pictq
);
}
input_buffer_ptr
=
SDL_AMediaCodec_getInputBuffer
(
opaque
->
acodec
,
input_buffer_index
,
&
input_buffer_
size
);
if
(
!
input_buffer_ptr
)
{
copy_size
=
SDL_AMediaCodec_writeInputData
(
opaque
->
acodec
,
input_buffer_index
,
d
->
pkt_temp
.
data
,
d
->
pkt_temp
.
size
);
if
(
!
copy_size
)
{
ALOGE
(
"%s: SDL_AMediaCodec_getInputBuffer failed
\n
"
,
__func__
);
ret
=
-
1
;
goto
fail
;
}
copy_size
=
FFMIN
(
input_buffer_size
,
d
->
pkt_temp
.
size
);
memcpy
(
input_buffer_ptr
,
d
->
pkt_temp
.
data
,
copy_size
);
time_stamp
=
d
->
pkt_temp
.
pts
;
if
(
!
time_stamp
&&
d
->
pkt_temp
.
dts
)
time_stamp
=
d
->
pkt_temp
.
dts
;
...
...
@@ -537,7 +532,7 @@ static int feed_input_buffer(JNIEnv *env, IJKFF_Pipenode *node, int64_t timeUs,
++*
enqueue_count
;
}
if
(
input_buffer
_size
<
0
)
{
if
(
copy
_size
<
0
)
{
d
->
packet_pending
=
0
;
}
else
{
d
->
pkt_temp
.
dts
=
...
...
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.c
浏览文件 @
7491f77c
...
...
@@ -148,16 +148,10 @@ sdl_amedia_status_t SDL_AMediaCodec_flush(SDL_AMediaCodec* acodec)
return
acodec
->
func_flush
(
acodec
);
}
uint8_t
*
SDL_AMediaCodec_getInputBuffer
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_
size
)
ssize_t
SDL_AMediaCodec_writeInputData
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
const
uint8_t
*
data
,
size_t
size
)
{
assert
(
acodec
->
func_getInputBuffer
);
return
acodec
->
func_getInputBuffer
(
acodec
,
idx
,
out_size
);
}
uint8_t
*
SDL_AMediaCodec_getOutputBuffer
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_size
)
{
assert
(
acodec
->
func_getOutputBuffer
);
return
acodec
->
func_getOutputBuffer
(
acodec
,
idx
,
out_size
);
assert
(
acodec
->
func_writeInputData
);
return
acodec
->
func_writeInputData
(
acodec
,
idx
,
data
,
size
);
}
ssize_t
SDL_AMediaCodec_dequeueInputBuffer
(
SDL_AMediaCodec
*
acodec
,
int64_t
timeoutUs
)
...
...
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec.h
浏览文件 @
7491f77c
...
...
@@ -76,8 +76,7 @@ typedef struct SDL_AMediaCodec
sdl_amedia_status_t
(
*
func_stop
)(
SDL_AMediaCodec
*
acodec
);
sdl_amedia_status_t
(
*
func_flush
)(
SDL_AMediaCodec
*
acodec
);
uint8_t
*
(
*
func_getInputBuffer
)(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_size
);
uint8_t
*
(
*
func_getOutputBuffer
)(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_size
);
ssize_t
(
*
func_writeInputData
)(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
const
uint8_t
*
data
,
size_t
size
);
ssize_t
(
*
func_dequeueInputBuffer
)(
SDL_AMediaCodec
*
acodec
,
int64_t
timeoutUs
);
sdl_amedia_status_t
(
*
func_queueInputBuffer
)(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
off_t
offset
,
size_t
size
,
uint64_t
time
,
uint32_t
flags
);
...
...
@@ -128,8 +127,7 @@ sdl_amedia_status_t SDL_AMediaCodec_start(SDL_AMediaCodec* acodec);
sdl_amedia_status_t
SDL_AMediaCodec_stop
(
SDL_AMediaCodec
*
acodec
);
sdl_amedia_status_t
SDL_AMediaCodec_flush
(
SDL_AMediaCodec
*
acodec
);
uint8_t
*
SDL_AMediaCodec_getInputBuffer
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_size
);
// uint8_t* SDL_AMediaCodec_getOutputBuffer(SDL_AMediaCodec* acodec, size_t idx, size_t *out_size);
ssize_t
SDL_AMediaCodec_writeInputData
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
const
uint8_t
*
data
,
size_t
size
);
ssize_t
SDL_AMediaCodec_dequeueInputBuffer
(
SDL_AMediaCodec
*
acodec
,
int64_t
timeoutUs
);
sdl_amedia_status_t
SDL_AMediaCodec_queueInputBuffer
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
off_t
offset
,
size_t
size
,
uint64_t
time
,
uint32_t
flags
);
...
...
ijkmedia/ijksdl/android/ijksdl_codec_android_mediacodec_java.c
浏览文件 @
7491f77c
...
...
@@ -36,8 +36,6 @@ static SDL_Class g_amediacodec_class = {
typedef
struct
SDL_AMediaCodec_Opaque
{
jobject
android_media_codec
;
jobjectArray
input_buffer_array
;
jobject
input_buffer
;
jobject
output_buffer_info
;
bool
is_input_buffer_valid
;
...
...
@@ -93,8 +91,6 @@ static sdl_amedia_status_t SDL_AMediaCodecJava_delete(SDL_AMediaCodec* acodec)
}
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
output_buffer_info
);
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer
);
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer_array
);
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
android_media_codec
);
}
...
...
@@ -102,19 +98,6 @@ static sdl_amedia_status_t SDL_AMediaCodecJava_delete(SDL_AMediaCodec* acodec)
return
SDL_AMEDIA_OK
;
}
inline
static
int
getInputBuffers
(
JNIEnv
*
env
,
SDL_AMediaCodec
*
acodec
)
{
SDL_AMediaCodec_Opaque
*
opaque
=
(
SDL_AMediaCodec_Opaque
*
)
acodec
->
opaque
;
jobject
android_media_codec
=
opaque
->
android_media_codec
;
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer_array
);
opaque
->
input_buffer_array
=
JJKC_MediaCodec__getInputBuffers__asGlobalRef__catchAll
(
env
,
android_media_codec
);
if
(
!
opaque
->
input_buffer_array
)
return
-
1
;
return
0
;
}
static
sdl_amedia_status_t
SDL_AMediaCodecJava_configure_surface
(
JNIEnv
*
env
,
SDL_AMediaCodec
*
acodec
,
...
...
@@ -135,7 +118,6 @@ static sdl_amedia_status_t SDL_AMediaCodecJava_configure_surface(
}
opaque
->
is_input_buffer_valid
=
true
;
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer_array
);
return
SDL_AMEDIA_OK
;
}
...
...
@@ -202,46 +184,48 @@ static sdl_amedia_status_t SDL_AMediaCodecJava_flush(SDL_AMediaCodec* acodec)
return
SDL_AMEDIA_OK
;
}
static
uint8_t
*
SDL_AMediaCodecJava_getInputBuffer
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
size_t
*
out_
size
)
static
ssize_t
SDL_AMediaCodecJava_writeInputData
(
SDL_AMediaCodec
*
acodec
,
size_t
idx
,
const
uint8_t
*
data
,
size_t
size
)
{
AMCTRACE
(
"%s"
,
__func__
);
ssize_t
write_ret
=
-
1
;
jobject
input_buffer_array
=
NULL
;
jobject
input_buffer
=
NULL
;
JNIEnv
*
env
=
NULL
;
if
(
JNI_OK
!=
SDL_JNI_SetupThreadEnv
(
&
env
))
{
ALOGE
(
"%s: SetupThreadEnv failed"
,
__func__
);
return
NULL
;
return
-
1
;
}
SDL_AMediaCodec_Opaque
*
opaque
=
(
SDL_AMediaCodec_Opaque
*
)
acodec
->
opaque
;
if
(
0
!=
getInputBuffers
(
env
,
acodec
))
return
NULL
;
input_buffer_array
=
JJKC_MediaCodec__getInputBuffers__catchAll
(
env
,
opaque
->
android_media_codec
);
if
(
!
input_buffer_array
)
return
-
1
;
assert
(
opaque
->
input_buffer_array
);
int
buffer_count
=
(
*
env
)
->
GetArrayLength
(
env
,
opaque
->
input_buffer_array
);
int
buffer_count
=
(
*
env
)
->
GetArrayLength
(
env
,
input_buffer_array
);
if
(
JJK_ExceptionCheck__catchAll
(
env
)
||
idx
<
0
||
idx
>=
buffer_count
)
{
ALOGE
(
"%s: idx(%d) < count(%d)
\n
"
,
__func__
,
(
int
)
idx
,
(
int
)
buffer_count
);
return
NULL
;
goto
fail
;
}
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer
);
jobject
local_input_buffer
=
(
*
env
)
->
GetObjectArrayElement
(
env
,
opaque
->
input_buffer_array
,
idx
);
if
(
JJK_ExceptionCheck__catchAll
(
env
)
||
!
local_input_buffer
)
{
input_buffer
=
(
*
env
)
->
GetObjectArrayElement
(
env
,
input_buffer_array
,
idx
);
if
(
JJK_ExceptionCheck__catchAll
(
env
)
||
!
input_buffer
)
{
ALOGE
(
"%s: GetObjectArrayElement failed
\n
"
,
__func__
);
return
NULL
;
}
opaque
->
input_buffer
=
(
*
env
)
->
NewGlobalRef
(
env
,
local_input_buffer
);
SDL_JNI_DeleteLocalRefP
(
env
,
&
local_input_buffer
);
if
(
JJK_ExceptionCheck__catchAll
(
env
)
||
!
opaque
->
input_buffer
)
{
ALOGE
(
"%s: GetObjectArrayElement.NewGlobalRef failed
\n
"
,
__func__
);
return
NULL
;
goto
fail
;
}
jlong
size
=
(
*
env
)
->
GetDirectBufferCapacity
(
env
,
opaque
->
input_buffer
);
void
*
ptr
=
(
*
env
)
->
GetDirectBufferAddress
(
env
,
opaque
->
input_buffer
);
{
jlong
buf_size
=
(
*
env
)
->
GetDirectBufferCapacity
(
env
,
input_buffer
);
void
*
buf_ptr
=
(
*
env
)
->
GetDirectBufferAddress
(
env
,
input_buffer
);
write_ret
=
size
<
buf_size
?
size
:
buf_size
;
memcpy
(
buf_ptr
,
data
,
write_ret
);
}
if
(
out_size
)
*
out_size
=
size
;
return
ptr
;
fail:
SDL_JNI_DeleteLocalRefP
(
env
,
&
input_buffer
);
SDL_JNI_DeleteLocalRefP
(
env
,
&
input_buffer_array
);
return
write_ret
;
}
ssize_t
SDL_AMediaCodecJava_dequeueInputBuffer
(
SDL_AMediaCodec
*
acodec
,
int64_t
timeoutUs
)
...
...
@@ -321,7 +305,6 @@ ssize_t SDL_AMediaCodecJava_dequeueOutputBuffer(SDL_AMediaCodec* acodec, SDL_AMe
}
if
(
idx
==
AMEDIACODEC__INFO_OUTPUT_BUFFERS_CHANGED
)
{
ALOGI
(
"%s: INFO_OUTPUT_BUFFERS_CHANGED
\n
"
,
__func__
);
SDL_JNI_DeleteGlobalRefP
(
env
,
&
opaque
->
input_buffer_array
);
continue
;
}
else
if
(
idx
==
AMEDIACODEC__INFO_OUTPUT_FORMAT_CHANGED
)
{
ALOGI
(
"%s: INFO_OUTPUT_FORMAT_CHANGED
\n
"
,
__func__
);
...
...
@@ -394,7 +377,7 @@ static SDL_AMediaCodec* SDL_AMediaCodecJava_init(JNIEnv *env, jobject android_me
acodec
->
func_stop
=
SDL_AMediaCodecJava_stop
;
acodec
->
func_flush
=
SDL_AMediaCodecJava_flush
;
acodec
->
func_
getInputBuffer
=
SDL_AMediaCodecJava_getInputBuffer
;
acodec
->
func_
writeInputData
=
SDL_AMediaCodecJava_writeInputData
;
acodec
->
func_dequeueInputBuffer
=
SDL_AMediaCodecJava_dequeueInputBuffer
;
acodec
->
func_queueInputBuffer
=
SDL_AMediaCodecJava_queueInputBuffer
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录