]> git.sesse.net Git - vlc/blobdiff - bindings/java/core/src/main/java/org/videolan/jvlc/internal/LibVlc.java
jvlc: libvlc synchronization: some missing audio functions added
[vlc] / bindings / java / core / src / main / java / org / videolan / jvlc / internal / LibVlc.java
index 66725fb16b6217354d98b54021c94189d0d54685..b3e9dca6254ad332127af5125173a282f5043007 100644 (file)
@@ -25,9 +25,6 @@
 
 package org.videolan.jvlc.internal;
 
-import java.util.HashMap;
-import java.util.Map;
-
 import com.sun.jna.Callback;
 import com.sun.jna.Library;
 import com.sun.jna.Native;
@@ -37,30 +34,17 @@ import com.sun.jna.Pointer;
 import com.sun.jna.PointerType;
 import com.sun.jna.Structure;
 import com.sun.jna.Union;
-import com.sun.jna.win32.W32APIFunctionMapper;
-import com.sun.jna.win32.W32APITypeMapper;
 
 
 public interface LibVlc extends Library
 {
-    Map options = new HashMap() {
-        {
-            put(Library.OPTION_DLOPEN_GLOBAL, Boolean.TRUE);
-        }
-    };
-    
-    LibVlc INSTANCE = (LibVlc) Native.loadLibrary(Platform.isWindows()? "libvlc" : "vlc", LibVlc.class, options);
+    LibVlc INSTANCE = (LibVlc) Native.loadLibrary(Platform.isWindows()? "libvlc" : "vlc", LibVlc.class);
 
     LibVlc SYNC_INSTANCE = (LibVlc) Native.synchronizedLibrary(INSTANCE);
-    
+
     public static class libvlc_exception_t extends Structure
     {
-
-        public int raised;
-
-        public int code;
-
-        public String message;
+        public int b_raised;
     }
 
     public static class libvlc_log_message_t extends Structure
@@ -84,7 +68,7 @@ public interface LibVlc extends Library
 
         public int type;
 
-        public Pointer obj;
+        public Pointer p_obj;
 
         public event_type_specific event_type_specific;
 
@@ -92,7 +76,7 @@ public interface LibVlc extends Library
 
     public class media_meta_changed extends Structure
     {
-
+        // Enum !
         public Pointer meta_type;
     }
 
@@ -142,6 +126,21 @@ public interface LibVlc extends Library
         public long new_time;
     }
 
+    public class media_player_title_changed extends Structure
+    {
+        public int new_title;
+    }
+
+    public class media_player_seekable_changed extends Structure
+    {
+        public NativeLong new_seekable;
+    }
+
+    public class media_player_pausable_changed extends Structure
+    {
+        public NativeLong new_pausable;
+    }
+
     /* media list */
     public class media_list_item_added extends Structure
     {
@@ -208,17 +207,26 @@ public interface LibVlc extends Library
         public int index;
     }
 
-    /* media discoverer */
-    public class media_media_discoverer_started extends Structure
+    public class media_list_player_next_item_set extends Structure
     {
+        public LibVlcMedia item;
+    }
 
-        public Pointer unused;
+    public class media_player_snapshot_taken extends Structure
+    {
+        public String psz_filename;
     }
 
-    public class media_media_discoverer_ended extends Structure
+    public class media_player_length_changed extends Structure
     {
+        // @todo: check the type
+        public long new_length;
+    }
 
-        public Pointer unused;
+    public class vlm_media_event extends Structure
+    {
+        public String psz_media_name;
+        public String psz_instance_name;
     }
 
     public class event_type_specific extends Union
@@ -240,6 +248,12 @@ public interface LibVlc extends Library
 
         public media_player_time_changed media_player_time_changed;
 
+        public media_player_title_changed media_player_title_changed;
+
+        public media_player_seekable_changed media_player_seekable_changed;
+
+        public media_player_pausable_changed media_player_pausable_changed;
+
         public media_list_item_added media_list_item_added;
 
         public media_list_will_add_item media_list_will_add_item;
