在上文中還有不少bug,而且實現上拖泥帶水,最近好好看了下scrollview的api,下面是精鍊後的代碼,少了很多,而且精準。
用的時候只需要在相應的事件裡寫入下面的代碼就可以了。
第一種狀態(提示下拉可以更新部落格園新聞):
第二種狀態(提示下拉的幅度已夠可以釋放進入更新操作)
第三種狀態(提示正在更新,更新完畢回到第一個狀態)
private double actuableOffset, validStartOffset;
private bool mplStarted;
protected override void OnManipulationStarted(ManipulationStartedEventArgs e)
{
base.OnManipulationStarted(e);
mplStarted = true;
}
protected override void OnManipulationCompleted(ManipulationCompletedEventArgs e)
{
//150是下拉的距離可以自己調適
if (actuableOffset > 150 && scrollViewer.VerticalOffset == 0)
{
MessageBox.Show("Head pull bingo!");
}
if(actuableOffset<-150&&scrollViewer.VerticalOffset==scrollViewer.ScrollableHeight)
{
MessageBox.Show("Tail pull bingo!");
}
base.OnManipulationCompleted(e);
}
protected override void OnMouseMove(MouseEventArgs e)
{
//head capture startRelative
if ( scrollViewer.VerticalOffset == 0)
{
if (mplStarted)
{
mplStarted = false;
validStartOffset = e.GetPosition(null).Y;
}
actuableOffset = e.GetPosition(null).Y - validStartOffset;
}
//tail
if(scrollViewer.VerticalOffset==scrollViewer.ScrollableHeight)
{
if(mplStarted)
{
mplStarted = false;
validStartOffset = e.GetPosition(null).Y;
}
actuableOffset = e.GetPosition(null).Y - validStartOffset;
}
UIControlHelper.FindFirst<Pivot>().Title = actuableOffset;
base.OnMouseMove(e);
}