UWP開發入門(七)——下拉刷新

来源:http://www.cnblogs.com/manupstairs/archive/2016/02/06/5184386.html
-Advertisement-
Play Games

本篇意在給這幾天Win10 Mobile負面新聞不斷的某軟洗地,想要證明實現一個簡單的下拉刷新並不困難。UWP開發更大的困難在於懶惰,缺乏學習的意願。而不是“某軟連下拉刷新控制項都沒有”這樣的想法。 之前我也沒有進行過下拉刷新的研究。於是先去google了幾篇blog學習了一下,然後再看了某軟官方的S


  本篇意在給這幾天Win10 Mobile負面新聞不斷的某軟洗地,想要證明實現一個簡單的下拉刷新並不困難。UWP開發更大的困難在於懶惰,缺乏學習的意願。而不是“某軟連下拉刷新控制項都沒有”這樣的想法。

  之前我也沒有進行過下拉刷新的研究。於是先去google了幾篇blog學習了一下,然後再看了某軟官方的Sample。(同學們啊官方有下拉刷新的Sample啊!就在Git上啊!不要錢無門檻啊!)學習之後發現實現的方式大體分為兩類。

  一類是以某軟Sample和博客園MS-UAP封裝的PullToRefreshBox為代表,將一片“釋放刷新”區域和一個ListView上下排列放置到一個ScrollView中。初始通過向下滾動ScrollView將“釋放刷新”區域上移至不可見,在每次向上滾動顯示“釋放刷新”區域時,觸發ScrollViewViewChanged事件來進行載入新數據。完成新數據載入後,再次將“釋放刷新”區域上移隱藏。

  另一類是通過附加屬性來獲取ListView內部的ScrollView,並檢測內部ScrollView的相關Manpulation事件來實現數據刷新。

  考慮到附加屬性稍稍超出入門範圍,且第一類代碼可以寫得較為簡單。故採用ScrollView嵌套的方法,給出一個極簡的下拉刷新實現,雖並不能應對所有的需求,但考慮到30行不到的代碼量,絕對你值得擁有!

  首先是XAML的代碼,平淡無奇沒有任何高深的技巧:

    <Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
        
        <ScrollViewer x:Name="scrollViewer"
                     Loaded="scrollViewer_Loaded"
                      ViewChanged="scrollViewer_ViewChanged">

            <StackPanel Orientation="Vertical">
                <ProgressRing IsActive="{x:Bind IsPullRefresh,Mode=OneWay}" Height="30"></ProgressRing>
                <ListView x:Name="list" ItemsSource="{x:Bind Items}" ></ListView>
            </StackPanel>
            
        </ScrollViewer>
    </Grid>

  再來看cs文件。首先是ItemsIsPullRefresh屬性的定義,前者是ListView中的數據集,後者BindingProgressRingIsActive屬性,這裡略過不表。

  值得註意的僅有scrollViewer_LoadedscrollViewer_ViewChanged兩個方法。scrollViewerLoad方法里,我們在初始狀態下將ScrollViewer向上滾動了30px,正好將ProgressRing隱藏了起來。然後是scrollViewer_ViewChanged方法,IsIntermediate屬性指出滑動是否還在進行中,如果不是並且到達頂部了,就去載入新的數據,同時控制ProgressRing的菊花轉圈圈。最後,再將ScrollViewer向上滾動30px藏起ProgressRing

    public sealed partial class MainPage : Page, INotifyPropertyChanged
    {
        public ObservableCollection<object> Items { get; set; }

        public bool IsPullRefresh
        {
            get
            {
                return _isPullRefresh;
            }

            set
            {
                _isPullRefresh = value;
                OnPropertyChanged(nameof(IsPullRefresh));
            }
        }

        bool _isPullRefresh = false;

        public MainPage()
        {
            this.InitializeComponent();

            Items = new ObservableCollection<object>();
            for (int i = 0; i < 40; i++)
            {
                Items.Add(i);
            }
        }

        public event PropertyChangedEventHandler PropertyChanged;

        public void OnPropertyChanged(string name)
        {
            this.PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));
        }

        private void scrollViewer_Loaded(object sender, RoutedEventArgs e)
        {
            scrollViewer.ChangeView(null, 30, null);
        }

        private async void scrollViewer_ViewChanged(object sender, ScrollViewerViewChangedEventArgs e)
        {
            var sv = sender as ScrollViewer;

            if (!e.IsIntermediate)
            {
                if (sv.VerticalOffset == 0.0)
                {
                    IsPullRefresh = true;
                    await Task.Delay(2000);
                    for (int i = 0; i < 5; i++)
                    {
                        Items.Insert(0, i);
                    }
                    sv.ChangeView(null, 30, null);
                }
                IsPullRefresh = false;
            }
        }
    }

  打完收工,是不是覺得挺簡單的?UWP開發即是如此,困難確實有,經驗的確沒有。跟相對成熟的iOSAndroid開發相比,是需要更多的汗水和努力。但是微軟是否要倒了?微軟技術又是否沒前途?Windows 10是否廢品?有空在網上搜這種沒有卵用的東西,不如多多學習。

  繼續打廣告,這種ScrollViewer嵌套ListView的方式呢,確實可以解決問題。但偶爾也會發現和ListView控制項自身的ScrollViewer滑動衝突,以及不能精確定位ListViewItem等問題。那麼如果想要更加精進的話?記得看俺下一篇哦,隨手點個贊吧……嘿嘿嘿……

