1 /*****************************************************************************
2 * libvlc_events.h: libvlc_events external API structure
3 *****************************************************************************
4 * Copyright (C) 1998-2008 the VideoLAN team
7 * Authors: Filippo Carone <littlejohn@videolan.org>
8 * Pierre d'Herbemont <pdherbemont@videolan.org>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 #ifndef LIBVLC_EVENTS_H
26 #define LIBVLC_EVENTS_H 1
30 * This file defines libvlc_event external API
37 /*****************************************************************************
39 *****************************************************************************/
41 /** \defgroup libvlc_event libvlc_event
42 * \ingroup libvlc_core
43 * LibVLC Available Events
47 typedef enum libvlc_event_type_t {
48 libvlc_MediaMetaChanged,
49 libvlc_MediaSubItemAdded,
50 libvlc_MediaDurationChanged,
51 libvlc_MediaPreparsedChanged,
53 libvlc_MediaStateChanged,
55 libvlc_MediaPlayerNothingSpecial,
56 libvlc_MediaPlayerOpening,
57 libvlc_MediaPlayerBuffering,
58 libvlc_MediaPlayerPlaying,
59 libvlc_MediaPlayerPaused,
60 libvlc_MediaPlayerStopped,
61 libvlc_MediaPlayerForward,
62 libvlc_MediaPlayerBackward,
63 libvlc_MediaPlayerEndReached,
64 libvlc_MediaPlayerEncounteredError,
65 libvlc_MediaPlayerTimeChanged,
66 libvlc_MediaPlayerPositionChanged,
67 libvlc_MediaPlayerSeekableChanged,
68 libvlc_MediaPlayerPausableChanged,
70 libvlc_MediaListItemAdded,
71 libvlc_MediaListWillAddItem,
72 libvlc_MediaListItemDeleted,
73 libvlc_MediaListWillDeleteItem,
75 libvlc_MediaListViewItemAdded,
76 libvlc_MediaListViewWillAddItem,
77 libvlc_MediaListViewItemDeleted,
78 libvlc_MediaListViewWillDeleteItem,
80 libvlc_MediaListPlayerPlayed,
81 libvlc_MediaListPlayerNextItemSet,
82 libvlc_MediaListPlayerStopped,
84 libvlc_MediaDiscovererStarted,
85 libvlc_MediaDiscovererEnded,
87 libvlc_MediaPlayerTitleChanged
89 } libvlc_event_type_t;
93 * \param type the even type
94 * \param p_obj the sender object
95 * \param u Event dependent content
98 typedef struct libvlc_event_t
100 libvlc_event_type_t type;
102 union event_type_specific
104 /* media descriptor */
107 libvlc_meta_t meta_type;
108 } media_meta_changed;
111 libvlc_media_t * new_child;
112 } media_subitem_added;
115 int64_t new_duration;
116 } media_duration_changed;
120 } media_preparsed_changed;
127 libvlc_state_t new_state;
128 } media_state_changed;
134 } media_player_position_changed;
137 libvlc_time_t new_time;
138 } media_player_time_changed;
142 } media_player_title_changed;
145 libvlc_time_t new_seekable;
146 } media_player_seekable_changed;
149 libvlc_time_t new_pausable;
150 } media_player_pausable_changed;
155 libvlc_media_t * item;
157 } media_list_item_added;
160 libvlc_media_t * item;
162 } media_list_will_add_item;
165 libvlc_media_t * item;
167 } media_list_item_deleted;
170 libvlc_media_t * item;
172 } media_list_will_delete_item;
174 /* media list view */
177 libvlc_media_t * item;
179 } media_list_view_item_added;
182 libvlc_media_t * item;
184 } media_list_view_will_add_item;
187 libvlc_media_t * item;
189 } media_list_view_item_deleted;
192 libvlc_media_t * item;
194 } media_list_view_will_delete_item;
196 /* media discoverer */
200 } media_media_discoverer_started;
204 } media_media_discoverer_ended;
210 * Event manager that belongs to a libvlc object, and from whom events can
214 typedef struct libvlc_event_manager_t libvlc_event_manager_t;
217 * Callback function notification
218 * \param p_event the event triggering the callback
221 typedef void ( *libvlc_callback_t )( const libvlc_event_t *, void * );
229 #endif /* _LIBVLC_EVENTS_H */