Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
d9bc2eda
Commit
d9bc2eda
authored
Feb 22, 2009
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Low-level support for events attaching/detaching
parent
113488b7
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
212 additions
and
11 deletions
+212
-11
bindings/cil/src/libvlc.cs
bindings/cil/src/libvlc.cs
+78
-6
bindings/cil/src/marshal.cs
bindings/cil/src/marshal.cs
+122
-3
bindings/cil/src/media.cs
bindings/cil/src/media.cs
+6
-1
bindings/cil/src/player.cs
bindings/cil/src/player.cs
+6
-1
No files found.
bindings/cil/src/libvlc.cs
View file @
d9bc2eda
...
@@ -117,10 +117,10 @@ namespace VideoLAN.LibVLC
...
@@ -117,10 +117,10 @@ namespace VideoLAN.LibVLC
public static extern
public static extern
MediaListHandle MediaSubItems (MediaHandle media, NativeException ex);*/
MediaListHandle MediaSubItems (MediaHandle media, NativeException ex);*/
/*
[DllImport ("libvlc.dll", EntryPoint="libvlc_media_event_manager")]
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_media_event_manager"
)]
public
static
extern
public
static
extern
EventManagerHandle Media
Get
EventManager (MediaHandle media,
EventManagerHandle
MediaEventManager
(
MediaHandle
media
,
NativeException ex);*/
NativeException
ex
);
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_media_get_duration"
)]
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_media_get_duration"
)]
public
static
extern
public
static
extern
...
@@ -168,11 +168,12 @@ namespace VideoLAN.LibVLC
...
@@ -168,11 +168,12 @@ namespace VideoLAN.LibVLC
MediaHandle PlayerGetMedia (PlayerHandle player,
MediaHandle PlayerGetMedia (PlayerHandle player,
NativeException ex);*/
NativeException ex);*/
/*
[DllImport ("libvlc.dll",
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_media_player_event_manager"
)]
EntryPoint
=
"libvlc_media_player_event_manager"
)]
public
static
extern
public
static
extern
EventManagerHandle PlayerGetEventManager (PlayerHandle media,
EventManagerHandle
PlayerEventManager
(
PlayerHandle
media
,
NativeException ex);*/
NativeException
ex
);
[
DllImport
(
"libvlc.dll"
,
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_media_player_is_playing"
)]
EntryPoint
=
"libvlc_media_player_is_playing"
)]
public
static
extern
public
static
extern
...
@@ -326,5 +327,76 @@ namespace VideoLAN.LibVLC
...
@@ -326,5 +327,76 @@ namespace VideoLAN.LibVLC
public
static
extern
public
static
extern
int
PlayerCanPause
(
PlayerHandle
player
,
NativeException
ex
);
int
PlayerCanPause
(
PlayerHandle
player
,
NativeException
ex
);
/* TODO: video, audio */
/* event.c */
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_event_attach"
)]
public
static
extern
void
EventAttach
(
EventManagerHandle
manager
,
EventType
type
,
IntPtr
callback
,
IntPtr
user_data
,
NativeException
ex
);
[
DllImport
(
"libvlc.dll"
,
EntryPoint
=
"libvlc_event_detach"
)]
public
static
extern
void
EventDetach
(
EventManagerHandle
manager
,
EventType
type
,
IntPtr
callback
,
IntPtr
user_data
,
NativeException
ex
);
/* libvlc_event_type_name */
};
/**
* @brief EventCallback: LibVLC event handler
* @ingroup Internals
*/
internal
delegate
void
EventCallback
(
IntPtr
ev
,
IntPtr
data
);
/**
* @brief EventType: LibVLC event types
* @ingroup Internals
*/
internal
enum
EventType
{
MediaMetaChanged
,
MediaSubItemAdded
,
MediaDurationChanged
,
MediaPreparsedChanged
,
MediaFreed
,
MediaStateChanged
,
PlayerNothingSpecial
,
PlayerOpening
,
PlayerBuffering
,
PlayerPlaying
,
PlayerPaused
,
PlayerStopped
,
PlayerForward
,
PlayerBackward
,
PlayerEndReached
,
PlayerEncounteredError
,
PlayerTimeChanged
,
PlayerPositionChanged
,
PlayerSeekableChanged
,
PlayerPausableChanged
,
ListItemAdded
,
ListWillAddItem
,
ListItemDeleted
,
ListWillDeleteItem
,
ListViewItemAdded
,
ListViewWillAddItem
,
ListViewItemDeleted
,
ListViewWillDeleteItem
,
ListPlayerPlayed
,
ListPlayerNextItemSet
,
ListPlayerStopped
,
DiscovererStarted
,
DiscovererEnded
,
PlayerTitleChanged
,
};
};
};
};
bindings/cil/src/marshal.cs
View file @
d9bc2eda
...
@@ -22,6 +22,8 @@
...
@@ -22,6 +22,8 @@
**********************************************************************/
**********************************************************************/
using
System
;
using
System
;
using
System.Collections
;
using
System.Collections.Generic
;
using
System.Runtime.InteropServices
;
using
System.Runtime.InteropServices
;
namespace
VideoLAN.LibVLC
namespace
VideoLAN.LibVLC
...
@@ -63,7 +65,6 @@ namespace VideoLAN.LibVLC
...
@@ -63,7 +65,6 @@ namespace VideoLAN.LibVLC
Destroy
();
Destroy
();
return
true
;
return
true
;
}
}
};
};
/**
/**
...
@@ -72,8 +73,7 @@ namespace VideoLAN.LibVLC
...
@@ -72,8 +73,7 @@ namespace VideoLAN.LibVLC
*
*
* This is the baseline for all managed LibVLC objects. It wraps:
* This is the baseline for all managed LibVLC objects. It wraps:
* - an unmanaged LibVLC pointer,
* - an unmanaged LibVLC pointer,
* - a native exception structure, and
* - a native exception structure.
* - the object's native event manager.
*/
*/
public
class
BaseObject
:
IDisposable
public
class
BaseObject
:
IDisposable
{
{
...
@@ -121,4 +121,123 @@ namespace VideoLAN.LibVLC
...
@@ -121,4 +121,123 @@ namespace VideoLAN.LibVLC
handle
=
null
;
handle
=
null
;
}
}
};
};
internal
class
EventManagerHandle
:
NonNullHandle
{
protected
override
void
Destroy
()
{
}
};
/**
* @brief EventingObject: wrapper around an eventing LibVLC handle.
* @ingroup Internals
*
* This is the base class for all managed LibVLC objects which do have an
* event manager.
*/
public
abstract
class
EventingObject
:
BaseObject
{
/**
* @brief Managed to unmanaged event handler mapping
* @ingroup Internals
*
* The CLR cannot do reference counting for unmanaged callbacks.
* We keep track of handled events here instead.
*/
private
class
Event
{
public
EventCallback
managed
;
public
IntPtr
unmanaged
;
public
Event
(
EventCallback
managed
,
IntPtr
unmanaged
)
{
this
.
managed
=
managed
;
this
.
unmanaged
=
unmanaged
;
}
};
private
Dictionary
<
EventType
,
Event
>
events
;
/**< references to our unmanaged function pointers */
internal
EventingObject
()
:
base
()
{
events
=
new
Dictionary
<
EventType
,
Event
>
();
}
/**
* Releases unmanaged resources associated with the object.
* @param disposing true if the disposing the object explicitly,
* false if finalizing the object inside the GC.
*/
protected
override
void
Dispose
(
bool
disposing
)
{
events
=
null
;
base
.
Dispose
(
disposing
);
}
/**
* @return the unmanaged event manager for this object
*/
internal
abstract
EventManagerHandle
GetManager
();
/**
* Registers an event handler.
* @param type event type to register to
* @param callback callback to invoke when the event occurs
*
* @note
* For simplicity, we only allow one handler per type.
* Multicasting can be implemented higher up with managed code.
*/
internal
void
Attach
(
EventType
type
,
EventCallback
callback
)
{
EventManagerHandle
manager
;
IntPtr
cb
=
Marshal
.
GetFunctionPointerForDelegate
(
callback
);
Event
ev
=
new
Event
(
callback
,
cb
);
bool
unref
=
false
;
if
(
events
.
ContainsKey
(
type
))
throw
new
ArgumentException
(
"Duplicate event"
);
try
{
handle
.
DangerousAddRef
(
ref
unref
);
manager
=
GetManager
();
LibVLC
.
EventAttach
(
manager
,
type
,
cb
,
IntPtr
.
Zero
,
ex
);
}
finally
{
if
(
unref
)
handle
.
DangerousRelease
();
}
Raise
();
events
.
Add
(
type
,
ev
);
}
private
void
Detach
(
EventType
type
,
IntPtr
callback
)
{
EventManagerHandle
manager
;
bool
unref
=
false
;
try
{
handle
.
DangerousAddRef
(
ref
unref
);
manager
=
GetManager
();
LibVLC
.
EventDetach
(
manager
,
type
,
callback
,
IntPtr
.
Zero
,
ex
);
}
finally
{
if
(
unref
)
handle
.
DangerousRelease
();
}
Raise
();
events
.
Remove
(
type
);
}
internal
void
Detach
(
EventType
type
)
{
Detach
(
type
,
events
[
type
].
unmanaged
);
}
};
};
};
bindings/cil/src/media.cs
View file @
d9bc2eda
...
@@ -65,7 +65,7 @@ namespace VideoLAN.LibVLC
...
@@ -65,7 +65,7 @@ namespace VideoLAN.LibVLC
* @ingroup API
* @ingroup API
* Each media object represents an input media, such as a file or an URL.
* Each media object represents an input media, such as a file or an URL.
*/
*/
public
class
Media
:
Base
Object
,
ICloneable
public
class
Media
:
Eventing
Object
,
ICloneable
{
{
internal
MediaHandle
Handle
internal
MediaHandle
Handle
{
{
...
@@ -154,6 +154,11 @@ namespace VideoLAN.LibVLC
...
@@ -154,6 +154,11 @@ namespace VideoLAN.LibVLC
}
}
}
}
internal
override
EventManagerHandle
GetManager
()
{
return
LibVLC
.
MediaEventManager
(
Handle
,
null
);
}
/**
/**
* Duration of the media in microseconds. The precision of the result
* Duration of the media in microseconds. The precision of the result
* depends on the input stram protocol and file format. The value
* depends on the input stram protocol and file format. The value
...
...
bindings/cil/src/player.cs
View file @
d9bc2eda
...
@@ -51,7 +51,7 @@ namespace VideoLAN.LibVLC
...
@@ -51,7 +51,7 @@ namespace VideoLAN.LibVLC
* @ingroup API
* @ingroup API
* Use this class to play a media.
* Use this class to play a media.
*/
*/
public
class
Player
:
Base
Object
public
class
Player
:
Eventing
Object
{
{
internal
PlayerHandle
Handle
internal
PlayerHandle
Handle
{
{
...
@@ -106,6 +106,11 @@ namespace VideoLAN.LibVLC
...
@@ -106,6 +106,11 @@ namespace VideoLAN.LibVLC
Raise
();
Raise
();
}
}
internal
override
EventManagerHandle
GetManager
()
{
return
LibVLC
.
PlayerEventManager
(
Handle
,
null
);
}
/**
/**
* Whether the player is currently active.
* Whether the player is currently active.
* @version VLC 1.0
* @version VLC 1.0
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment