• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 55  文章 - 15  trackbacks - 0
            <2012年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

                     前文再續,本章介紹如何創建一個C++版本的Variable Sized Gridview,這里有兩種方法,一種是用微軟的Template,還有另一種方法,簡單些。本章先介紹微軟的方法。
                     其實C#版本微軟已經實現了,大家可以在VS2012上面去找找,方法是:新建-〉Online-〉Templates-〉Visual C#,右邊選項欄里面就有這個Variable Sized Grid Template了,創建之后,部署,運行,你就可以得到一個類似于Windows Store 的Ui,下面看兩張圖吧,我們講究有圖有真相。

             1. 找到這個Template:




            2. 運行效果:



                  這個Template中的代碼我感覺有點繞圈圈,不知道它為什么這么做,但是可以實現這種效果,我會試著來講解一下代碼的具體意思。
                  先把代碼帖出來:
             1 public ref class VariableGridView sealed : public Windows::UI::Xaml::Controls::GridView
             2         {
             3         public:
             4             property  Platform::String^ ItemRowSpanPropertyPath
             5             {
             6                 Platform::String^ get()
             7                 {
             8                     return safe_cast<Platform::String^>(GetValue(ItemRowSpanPropertyPathProperty));
             9                 }
            10                 void set(Platform::String^ value)
            11                 {
            12                     SetValue(ItemRowSpanPropertyPathProperty, value);
            13                 }
            14             }
            15             static property Windows::UI::Xaml::DependencyProperty^ ItemRowSpanPropertyPathProperty
            16             {
            17                 Windows::UI::Xaml::DependencyProperty^ get();
            18             }
            19 
            20 
            21 
            22             property  Platform::String^ ItemColSpanPropertyPath
            23             {
            24                 Platform::String^ get()
            25                 {
            26                     return safe_cast<Platform::String^>(GetValue(ItemColSpanPropertyPathProperty));
            27                 }
            28                 void set(Platform::String^ value)
            29                 {
            30                     SetValue(ItemColSpanPropertyPathProperty, value);
            31                 }
            32             }
            33             static property Windows::UI::Xaml::DependencyProperty^ ItemColSpanPropertyPathProperty
            34             {
            35                 Windows::UI::Xaml::DependencyProperty^ get();
            36             }
            37         protected:
            38             virtual void PrepareContainerForItemOverride(Windows::UI::Xaml::DependencyObject^ element, Platform::Object^ item) override;
            39         private:
            40             static Windows::UI::Xaml::DependencyProperty^ _itemRowSpanPropertyPathProperty;
            41             static Windows::UI::Xaml::DependencyProperty^ _itemColSpanPropertyPathProperty;
            42 
            43         };

            這里有幾個概念,今天先說一下Dependecy Property 這個東西吧,其他的下次繼續:
                  1. 我現在接觸到的Dependency Property,就是依賴屬性,主要用來進行數據綁定。我們知道WinRT一個比較重要的功能就是數據的綁定,而綁定的目標(target)屬性必須為依賴屬性屬性,而源(source)則沒有要求,你可以是依賴屬性,也可以不是依賴屬性。這部分內容我在MVVM那一張已經翻譯過了。源和目標都是依賴屬性的好處是,在binding的時候WinRT會自動地幫你做一些事情,這樣源屬性改變,目標屬性會立即改變。如果源屬性不是依賴屬性,那么,包含該屬性的類必須實現 INotifyPropertyChanged 這個借口,不然,就不行了。
                  2. 依賴屬性的定義有一套的流程。首先,我們看代碼中,在私有域:需要有一個靜態的DependencyProperty 變量,在公共域:需要一個對應的靜態DependencyProperty屬性。注意,一個是變量,一個是屬性,公共域的要有一個Property關鍵字。私有域的這個變量作為公共域屬性的back store。
                      另外,為了方便存取,還需要一個額外的屬性來獲得這個依賴屬性。注意到:DependecyProperty 屬性只有get()方法,相關屬性的set()、get()方法中分別調用SetValue(),GetValue(),方法。
                     頭文件中就需要這些東西,還沒有結束,聲明完依賴屬性,我們還需要注冊,讓WinRT這個綁定系統知道有這么一個類,有這樣一個依賴屬性。注冊的代碼如下:
            1 DependencyProperty^ VariableGridView::_itemColSpanPropertyPathProperty = 
            2     DependencyProperty::Register("ItemColSpanPropertyPath", TypeName(String::typeid), TypeName(VariableGridView::typeid),
            3     ref new PropertyMetadata(nullptr));
                     注冊完,這個類就有了一個依賴屬性了。
                    不錯,現在我們實現了這個類的一半了,為了達到可變尺寸的GridView,還有另一個重載方法是必不可少的。不過我打算明天再跟大家分享了,今天要早點回家做飯啦。哈哈。先把代碼貼上,C++的代碼跟C#很類似,
               
             1 void VariableGridView::PrepareContainerForItemOverride(DependencyObject^ element, Platform::Object^ item)
             2 {
             3     GridView::PrepareContainerForItemOverride(element, item);
             4     auto viewMode = (Data::DataItem^)(item);
             5     UIElement^ uiElement = safe_cast<UIElement^>(element);
             6 
             7     Binding^ colBinding = ref new Binding();
             8     colBinding->Source = viewMode;
             9     colBinding->Path = ref new PropertyPath(this->ItemColSpanPropertyPath);
            10     BindingOperations::SetBinding(uiElement,VariableSizedWrapGrid::ColumnSpanProperty, colBinding);
            11     
            12 
            13     Binding^ rowBinding = ref new Binding();
            14     rowBinding->Source = viewMode;
            15     rowBinding->Path = ref new PropertyPath(this->ItemRowSpanPropertyPath);
            16     BindingOperations::SetBinding(uiElement,VariableSizedWrapGrid::RowSpanProperty, rowBinding);    
            17 }
                  

            下期預告:即使完成了上面的兩步,其實還沒有完全實現VariableSized GridView,還需要在XAML文件中進行相應的修改,下期將介紹其余的部分。
            posted on 2012-10-12 17:19 Dino-Tech 閱讀(1316) 評論(1)  編輯 收藏 引用

            FeedBack:
            # re: Window 8 學習筆記(三)-- 如何創建一個可變尺寸的GridView  2013-09-23 16:35 墮落1990
            樓主能提供完整的源碼么,想系統學習下,謝謝啦,  回復  更多評論
              
            精品综合久久久久久888蜜芽| 欧美黑人激情性久久| 久久精品一本到99热免费| 久久精品人人做人人爽电影| 欧美粉嫩小泬久久久久久久 | 久久久久成人精品无码中文字幕| 久久综合鬼色88久久精品综合自在自线噜噜 | 国产精品久久毛片完整版| 一本伊大人香蕉久久网手机| 久久人人爽人人爽人人片AV麻烦 | 无码专区久久综合久中文字幕 | 国产 亚洲 欧美 另类 久久| 国产一区二区三区久久| 亚洲国产精品久久久久婷婷软件 | 久久精品国产免费一区| 久久精品国产一区| 93精91精品国产综合久久香蕉| 99久久精品免费国产大片| 国产激情久久久久影院老熟女免费| 一级做a爱片久久毛片| 久久久精品人妻无码专区不卡| 久久影院亚洲一区| 精产国品久久一二三产区区别 | 精品国产福利久久久| 香港aa三级久久三级| 人人狠狠综合88综合久久| 久久九九兔免费精品6| 久久亚洲精品无码AV红樱桃| 91精品国产色综合久久| 色综合久久精品中文字幕首页| 久久黄视频| 无码专区久久综合久中文字幕| 久久免费线看线看| 亚洲国产婷婷香蕉久久久久久| 亚洲国产欧美国产综合久久| 久久久久一区二区三区| 性高朝久久久久久久久久| 久久综合精品国产二区无码| 精品欧美一区二区三区久久久| 久久精品青青草原伊人| 久久99毛片免费观看不卡|