豆瓣电台WP7客户端 开发记录7

2022-05-07 16:07:44 浏览数 (1)

由于歌曲名称可能超过屏幕宽度而显示不下,所以当歌曲名称长度大于屏幕宽度的时候滚动显示。

 这里主要用storyboard来完成,主要是silverlight的知识了。

代码语言:javascript复制
  1  <Canvas>
2                     <Canvas.Resources>
 3                         <Storyboard x:Name="sb">
 4                             <DoubleAnimation x:Name="animation"
 5                             Storyboard.TargetProperty="(Canvas.Left)"
 6                             Storyboard.TargetName="SongName"
 7                             Duration="0:0:9"
 8                             RepeatBehavior="Forever" />
 9                         </Storyboard>
10                     </Canvas.Resources>
11                 <TextBlock  x:Name="SongName" FontSize="24"   HorizontalAlignment="Center" Margin="0,15,0,0" />
12  </Canvas> 
代码语言:javascript复制
cs: 1  /// <summary>
代码语言:javascript复制
2         /// 歌曲名称滚动
 3         /// </summary>
 4         private void SongNameMarquee()
 5         {
 6             this.sb.Stop();
 7             double sysWidth = System.Windows.Application.Current.Host.Content.ActualWidth;//屏幕宽度
 8             if (sysWidth <= this.SongName.ActualWidth)
 9             {
10                 animation.From = sysWidth;
11                 animation.To = -this.SongName.ActualWidth - (sysWidth - 360) / 2;//360为Canvas宽度
12                 this.sb.Begin();
13             }
14             else
15             {//canvas居中
16                 this.SongName.SetValue(Canvas.LeftProperty, 180-this.SongName.ActualWidth/2);
17             }
18 
19         }

 主要是计算几个点麻烦点 其他没什么。

0 人点赞