@@ -255,6 +269,14 @@ public interface LibVlc extends Library
         public media_list_view_item_deleted media_list_view_item_deleted;
 
         public media_list_view_will_delete_item media_list_view_will_delete_item;
+
+        public media_list_player_next_item_set media_list_player_next_item_set;
+
+        public media_player_snapshot_taken media_player_snapshot_taken;
+
+        public media_player_length_changed media_player_length_changed;
+
+        public vlm_media_event vlm_media_event;
     }
 
     public class LibVlcInstance extends PointerType
@@ -265,7 +287,7 @@ public interface LibVlc extends Library
     {
     }
 
-    public class LibVlcMediaInstance extends PointerType
+    public class LibVlcMediaPlayer extends PointerType
     {
     }
 
@@ -304,51 +326,57 @@ public interface LibVlc extends Library
     LibVlcInstance libvlc_new(int argc, String[] argv, libvlc_exception_t exception);
 
     void libvlc_release(LibVlcInstance libvlc_instance_t);
-  
+
     void libvlc_add_intf(LibVlcInstance libvlc_instance_t, String name, libvlc_exception_t exception);
-    
+
     void libvlc_wait(LibVlcInstance libvlc_instance_t);
-    
+
     String libvlc_get_version();
-    
+
     String libvlc_get_compiler();
-    
+
     String libvlc_get_changeset();
 
     // video
+    
+    void libvlc_media_player_set_hwnd(LibVlcMediaPlayer mediaplayer_instance, long drawable, libvlc_exception_t exception);
+    
+    long libvlc_media_player_get_hwnd(LibVlcMediaPlayer mediaplayer_instance);
+    
+    void libvlc_media_player_set_xwindow(LibVlcMediaPlayer mediaplayer_instance, long drawable, libvlc_exception_t exception);
+    
+    long libvlc_media_player_get_xwindow(LibVlcMediaPlayer mediaplayer_instance);
 
-    void libvlc_video_set_parent(LibVlcInstance libvlc_instance, long drawable, libvlc_exception_t exception);
-
-    void libvlc_toggle_fullscreen(LibVlcMediaInstance libvlc_instance);
+    void libvlc_toggle_fullscreen(LibVlcMediaPlayer libvlc_instance);
 
-    void libvlc_set_fullscreen(LibVlcMediaInstance instance, int fullscreen, libvlc_exception_t exception);
+    void libvlc_set_fullscreen(LibVlcMediaPlayer instance, int fullscreen, libvlc_exception_t exception);
 
