[更新]Windows Phone 實現類似“微博”下拉刷新效果


上文中還有不少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);
        }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM