轉(zhuǎn)帖|其它|編輯:郝浩|2011-03-10 13:40:02.000|閱讀 1194 次
概述:定時器(Timer)是一個挺常見的功能。通過使用定時器, 可以每隔一段制定的時間后觸發(fā)某一指定的事件,如刷新、定時提醒等等。那在Silverlight中怎么使用定時器呢?其實也很簡單,且聽我細(xì)細(xì)道來。:)
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
定時器(Timer)是一個挺常見的功能。通過使用定時器, 可以每隔一段制定的時間后觸發(fā)某一指定的事件,如刷新、定時提醒等等。那在Silverlight中怎么使用定時器呢?其實也很簡單,且聽我細(xì)細(xì)道來。
HtmlTimer類和Storyboard
這是最簡單的實現(xiàn)定時器的方式。你可以在你的程序中直接使用HtmlTimer類,它位于System.Windows.Browser命名空間下,使用之前你需要在工程中先加入對System.Silverlight.dll的引用。它的使用方法很簡單:
HtmlTimer timer = new HtmlTimer();
timer.Interval = 200; //200毫秒
timer.Tick += new EventHandler(timer_Tick);
timer.Start();
void timer_Tick(object sender, EventArgs e)
{
//在這里處理定時器事件
}
但是很不幸,這個類被標(biāo)記為obsolete,編譯的時候會報一個warning,就是說今后的正式版本可能會移除對這個類的支持,因為這個定 時器的精度不高,并不適合于間隔很短的動畫。那么為了保證我們現(xiàn)在寫的代碼能夠平穩(wěn)的過渡到Silverlight1.1的正式版本,我們可以使用 Storyboard來實現(xiàn)定時器的功能
大家可能利用Blend創(chuàng)建過動畫,實際上你創(chuàng)建的動畫在XAML文件中對應(yīng)了Storyboard這個對象,因此我們可以利用它提供的Completed事件(動畫結(jié)束之后觸發(fā))來模擬定時器。
首先在Page.xaml文件中添加一個Storyboard的資源:
<Canvas.Resources>
<Storyboard x:Name="timer" Completed="timer_Tick" />
</Canvas.Resources>
然后在代碼中設(shè)置定時器的間隔,并開啟動畫,然后在Completed中重新開始Storyboard就可以模擬定時器的行為了:
timer.Duration = new TimeSpan(0, 0, 0, 0, 200); //200毫秒 timer.Begin();
void timer_Tick(object sender, EventArgs e)
{
//在這里處理定時器事件
timer.Begin();
}
定時器控件
現(xiàn)在大家可能已經(jīng)知道如何用Storyboard來實現(xiàn)定時器的功能了,我們可以把它包裝成一個控件,這樣以后我們就可以很方便的在程序中使用定時器了。
為了方便從Xaml文件創(chuàng)建控件,我們先定義一個基類
public class XamlControl : Control
{
private readonly FrameworkElement m_Container;
protected FrameworkElement Container
{
get { return m_Container; }
}
protected XamlControl(string xamlName)
{
Stream stream =
GetType().Assembly.GetManifestResourceStream(xamlName);
if (stream == null)
{
throw new ArgumentException
("Xaml resource " + xamlName + " not present", "xamlName");
}
using (StreamReader sr = new StreamReader(stream))
{
string xamlData = sr.ReadToEnd();
m_Container = base.InitializeFromXaml(xamlData);
}
}
}
然后我們在工程中添加一個xaml文件,在Properties面板-Advanced-Build Action中選擇”Embedded Resource”,這樣我們就可以在代碼里動態(tài)的加載這個xaml文件了。文件的內(nèi)容如下
<Canvas
xmlns="//schemas.microsoft.com/client/2007"
xmlns:x="//schemas.microsoft.com/winfx/2006/xaml"
>
<Canvas.Triggers>
<EventTrigger RoutedEvent="Canvas.Loaded">
<EventTrigger.Actions>
<BeginStoryboard>
<Storyboard x:Name='timer'>
</Storyboard>
</BeginStoryboard>
</EventTrigger.Actions>
</EventTrigger>
</Canvas.Triggers>
</Canvas>
下面是定時器控件的代碼(需要將下面的SilverlightControl改成你自己建立的工程的名稱):
public class Timer : XamlControl
{
private Storyboard m_Timer;
public Timer()
: base("SilverlightControl.Timer.xaml")
{
if (Container == null) return;
m_Timer = Container.FindName("timer") as Storyboard;
m_Timer.Completed += OnComplete;
}
public TimeSpan Interval
{
get
{
return m_Timer.Duration.TimeSpan;
}
set
{
m_Timer.Duration = new Duration(value);
}
}
public event EventHandler<EventArgs> Tick;
private void FireTick()
{
Tick(this, new EventArgs());
}
private void OnComplete(object sender, EventArgs e)
{
FireTick();
m_Timer.Begin();
}
}
這樣我們就可以用類似于HtmlTimer的語法,很方便的操作定時器控件了
Timer timer = new Timer();
timer.Interval = new TimeSpan(0, 0, 0, 0, 200);
timer.Tick += timer_tick;
Children.Add(timer); //開始計時
如果要停止計時,只需要用Children.Remove(timer)即可
一點需要注意的地方,當(dāng)你調(diào)用Storyboard.Begin的時候,如果這個Storyboard還沒有被加入Xaml的DOM樹中,如下 圖中右下角的紅色節(jié)點所示,那么這時Silverlight會拋出異常。這在你將Storyboard內(nèi)嵌在自定義控件里的時候要特別小心,如果你的控件 不在當(dāng)前Xaml的DOM樹中,而你調(diào)用了這個控件內(nèi)包含的Storyboard的Begin方法或者Stop方法,都會產(chǎn)生異常。
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:網(wǎng)絡(luò)轉(zhuǎn)載