mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-21 06:38:19 +00:00
playback/player: Update Android bindings to the latest API
This commit is contained in:
parent
b7a1198170
commit
5035124050
2 changed files with 77 additions and 21 deletions
|
@ -55,6 +55,8 @@ static JavaVM *java_vm;
|
||||||
static jfieldID native_player_field_id;
|
static jfieldID native_player_field_id;
|
||||||
static jmethodID on_position_updated_method_id;
|
static jmethodID on_position_updated_method_id;
|
||||||
static jmethodID on_duration_changed_method_id;
|
static jmethodID on_duration_changed_method_id;
|
||||||
|
static jmethodID on_state_changed_method_id;
|
||||||
|
static jmethodID on_buffering_method_id;
|
||||||
static jmethodID on_end_of_stream_method_id;
|
static jmethodID on_end_of_stream_method_id;
|
||||||
static jmethodID on_error_method_id;
|
static jmethodID on_error_method_id;
|
||||||
static jmethodID on_video_dimensions_changed_method_id;
|
static jmethodID on_video_dimensions_changed_method_id;
|
||||||
|
@ -130,6 +132,32 @@ on_duration_changed (GstPlayer * unused, GstClockTime duration, Player * player)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_state_changed (GstPlayer * unused, GstPlayerState state, Player * player)
|
||||||
|
{
|
||||||
|
JNIEnv *env = get_jni_env ();
|
||||||
|
|
||||||
|
(*env)->CallVoidMethod (env, player->java_player,
|
||||||
|
on_state_changed_method_id, state);
|
||||||
|
if ((*env)->ExceptionCheck (env)) {
|
||||||
|
(*env)->ExceptionDescribe (env);
|
||||||
|
(*env)->ExceptionClear (env);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_buffering (GstPlayer * unused, gint percent, Player * player)
|
||||||
|
{
|
||||||
|
JNIEnv *env = get_jni_env ();
|
||||||
|
|
||||||
|
(*env)->CallVoidMethod (env, player->java_player,
|
||||||
|
on_buffering_method_id, percent);
|
||||||
|
if ((*env)->ExceptionCheck (env)) {
|
||||||
|
(*env)->ExceptionDescribe (env);
|
||||||
|
(*env)->ExceptionClear (env);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
on_end_of_stream (GstPlayer * unused, Player * player)
|
on_end_of_stream (GstPlayer * unused, Player * player)
|
||||||
{
|
{
|
||||||
|
@ -187,6 +215,10 @@ native_new (JNIEnv * env, jobject thiz)
|
||||||
G_CALLBACK (on_position_updated), player);
|
G_CALLBACK (on_position_updated), player);
|
||||||
g_signal_connect (player->player, "duration-changed",
|
g_signal_connect (player->player, "duration-changed",
|
||||||
G_CALLBACK (on_duration_changed), player);
|
G_CALLBACK (on_duration_changed), player);
|
||||||
|
g_signal_connect (player->player, "state-changed",
|
||||||
|
G_CALLBACK (on_state_changed), player);
|
||||||
|
g_signal_connect (player->player, "buffering",
|
||||||
|
G_CALLBACK (on_buffering), player);
|
||||||
g_signal_connect (player->player, "end-of-stream",
|
g_signal_connect (player->player, "end-of-stream",
|
||||||
G_CALLBACK (on_end_of_stream), player);
|
G_CALLBACK (on_end_of_stream), player);
|
||||||
g_signal_connect (player->player, "error", G_CALLBACK (on_error), player);
|
g_signal_connect (player->player, "error", G_CALLBACK (on_error), player);
|
||||||
|
@ -283,20 +315,6 @@ native_get_uri (JNIEnv * env, jobject thiz)
|
||||||
return uri;
|
return uri;
|
||||||
}
|
}
|
||||||
|
|
||||||
static jboolean
|
|
||||||
native_is_playing (JNIEnv * env, jobject thiz)
|
|
||||||
{
|
|
||||||
Player *player = GET_CUSTOM_DATA (env, thiz, native_player_field_id);
|
|
||||||
jboolean is_playing;
|
|
||||||
|
|
||||||
if (!player)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
g_object_get (player->player, "is-playing", &is_playing, NULL);
|
|
||||||
|
|
||||||
return is_playing;
|
|
||||||
}
|
|
||||||
|
|
||||||
static jlong
|
static jlong
|
||||||
native_get_position (JNIEnv * env, jobject thiz)
|
native_get_position (JNIEnv * env, jobject thiz)
|
||||||
{
|
{
|
||||||
|
@ -406,6 +424,10 @@ native_class_init (JNIEnv * env, jclass klass)
|
||||||
(*env)->GetMethodID (env, klass, "onPositionUpdated", "(J)V");
|
(*env)->GetMethodID (env, klass, "onPositionUpdated", "(J)V");
|
||||||
on_duration_changed_method_id =
|
on_duration_changed_method_id =
|
||||||
(*env)->GetMethodID (env, klass, "onDurationChanged", "(J)V");
|
(*env)->GetMethodID (env, klass, "onDurationChanged", "(J)V");
|
||||||
|
on_state_changed_method_id =
|
||||||
|
(*env)->GetMethodID (env, klass, "onStateChanged", "(I)V");
|
||||||
|
on_buffering_method_id =
|
||||||
|
(*env)->GetMethodID (env, klass, "onBuffering", "(I)V");
|
||||||
on_end_of_stream_method_id =
|
on_end_of_stream_method_id =
|
||||||
(*env)->GetMethodID (env, klass, "onEndOfStream", "()V");
|
(*env)->GetMethodID (env, klass, "onEndOfStream", "()V");
|
||||||
on_error_method_id =
|
on_error_method_id =
|
||||||
|
@ -415,6 +437,7 @@ native_class_init (JNIEnv * env, jclass klass)
|
||||||
|
|
||||||
if (!native_player_field_id ||
|
if (!native_player_field_id ||
|
||||||
!on_position_updated_method_id || !on_duration_changed_method_id ||
|
!on_position_updated_method_id || !on_duration_changed_method_id ||
|
||||||
|
!on_state_changed_method_id || !on_buffering_method_id ||
|
||||||
!on_end_of_stream_method_id ||
|
!on_end_of_stream_method_id ||
|
||||||
!on_error_method_id || !on_video_dimensions_changed_method_id) {
|
!on_error_method_id || !on_video_dimensions_changed_method_id) {
|
||||||
static const gchar *message =
|
static const gchar *message =
|
||||||
|
@ -437,7 +460,6 @@ static JNINativeMethod native_methods[] = {
|
||||||
{"nativeFree", "()V", (void *) native_free},
|
{"nativeFree", "()V", (void *) native_free},
|
||||||
{"nativeGetUri", "()Ljava/lang/String;", (void *) native_get_uri},
|
{"nativeGetUri", "()Ljava/lang/String;", (void *) native_get_uri},
|
||||||
{"nativeSetUri", "(Ljava/lang/String;)V", (void *) native_set_uri},
|
{"nativeSetUri", "(Ljava/lang/String;)V", (void *) native_set_uri},
|
||||||
{"nativeIsPlaying", "()Z", (void *) native_is_playing},
|
|
||||||
{"nativeGetPosition", "()J", (void *) native_get_position},
|
{"nativeGetPosition", "()J", (void *) native_get_position},
|
||||||
{"nativeGetDuration", "()J", (void *) native_get_duration},
|
{"nativeGetDuration", "()J", (void *) native_get_duration},
|
||||||
{"nativeGetVolume", "()D", (void *) native_get_volume},
|
{"nativeGetVolume", "()D", (void *) native_get_volume},
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
*
|
*
|
||||||
* Copyright (C) 2014 Sebastian Dröge <sebastian@centricular.com>
|
* Copyright (C) 2014-2015 Sebastian Dröge <sebastian@centricular.com>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -77,11 +77,6 @@ public class Player implements Closeable {
|
||||||
nativeSetUri(uri);
|
nativeSetUri(uri);
|
||||||
}
|
}
|
||||||
|
|
||||||
private native boolean nativeIsPlaying();
|
|
||||||
public boolean isPlaying() {
|
|
||||||
return nativeIsPlaying();
|
|
||||||
}
|
|
||||||
|
|
||||||
private native long nativeGetPosition();
|
private native long nativeGetPosition();
|
||||||
public long getPosition() {
|
public long getPosition() {
|
||||||
return nativeGetPosition();
|
return nativeGetPosition();
|
||||||
|
@ -153,6 +148,45 @@ public class Player implements Closeable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final State[] stateMap = {State.STOPPED, State.BUFFERING, State.PAUSED, State.PLAYING};
|
||||||
|
public enum State {
|
||||||
|
STOPPED,
|
||||||
|
BUFFERING,
|
||||||
|
PAUSED,
|
||||||
|
PLAYING
|
||||||
|
}
|
||||||
|
|
||||||
|
public static interface StateChangedListener {
|
||||||
|
abstract void stateChanged(Player player, State state);
|
||||||
|
}
|
||||||
|
|
||||||
|
private StateChangedListener stateChangedListener;
|
||||||
|
public void setStateChangedListener(StateChangedListener listener) {
|
||||||
|
stateChangedListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onStateChanged(int stateIdx) {
|
||||||
|
if (stateChangedListener != null) {
|
||||||
|
State state = stateMap[stateIdx];
|
||||||
|
stateChangedListener.stateChanged(this, state);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static interface BufferingListener {
|
||||||
|
abstract void buffering(Player player, int percent);
|
||||||
|
}
|
||||||
|
|
||||||
|
private BufferingListener bufferingListener;
|
||||||
|
public void setBufferingListener(BufferingListener listener) {
|
||||||
|
bufferingListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onBuffering(int percent) {
|
||||||
|
if (bufferingListener != null) {
|
||||||
|
bufferingListener.buffering(this, percent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static interface EndOfStreamListener {
|
public static interface EndOfStreamListener {
|
||||||
abstract void endOfStream(Player player);
|
abstract void endOfStream(Player player);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue