This control library adds support for LibVLC MediaPlayer for Avalonia Desktop applications.
Add a namespace for the library to your .axaml files:
xmlns:media="using:Iciclecreek.Avalonia.Controls.Media"
<media:VideoView Source={Binding Url}>
<media:MediaPlayerControls/>
</media:VideoView>
In this case a MediaPlayerControls element is external to the video player window (aka, not overlayed), but data bound to the MediaPlayerViewModel for the VideoView.
<media:VideoView Name="Player" Source={Binding Url} />
<media:MediaPlayerControls DataContext={Binding #Player.MediaPlayerViewModel}"/>
Here is an example which shows how you can create your own command bindings using the MediaPlayerViewModel
<media:VideoView Name="Player" Source={Binding Url} >
<StackPanel Orientation="Horizontal" Background="Lavender">
<Button Command="{Binding Play}">Play</Button>
<Slider Value="{Binding Time}" Maximum="{Binding Length}" Width="200"/>
<Button Command="{Binding Stop}">Stop</Button>
</StackPanel>
</media:VideoView>
The main class driving this is a view model which is set up to support Commands and Property notification to make it easy to data bind UI to the state of the MediaPlayer in the VideoView control. All of the Commands implement CanXXX() so that they are enabled/disabled automatically when bound as a Command.
Command | Parameters | Description |
---|---|---|
Play | - | Play video |
Stop | - | Stop Video - Play starts video over |
Pause | - | Pause video - Play resumes |
Mute | - | Mutes video |
Unmute | - | Unmutes video |
TogglePlayPause | - | Toggles Play/Pause for video |
ToggleMute | - | Toggles Mute state |
SetRate | float | Changes rate of playback (for example "1.75" => 1.75x faster than noraml) |
Download | Open video external |
The MediaPlayerViewModel also exposes the state of the MediaPlayer so you can bind your UI to the properties and it will update in real time to changes (aka appropriate property notification).
Property | Type | Description |
---|---|---|
IsMuted | bool | Mute state |
IsCloseCaptioned | bool | Closed Caption state |
Volume | int | volume for the video playback |
IsSeekable | bool | Seekable state |
Time | int | Current playback position in ms. Changing this changes playback position, so Slider control bound to this controls playback position of the video. |
Length | int | Length of the video in ms. |
Rate | float | Playback speed. |
This library contains a fork of the unofficial VideoView with overlay support. The changes are
This is a prebuilt element which looks like this:
It has not been tested at all with Android/iOS