-    int libvlc_get_fullscreen(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_get_fullscreen(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_video_get_height(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_video_get_height(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_video_get_width(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_video_get_width(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    String libvlc_video_get_aspect_ration(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    String libvlc_video_get_aspect_ration(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    void libvlc_video_set_aspect_ration(LibVlcMediaInstance instance, String ratio, libvlc_exception_t exception);
+    void libvlc_video_set_aspect_ration(LibVlcMediaPlayer instance, String ratio, libvlc_exception_t exception);
 
-    int libvlc_video_get_spu(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_video_get_spu(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_video_set_spu(LibVlcMediaInstance instance, int spu, libvlc_exception_t exception);
+    int libvlc_video_set_spu(LibVlcMediaPlayer instance, int spu, libvlc_exception_t exception);
 
-    String libvlc_video_get_crop_geometry(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    String libvlc_video_get_crop_geometry(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    void libvlc_video_set_crop_geometry(LibVlcMediaInstance instance, String geometry, libvlc_exception_t exception);
+    void libvlc_video_set_crop_geometry(LibVlcMediaPlayer instance, String geometry, libvlc_exception_t exception);
 
-    void libvlc_video_take_snapshot(LibVlcMediaInstance instance, String filename, int width, int height,
+    void libvlc_video_take_snapshot(LibVlcMediaPlayer instance, String filename, int width, int height,
         libvlc_exception_t exception);
 
-    void libvlc_video_destroy(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_video_destroy(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    void libvlc_video_resize(LibVlcMediaInstance instance, int width, int height, libvlc_exception_t exception);
+    void libvlc_video_resize(LibVlcMediaPlayer instance, int width, int height, libvlc_exception_t exception);
 
-    void libvlc_video_reparent(LibVlcMediaInstance instance, long drawable, libvlc_exception_t exception);
+    void libvlc_video_reparent(LibVlcMediaPlayer instance, long drawable, libvlc_exception_t exception);
 
     void libvlc_video_set_size(LibVlcInstance instance, int width, int height, libvlc_exception_t exception);
 
@@ -364,16 +392,26 @@ public interface LibVlc extends Library
 
     int libvlc_audio_set_volume(LibVlcInstance instance, int volume, libvlc_exception_t exception);
 
-    int libvlc_audio_get_track_count(LibVlcMediaInstance mediaInstance, libvlc_exception_t exception);
+    int libvlc_audio_get_track_count(LibVlcMediaPlayer mediaInstance, libvlc_exception_t exception);
 
-    int libvlc_audio_get_track(LibVlcMediaInstance mediaInstance, libvlc_exception_t exception);
+    int libvlc_audio_get_track(LibVlcMediaPlayer mediaInstance, libvlc_exception_t exception);
 
-    void libvlc_audio_set_track(LibVlcMediaInstance mediaInstance, int channel, libvlc_exception_t exception);
+    void libvlc_audio_set_track(LibVlcMediaPlayer mediaInstance, int channel, libvlc_exception_t exception);
 
     int libvlc_audio_get_channel(LibVlcInstance instance, libvlc_exception_t exception);
 
     void libvlc_audio_set_channel(LibVlcInstance instance, int channel, libvlc_exception_t exception);
 
+    int libvlc_audio_output_device_count(LibVlcInstance instance, libvlc_exception_t exception);
+    
+    String libvlc_audio_output_device_id(LibVlcInstance instance, String audio_output, int i_device);
+    
+    String libvlc_audio_output_device_longname(LibVlcInstance instance, String audio_output, int i_device);
+    
+    String libvlc_audio_output_device_set(LibVlcInstance instance, String audio_output, String device_name, String deviceId);
+    
+    int libvlc_audio_output_get_device_type(LibVlcInstance instance, libvlc_exception_t exception);
+        
     // playlist
 
     void libvlc_playlist_loop(LibVlcInstance instance, int loop, libvlc_exception_t exception);
@@ -399,11 +437,11 @@ public interface LibVlc extends Library
 
     int libvlc_playlist_delete_item(LibVlcInstance instance, int itemIndex, libvlc_exception_t exception);
 
-    LibVlcMediaInstance libvlc_playlist_get_media_player(LibVlcInstance instance, libvlc_exception_t exception);
+    LibVlcMediaPlayer libvlc_playlist_get_media_player(LibVlcInstance instance, libvlc_exception_t exception);
 
-    int libvlc_media_player_is_seekable(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_media_player_is_seekable(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_media_player_can_pause(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_media_player_can_pause(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
     // media descriptor
 
@@ -411,50 +449,64 @@ public interface LibVlc extends Library
 
     void libvlc_media_add_option(LibVlcMedia media, String option, libvlc_exception_t exception);
 
+    LibVlcMedia libvlc_media_duplicate(LibVlcMedia media);
+
     String libvlc_media_get_mrl(LibVlcMedia media);
 
+    void libvlc_media_retain(LibVlcMedia media);
+
     void libvlc_media_release(LibVlcMedia media);
 
+    int libvlc_media_get_state(LibVlcMedia media, libvlc_exception_t exception);
+
+    LibVlcMediaList libvlc_media_subitems(LibVlcMedia media, libvlc_exception_t exception);
+
     LibVlcEventManager libvlc_media_event_manager(LibVlcMedia media, libvlc_exception_t exception);
 
+    long libvlc_get_duration(LibVlcMedia media, libvlc_exception_t exception);
+
+    int libvlc_media_is_preparsed(LibVlcMedia media, libvlc_exception_t exception);
+
     // media player
 
-    LibVlcMediaInstance libvlc_media_player_new(LibVlcInstance instance, libvlc_exception_t exception);
+    LibVlcMediaPlayer libvlc_media_player_new(LibVlcInstance instance, libvlc_exception_t exception);
 
-    LibVlcMediaInstance libvlc_media_player_new_from_media(LibVlcMedia media, libvlc_exception_t exception);
+    LibVlcMediaPlayer libvlc_media_player_new_from_media(LibVlcMedia media, libvlc_exception_t exception);
 
-    void libvlc_media_player_play(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    void libvlc_media_player_play(LibVlcMediaPlayer media_player, libvlc_exception_t exception);
 
-    void libvlc_media_player_pause(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    void libvlc_media_player_pause(LibVlcMediaPlayer media_player, libvlc_exception_t exception);
 
-    void libvlc_media_player_stop(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    void libvlc_media_player_stop(LibVlcMediaPlayer media_player, libvlc_exception_t exception);
 
-    void libvlc_media_player_set_drawable(LibVlcMediaInstance libvlc_media_player, int drawable,
+    void libvlc_media_player_set_drawable(LibVlcMediaPlayer libvlc_media_player, int drawable,
         libvlc_exception_t exception);
 
-    long libvlc_media_player_get_length(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    long libvlc_media_player_get_length(LibVlcMediaPlayer instance, libvlc_exception_t exception);
+
+    long libvlc_media_player_get_time(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    long libvlc_media_player_get_time(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_player_set_time(LibVlcMediaPlayer instance, long time, libvlc_exception_t exception);
 
-    void libvlc_media_player_set_time(LibVlcMediaInstance instance, long time, libvlc_exception_t exception);
+    float libvlc_media_player_get_position(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    float libvlc_media_player_get_position(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_player_set_position(LibVlcMediaPlayer instance, float position, libvlc_exception_t exception);
 
-    void libvlc_media_player_set_position(LibVlcMediaInstance instance, float position, libvlc_exception_t exception);
+    int libvlc_media_player_is_playing(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_media_player_will_play(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_media_player_will_play(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    void libvlc_media_player_set_rate(LibVlcMediaInstance instance, float rate, libvlc_exception_t exception);
+    void libvlc_media_player_set_rate(LibVlcMediaPlayer instance, float rate, libvlc_exception_t exception);
 
-    float libvlc_media_player_get_rate(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    float libvlc_media_player_get_rate(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
-    int libvlc_media_player_has_vout(LibVlcMediaInstance instance2, libvlc_exception_t exception);
+    int libvlc_media_player_has_vout(LibVlcMediaPlayer instance2, libvlc_exception_t exception);
 
-    float libvlc_media_player_get_fps(LibVlcMediaInstance instance2, libvlc_exception_t exception);
+    float libvlc_media_player_get_fps(LibVlcMediaPlayer instance2, libvlc_exception_t exception);
 
-    void libvlc_media_player_release(LibVlcMediaInstance instance);
+    void libvlc_media_player_release(LibVlcMediaPlayer instance);
 
-    LibVlcEventManager libvlc_media_player_event_manager(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_player_event_manager(LibVlcMediaPlayer media_player, libvlc_exception_t exception);
 
     // media list
 
@@ -497,7 +549,7 @@ public interface LibVlc extends Library
     void libvlc_media_list_player_release(LibVlcMediaListPlayer libvlc_media_list_player);
 
     void libvlc_media_list_player_set_media_player(LibVlcMediaListPlayer libvlc_media_list_player,
-        LibVlcMediaInstance libvlc_media_player, libvlc_exception_t exception);
+        LibVlcMediaPlayer libvlc_media_player, libvlc_exception_t exception);
 
     void libvlc_media_list_player_set_media_list(LibVlcMediaListPlayer libvlc_media_list_player,
         LibVlcMediaList libvlc_media_list, libvlc_exception_t exception);
@@ -571,7 +623,7 @@ public interface LibVlc extends Library
     void libvlc_event_detach(LibVlcEventManager event_manager, int event_type, LibVlcCallback callback,
         Pointer userData, libvlc_exception_t excecption);
 
-    void libvlc_toggle_fullscreen(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_toggle_fullscreen(LibVlcMediaPlayer instance, libvlc_exception_t exception);
 
     // logging