Windows Phone 8 中Pivot和Panorama控件手勢監聽的變化(用於引導頁)

http://www.cnblogs.com/wzk89/archive/2013/04/21/3034230.html


背景

在Windows Phone 7的時代,咱們能夠經過監聽ManipulationStarted、ManipulationDelta和ManipulationCompleted事件來判斷Pivot或者Panorama控件是向左滑動仍是向右滑動。html

例如:Windows Phone 7中,咱們經過監聽滑動手勢事件來控制Pivot控件中第一項不能向右滑動和最後一項不能向左滑動,如下具體實現方法:windows

   1:  protected override void OnManipulationCompleted(ManipulationCompletedEventArgs e)
   2:          {
   3:              this.pivot.IsHitTestVisible = true;
   4:          }
   5:          protected override void OnManipulationDelta(ManipulationDeltaEventArgs e)
   6:          {
   7:
   8:              if (this.pivot.SelectedIndex == 0)
   9:              {
  10:                  if (e.DeltaManipulation.Translation.X > 0)
  11:                  {
  12:                      e.Complete();
  13:                      this.pivot.IsHitTestVisible =false;
  14:                  }
  15:              }
  16:              if (this.pivot.SelectedIndex == 4)
  17:              {
  18:                  if (e.DeltaManipulation.Translation.X < 0)
  19:                  {
  20:                      e.Complete();
  21:                      this.pivot.IsHitTestVisible = true;
  22:                  }
  23:              }
  24:          }

前幾天我將該段代碼移植到Windows Phone 8項目中進行測試,發現沒有任何的效果。而後我就在這個三個事件上面加入斷點進行調試。ide

1

發現滑動Pivot控件的時候,只執行了ManipulationStarted事件,並無執行ManipulationDelta和ManipulationCompleted事件,很是的神奇學習

追蹤緣由

發現問題以後,我就開始追蹤緣由。測試

追蹤一:MSDN對Pivot的類庫說明文件;this

發現MSDN存在兩處對Pivot控件的使用說明網址:spa

Windows Phone 7中Pivot控件的解釋:點擊此處查看3d

2

Windows Phone 8中Pivot控件的解釋:點擊此處查看調試

3

經過對比繼承層次結構發現:orm

Windows Phone 7中Pivot控件是經過使用泛型參數的類派生自ItemsControl:

public class TemplatedItemsControl<T> : ItemsControl where T : System.Windows.FrameworkElement, new()

這代表ItemsControl由類型爲T的子元素填充,Pivot派生自TemplatedItemsControl,但類型參數設置爲PivotItem。

public class Pivot : TemplatedItemsControl<PivotItem>

Windows Phone 8中Pivot控件直接派生自ItemsControl:

public class Pivot : ItemsControl

可是僅僅從類層次結構上說明不了任何問題,無論在Windows Phone 7或者8中Pivot都會繼承自System.Windows.Controls.Control,也就說理論上都會監聽到三個手勢事件的。

追蹤二:Windows Phone 8對Pivot的說明中發現「新大陸」;

4

你們能夠點擊這裏查看詳細說明文檔。

同時針對於Windows Phone 8中對Panorama控件的解釋,點擊這裏查看詳細說明文檔;

8

經過該文檔,我發如今Windows Phone 8的Pivot控件和Panorama控件已經內置了拖動、輕拂或點擊等常見的手勢

結論

經過以上我追蹤問題產生的緣由,我得出的結論是:

Windows Phone 8中咱們在拖動Pivot控件或Panorama控件的時候,實際上是產生了Manipulation相關事件,可是被Pivot或Panorama內部封裝的手勢路由事件直接給攔截掉了,以致於咱們在ManipulationDelta和ManipulationCompleted事件中處理的任何自定義邏輯都不會被執行。

同時我進行了簡單的對比驗證

在一個Page中放置一個文本框控件和一個Pivot控件,而後在Page的cs文件中override一下OnManipulationStarted、OnManipulationDelta和OnManipulationCompleted三個事件。

我在拖動文本框控件的時候OnManipulationDelta和OnManipulationCompleted事件都會被執行,可是拖動Pivot控件兩個事件就不會執行,而OnManipulationStarted事件會被執行。

那麼咱們能夠在試一下,監聽PivotItem中某一個控件的ManipulationStarted、ManipulationDelta和ManipulationCompleted三個事件,一樣會發現ManipulationDelta和ManipulationCompleted中自定義的邏輯不會被執行。

所以我認爲Windows Phone 8中經過OnManipulationDelta和OnManipulationCompleted事件是沒法監聽Pivot控件的是向左仍是向右拖動。

同理我也對Windows Phone 8中Panorama控件使用一樣方式進行了測試,這裏我就不在過多解釋了,有興趣的同窗能夠試驗一下。

PS:若是你們有好的解決思路,但願提供給我,共同窗習一下

問題發散

你們確定都用過Windows Phone Toolkit,裏面有相關手勢監聽的Demo。經過對比Windows Phone 7和8的版本源代碼,會發現:

WP7版本中GestureSample.xaml頁面經過引用Toolkit封裝的手勢事件來對手勢監控。

5

而WP8版本中GestureSample.xaml頁面沒有引用以前的Toolkit封裝的手勢事件,而是迴歸到本質使用Windows Phone自帶的ManipulationStarted、ManipulationDelta和ManipulationCompleted三個事件來處理的。

6

7

另外Windows Phone 8中Pivot和Panorama控件都是進行了內置[爲了減小這兩個控件對系統內存的佔用率],同時Pivot控件增長了IsLocked屬性來控制是否鎖定了 pivot 控件。

以上針對Windows Phone 8中Pivot和Panorama控件滑動手勢的監聽試驗,我但願可以爲你們起到拋磚引玉的做用。

 

相關參考文章:

  1. Windows Phone 7中Pivot類說明文檔

  2. Windows Phone 8中Pivot類說明文檔

  3. Windows Phone Pivot 控件

  4. Windows Phone 8中Panorama類說名文檔

  5. Windows Phone 的全景控件

相關文章
相關標籤/搜索