aboutsummaryrefslogtreecommitdiff
path: root/lib/gtk-vlc-player/gtk-vlc-player.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gtk-vlc-player/gtk-vlc-player.h')
-rw-r--r--lib/gtk-vlc-player/gtk-vlc-player.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/lib/gtk-vlc-player/gtk-vlc-player.h b/lib/gtk-vlc-player/gtk-vlc-player.h
new file mode 100644
index 0000000..217371c
--- /dev/null
+++ b/lib/gtk-vlc-player/gtk-vlc-player.h
@@ -0,0 +1,61 @@
+#ifndef __GTK_VLC_PLAYER_H
+#define __GTK_VLC_PLAYER_H
+
+#include <glib-object.h>
+#include <gtk/gtk.h>
+
+#include <vlc/vlc.h>
+
+G_BEGIN_DECLS
+
+#define GTK_TYPE_VLC_PLAYER \
+ (gtk_vlc_player_get_type())
+#define GTK_VLC_PLAYER(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST((obj), GTK_TYPE_VLC_PLAYER, GtkVlcPlayer))
+#define GTK_VLC_PLAYER_CLASS(klass) \
+ (G_TYPE_CHECK_CLASS_CAST((klass), GTK_TYPE_VLC_PLAYER, GtkVlcPlayerClass))
+#define GTK_IS_VLC_PLAYER(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE((obj), GTK_TYPE_VLC_PLAYER))
+#define GTK_IS_VLC_PLAYER_CLASS(klass) \
+ (G_TYPE_CHECK_CLASS_TYPE((klass), GTK_TYPE_VLC_PLAYER))
+#define GTK_VLC_PLAYER_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS((obj), GTK_TYPE_VLC_PLAYER, GtkVlcPlayerClass))
+
+typedef struct _GtkVlcPlayer {
+ GtkDrawingArea parent_instance;
+
+ libvlc_instance_t *vlc_inst;
+ libvlc_media_player_t *media_player;
+
+ gboolean isFullscreen;
+
+ GtkWidget *fullscreen_window;
+ GtkWidget *orig_parent;
+} GtkVlcPlayer;
+
+typedef struct _GtkVlcPlayerClass {
+ GtkDrawingAreaClass parent_class;
+
+ void (*time_changed) (GtkVlcPlayer *self, gint64 new_time, gpointer user_data);
+ void (*length_changed) (GtkVlcPlayer *self, gint64 new_length, gpointer user_data);
+} GtkVlcPlayerClass;
+
+GType gtk_vlc_player_get_type(void);
+
+/*
+ * API
+ */
+GtkWidget *gtk_vlc_player_new(void);
+gboolean gtk_vlc_player_load(GtkVlcPlayer *player, const gchar *uri);
+
+void gtk_vlc_player_play(GtkVlcPlayer *player);
+void gtk_vlc_player_pause(GtkVlcPlayer *player);
+gboolean gtk_vlc_player_toggle(GtkVlcPlayer *player);
+void gtk_vlc_player_stop(GtkVlcPlayer *player);
+
+void gtk_vlc_player_seek(GtkVlcPlayer *player, gint64 time);
+
+
+G_END_DECLS
+
+#endif