Microsoft/Windows-universal-samples


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • css針對各個瀏覽器的首碼是什麼:現在寫css3代碼的時候,為了實現相容性,需要在前面加首碼以便相容對應的瀏覽器。下麵就列舉一下首碼的寫法: -webkit//Webkit內核,例如谷歌和Safari瀏覽器 -moz//Gecko內核,例如火狐瀏覽器 -o//Presto內核,例如Opera瀏覽器
  • JavaScript構成簡介: 互聯網的出現,極大的促進了信息的交流,隨著步伐的前進,網站的交互需求越來越多,但是受限於當時的軟硬體條件,特別是網路環境的限制,非常簡單的表單驗證都要花費大量的時間在伺服器與客戶端之間進行傳輸,為此網景公司推出了最初的LiveScript語言,後來改名為JavaScr
  • altKey屬性的定義和用法:此屬性返回一個布爾值。指示在指定的事件發生時,Alt鍵是否被按下並保持住了。更多相關內容可以參閱javascript的event對象一章節。語法結構: event.altKey=true|false|1|0 瀏覽器支持:1.IE瀏覽器支持此屬性。2.火狐瀏覽器支持此屬性
  • [1]單選按鈕 [2]多選按鈕 [3]下拉列表
  • 在當今這個多種不同資料庫混用,各種不同語言不同框架融合的年代(一切為了降低成本並高效的提供服務),知識點多如牛毛。雖然大部分SQL腳本可以使用標準SQL來寫,但在實際中,效率就是一切,因而每種不同廠商的SQL新特性有時還是會用到,這部分內容更是讓人抓瞎,常常會由於一些很簡單的問題花很久來搜索準確答案
  • 分類:C#、Android、VS2015; 創建日期:2016-02-07 一、簡介 圖庫(也叫畫廊)是一個佈局小部件,用於在可水平滾動的列表中顯示每一副圖片,當前所選的圖片將置於視圖的中心。 註意:Android已經棄用了這個小部件,棄用的原因是用Galery實現的效率比較低,官方的建議是改為用H...
  • 分類:C#、Android、VS2015; 創建日期:2016-02-07 一、簡介 1、CheckBox 覆選 【Checked】屬性:是否選中。 2、RadioButton 單選 【Checked】屬性:是否選中。 【RadioGroup】屬性:RadioButton的分組容器。註意必須將Rad...
  • 分類:C#、Android、VS2015; 創建日期:2016-02-07 一、簡介 1、Button 常規按鈕。 2、TextView 文本視圖,其功能和WPF的TextBlock控制項類似,【工具箱】中提供的3個組件實際上是同一個TextView控制項用不同的屬性來區分的,這3個不同的屬性在【工具箱...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...