Pet*_*uin 8 c# wpf xaml mediaelement progress-bar
在c#/ wpf中,我在窗口中添加了一个进度条和媒体元素.我们的想法是,进度条显示媒体元素的播放量.
我尝试使用以下xaml:
<Window x:Class="TestApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1" Height="627" Width="889">
<Grid>
<MediaElement Margin="152,8,140,41" Name="mediaElement1" MediaEnded="mediaElement1_MediaEnded" Visibility="Hidden" />
<ProgressBar Height="23" Margin="152,8,10,0" Name="mp3PlayingProgressBar" VerticalAlignment="Top" Foreground="DarkBlue" Maximum="{Binding Path=NaturalDuration.TimeSpan.TotalSeconds, Mode=OneWay, ElementName=mediaElement1}" Value="{Binding Path=Position.TotalSeconds, Mode=OneWay, ElementName=mediaElement1}" />
</Grid>
</Window>
Run Code Online (Sandbox Code Playgroud)
我试图将Maximum和Value属性绑定到mediaelement.但是当我将mp3加载到mediaelement时,进度条没有任何反应.(音乐正在播放,因此mp3已加载并正常播放).
我更喜欢用绑定来做这件事.
我在这做错了什么?
Rah*_*oni 10
这是因为Media未打开,因此进度条不知道最大值.试试这个...
对MediaOpened使用以下事件,对进度条或滑块使用MouseLeftButtonUp.我试过了,它运作得很好.
public partial class AudioPage : Page
{
TimeSpan _position;
DispatcherTimer _timer = new DispatcherTimer();
public AudioPage()
{
InitializeComponent();
_timer.Interval = TimeSpan.FromMilliseconds(1000);
_timer.Tick += new EventHandler(ticktock);
_timer.Start();
}
void ticktock(object sender, EventArgs e)
{
sliderSeek.Value = media.Position.TotalSeconds;
}
// Executes when the user navigates to this page.
protected override void OnNavigatedTo(NavigationEventArgs e)
{
}
private void Play_Click(object sender, RoutedEventArgs e)
{
media.Play();
}
private void Pause_Click(object sender, RoutedEventArgs e)
{
media.Pause();
}
private void Stop_Click(object sender, RoutedEventArgs e)
{
media.Stop();
}
private void media_MediaOpened(object sender, RoutedEventArgs e)
{
_position = media.NaturalDuration.TimeSpan;
sliderSeek.Minimum = 0;
sliderSeek.Maximum = _position.TotalSeconds;
}
private void sliderSeek_MouseLeftButtonUp(object sender, MouseButtonEventArgs e)
{
int pos = Convert.ToInt32(sliderSeek.Value);
media.Position = new TimeSpan(0, 0, 0, pos, 0);
}
}
Run Code Online (Sandbox Code Playgroud)
助理XAMl如下......
<Grid x:Name="LayoutRoot" Background="#FFFFE8E8">
<Grid.RowDefinitions>
<RowDefinition Height="220*" />
<RowDefinition Height="75*" />
</Grid.RowDefinitions>
<MediaElement Height="189" HorizontalAlignment="Left" Margin="12,12,0,0" Name="media" VerticalAlignment="Top" Width="399" Source="anyfile.mp3" AutoPlay="True" MediaOpened="media_MediaOpened" />
<StackPanel Orientation="Horizontal" Grid.Row="1" Height="30" Margin="12,8,163,37">
<TextBlock Text="Volume" VerticalAlignment="Center"></TextBlock>
<Slider Margin="2" Maximum="1" Minimum="0" Width="102" Value="{Binding Path=Volume, Mode=TwoWay, ElementName=media}"></Slider>
<TextBlock Text="{Binding ElementName=media, Path=Volume, Mode=OneWay, StringFormat=0.00}" VerticalAlignment="Center" />
</StackPanel>
<StackPanel Orientation="Horizontal" Grid.Row="1" Height="30" Margin="26,47,163,-2">
<TextBlock Text="Seek" VerticalAlignment="Center"></TextBlock>
<Slider Margin="2" Width="104" Name="sliderSeek" MouseLeftButtonUp="sliderSeek_MouseLeftButtonUp"></Slider>
<TextBlock Text="{Binding ElementName=sliderSeek, Path=Value, StringFormat=0}" VerticalAlignment="Center"></TextBlock>
</StackPanel>
<StackPanel Orientation="Horizontal" Grid.Row="1" Height="30" Margin="266,8,12,37">
<Button Name="Play" Content="Play" Margin="2" Click="Play_Click" />
<Button Name="Pause" Content="Pause" Margin="2" Click="Pause_Click" />
<Button Name="Stop" Content="Stop" Margin="2" Click="Stop_Click" />
</StackPanel>
</Grid>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
24690 次 |
最近记录: |