因为这两天比较忙,所以没有及时把要发表的东西写来.废话少说:我前面把两个简单的滚动说了下.接下来介绍第三种集合循环滚动.
2011-11-21 09:28
447 查看
下面我来说下集合滚动.在silverlght中没有html那样简单一句话就能实现循环滚动.既:marquee.
原始的例:<marquee onmouseover="stop()" onmouseout="start()" scrollamount="2" scrolldelay="1" height="22">
要循环的信息
</marquee>
我查阅了大量的文档和帮助,我确定自己写动画.在silverlight中没有像marquee那样简单的控件.只能自己拼:正面加上反面循环.
例子如下:因为这个是实际项目中的,下面的例子我简单的注释下,有写变量和注释写的不是很全.加上时间关系.如果有不明白的直接联系我,可查看相关文档.
或者直接来联系我:xuanrui.zhao@gmail.com
// 首先简单的描述下我做的这个功能:利用silverlight自带的动画标签:animation实现.在后台动态赋值两个集合,其实两个集合的值都是一样的就是
// 为了模拟marquee的循环.让其中一个集合在正面从上倒下,一个集合从下到上.实现滚动的假象.代码如下:
<Canvas x:Name="canMain" Background="Transparent" Cursor="Hand" >
<Canvas.Clip>
<!-- 定一个循环滚动的区域 -->
<RectangleGeometry x:Name="myRectangleGeometry" RadiusX="0" RadiusY="0" Rect="0,0, 340,50" />
</Canvas.Clip>
<Canvas.Triggers>
<EventTrigger RoutedEvent="Canvas.Loaded" >
<BeginStoryboard>
<!-- Canvas.Top :说明从下到上或者从上到下滚动 , RepeatBehavior="Forever" 为循环方式-->
<Storyboard x:Name="animation" Storyboard.TargetProperty="(Canvas.Top)" RepeatBehavior="Forever" >
<DoubleAnimation x:Name="daOne" Storyboard.TargetName="spScrollTwo" From="0" To="0" Duration="0:0:10" />
<DoubleAnimation x:Name="daTwo" Storyboard.TargetName="spScrollOne" From="0" To="0" Duration="0:0:10" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</Canvas.Triggers>
<StackPanel x:Name="spScrollOne" Orientation="Vertical"></StackPanel> >//要滚动的集合一
<StackPanel x:Name="spScrollTwo" Orientation="Vertical"></StackPanel>//要滚动的集合二
</Canvas>
// 这里我采用的是后台动态赋值:
public partial class testScroll: UserControl
{
// 信息条数
int icount = 0;
// 信息显示高度
Double iRoadInforMation = 0;
public testScroll()
{
InitializeComponent();
this.Loaded += new RoutedEventHandler(testScroll_Loaded);
}
#region 页面初始化方法
/// <summary>
/// 页面初始化方法
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void testScroll_Loaded(object sender, RoutedEventArgs e)
{
//动态获取数据
getDataInfor();
}
#endregion
#region 获得信息
/// <summary>
/// 获得信息
/// </summary>
private void getDataInfor()
{
...... ......... // 连接数据库
// 返回成功信息
if (r.IsSucceed)
{
// 定义实体类的集合
List<R_Infor> _Data_InforList = r.Body.FromJsonString<List<R_Infor>>();
// 判断返回查询结果
if (null != _Data_InforList && 0 < _Data_InforList .Count)
{
// 根据查询信息给页面赋值
foreach (var _Infor in_Data_InforList )
{
double _fontsize = 15;
++icount;
// 定义页面滚动显示信息容器
var tbInforOne = new TextBlock();
// 设定显示信息的样式信息
tbInforOne .Text = icount + ". " + _Infor .nayiyaou(); //描述内容
tbInforOne .Tag =Infor .ID();//内容ID
tbInforOne .FontSize = _fontsize;
tbInforOne .LineHeight = _fontsize;
tbInforOne .TextWrapping = TextWrapping.Wrap; //自动换行
tbInforOne .Margin = new Thickness(3, 4, 3, 3); //位置
tbInforOne .Width = (double)325; //显示宽度
spScrollOne.Children.Add(tbTraInforOne); //显示添加上前台控件
iRoadInforMation += (tbInforOne .ActualHeight + 7); //获得实际显示高度
// 定义页面滚动显示信息容器
var tbInforTwo = new TextBlock();
tbInforTwo .Text = icount + ". " + _Infor .nayiyaou(); //描述内容
tbInforTwo .Tag =Infor .ID();//内容ID
tbInforTwo .FontSize = _fontsize;
tbInforTwo .LineHeight = _fontsize;
tbInforTwo .TextWrapping = TextWrapping.Wrap; //自动换行
tbInforOne .Margin = new Thickness(3, 4, 3, 3); //位置
tbInforTwo .Width = (double)325; //显示宽度
spScrollTwo.Children.Add(tbTraInforTwo);
}
setScrolltt();
}
}
};
_Do.Post();
}
#endregion
#region 设置滚动信息
/// <summary>
/// 设置滚动信息
/// </summary>
private void setScrolltt()
{
iRoadInforMation = iRoadInforMation + 10;
myRectangleGeometry.Rect = new Rect(0, 0, 340, iRoadInforMation);
// 控制滚动信息速度
int _marqueeTimeInSeconds = Convert.ToInt32(icount * 1.5);
spScrollOne.Height = iRoadInforMation;
spScrollTwo.Height = iRoadInforMation;
daOne.To = -iRoadInforMation;
daOne.Duration = new Duration(TimeSpan.FromSeconds(_marqueeTimeInSeconds));
daTwo.From = iRoadInforMation;
daTwo.Duration = new Duration(TimeSpan.FromSeconds(_marqueeTimeInSeconds));
}
#endregion
//这个功能困扰了我一天.希望有很多和我一样需要这个功能的朋友和大家分享下.
原始的例:<marquee onmouseover="stop()" onmouseout="start()" scrollamount="2" scrolldelay="1" height="22">
要循环的信息
</marquee>
我查阅了大量的文档和帮助,我确定自己写动画.在silverlight中没有像marquee那样简单的控件.只能自己拼:正面加上反面循环.
例子如下:因为这个是实际项目中的,下面的例子我简单的注释下,有写变量和注释写的不是很全.加上时间关系.如果有不明白的直接联系我,可查看相关文档.
或者直接来联系我:xuanrui.zhao@gmail.com
// 首先简单的描述下我做的这个功能:利用silverlight自带的动画标签:animation实现.在后台动态赋值两个集合,其实两个集合的值都是一样的就是
// 为了模拟marquee的循环.让其中一个集合在正面从上倒下,一个集合从下到上.实现滚动的假象.代码如下:
<Canvas x:Name="canMain" Background="Transparent" Cursor="Hand" >
<Canvas.Clip>
<!-- 定一个循环滚动的区域 -->
<RectangleGeometry x:Name="myRectangleGeometry" RadiusX="0" RadiusY="0" Rect="0,0, 340,50" />
</Canvas.Clip>
<Canvas.Triggers>
<EventTrigger RoutedEvent="Canvas.Loaded" >
<BeginStoryboard>
<!-- Canvas.Top :说明从下到上或者从上到下滚动 , RepeatBehavior="Forever" 为循环方式-->
<Storyboard x:Name="animation" Storyboard.TargetProperty="(Canvas.Top)" RepeatBehavior="Forever" >
<DoubleAnimation x:Name="daOne" Storyboard.TargetName="spScrollTwo" From="0" To="0" Duration="0:0:10" />
<DoubleAnimation x:Name="daTwo" Storyboard.TargetName="spScrollOne" From="0" To="0" Duration="0:0:10" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</Canvas.Triggers>
<StackPanel x:Name="spScrollOne" Orientation="Vertical"></StackPanel> >//要滚动的集合一
<StackPanel x:Name="spScrollTwo" Orientation="Vertical"></StackPanel>//要滚动的集合二
</Canvas>
// 这里我采用的是后台动态赋值:
public partial class testScroll: UserControl
{
// 信息条数
int icount = 0;
// 信息显示高度
Double iRoadInforMation = 0;
public testScroll()
{
InitializeComponent();
this.Loaded += new RoutedEventHandler(testScroll_Loaded);
}
#region 页面初始化方法
/// <summary>
/// 页面初始化方法
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void testScroll_Loaded(object sender, RoutedEventArgs e)
{
//动态获取数据
getDataInfor();
}
#endregion
#region 获得信息
/// <summary>
/// 获得信息
/// </summary>
private void getDataInfor()
{
...... ......... // 连接数据库
// 返回成功信息
if (r.IsSucceed)
{
// 定义实体类的集合
List<R_Infor> _Data_InforList = r.Body.FromJsonString<List<R_Infor>>();
// 判断返回查询结果
if (null != _Data_InforList && 0 < _Data_InforList .Count)
{
// 根据查询信息给页面赋值
foreach (var _Infor in_Data_InforList )
{
double _fontsize = 15;
++icount;
// 定义页面滚动显示信息容器
var tbInforOne = new TextBlock();
// 设定显示信息的样式信息
tbInforOne .Text = icount + ". " + _Infor .nayiyaou(); //描述内容
tbInforOne .Tag =Infor .ID();//内容ID
tbInforOne .FontSize = _fontsize;
tbInforOne .LineHeight = _fontsize;
tbInforOne .TextWrapping = TextWrapping.Wrap; //自动换行
tbInforOne .Margin = new Thickness(3, 4, 3, 3); //位置
tbInforOne .Width = (double)325; //显示宽度
spScrollOne.Children.Add(tbTraInforOne); //显示添加上前台控件
iRoadInforMation += (tbInforOne .ActualHeight + 7); //获得实际显示高度
// 定义页面滚动显示信息容器
var tbInforTwo = new TextBlock();
tbInforTwo .Text = icount + ". " + _Infor .nayiyaou(); //描述内容
tbInforTwo .Tag =Infor .ID();//内容ID
tbInforTwo .FontSize = _fontsize;
tbInforTwo .LineHeight = _fontsize;
tbInforTwo .TextWrapping = TextWrapping.Wrap; //自动换行
tbInforOne .Margin = new Thickness(3, 4, 3, 3); //位置
tbInforTwo .Width = (double)325; //显示宽度
spScrollTwo.Children.Add(tbTraInforTwo);
}
setScrolltt();
}
}
};
_Do.Post();
}
#endregion
#region 设置滚动信息
/// <summary>
/// 设置滚动信息
/// </summary>
private void setScrolltt()
{
iRoadInforMation = iRoadInforMation + 10;
myRectangleGeometry.Rect = new Rect(0, 0, 340, iRoadInforMation);
// 控制滚动信息速度
int _marqueeTimeInSeconds = Convert.ToInt32(icount * 1.5);
spScrollOne.Height = iRoadInforMation;
spScrollTwo.Height = iRoadInforMation;
daOne.To = -iRoadInforMation;
daOne.Duration = new Duration(TimeSpan.FromSeconds(_marqueeTimeInSeconds));
daTwo.From = iRoadInforMation;
daTwo.Duration = new Duration(TimeSpan.FromSeconds(_marqueeTimeInSeconds));
}
#endregion
//这个功能困扰了我一天.希望有很多和我一样需要这个功能的朋友和大家分享下.
相关文章推荐
- 增强for循环和迭代对集合操作的简单比较
- hdu 1087Super Jumping! Jumping! Jumping!(简单的dp就是一个判断条件两个for循环,将这个量与前面出现的两进行比较)
- 书到用时方恨少 做项目的时候才知道自己懂的东西少了,有时候会因为无知,导致比较重的后果。所以平时不断地学习,看论文啊,或者看别人的设计方案了
- 银联支付也是一般比较常用的支付功能,这里简单了介绍android app如果短期快速应用这一方面的东西
- iconfont字体图标的使用方法--超简单! 我之前因为项目用bootstrap比较多,所以使用font awesome字体图标比较多,后来接触到了iconfont,发现想要的什么图标都有,还可以
- 仿淘宝首页的淘宝头条垂直滚动,因为循环滚动的是布局,所以很多向上的情况都可以用,可以先收藏起。
- 关于微软软件的操作系统在中国公司的比较性能测试-后果有很多后门木马因为微软没有打开系统的两个功能
- 关于oracle with as用法(比较简单的介绍)
- 两个集合合并成并去重的简单方法
- 因为生活简单,所以内心强大
- MyBatis多数据源配置实现读写分离 发表于 2017-09-29 | 分类于 Database | 常见的数据库连接池有C3P0、DBCP和阿里巴巴的druid,后两个在实际场景中用的比较多
- 2008年7月21号,晴,今天是我读博士的第15天,上星期六和星期天,我没有记录自己,因为我得太太从九江来到了武汉,两天的时间,我好好的陪了她两天
- 看看一个朋友写的代码,大家发表发表意见,比较简单的代码
- 各大电子商务网站的站内搜索比较,因为要做站内搜索,所以前去观摩下
- Xcode编译生成ipa文件(因为两种证书所以打两个ipa)
- 两个实用的强大linux命令介绍,vim比较, tar备份权限
- 介绍简单实用APP动画效果的两个关键
- java比较两个字符串完全不同处高亮显示(过滤了某些字符串前面不不相干字符)
- 这两天有事偷懒了啊,,总结下简单学的东西
- 对比两个同类型的泛型集合并返回差异泛型集合 ——两个List<类名>的比较