• <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
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

                   
                  前情提要:若要實(shí)現(xiàn)一個(gè)類似于Windows Store的界面的話,這個(gè)類必須要先繼承自GridView,并且要重寫PrepareContainerForItemOverride方法。微軟提供的模板中又給出了兩個(gè)依賴屬性來(lái)幫助我們完成這種可變尺寸的GridView。下面我們來(lái)看看重載的PrepareContainerForItemOverride方法都做了些什么。

                   首先來(lái)看微軟官方給出的該方法的描述:
                   Prepares the specified element to display the specified item.
                  用特定的元素來(lái)顯示特定的項(xiàng)。

            怎么理解?看代碼理解:
            1 protected:
            2 virtual void PrepareContainerForItemOverride(
            3   DependencyObject^ element, 
            4   Object^ item
            5 )
            6 

            element: The element that's used to display the specified item.
            item: The item to display.
            即,用此element來(lái)表現(xiàn)該item,繼而顯示這個(gè)item。一般情況下,我們的GridView里面都會(huì)有N個(gè)Item,那么,該方法會(huì)執(zhí)行N遍,使每個(gè)Item都能被設(shè)定。即我們的GridView就是Container:
             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 }
            第3行: 先調(diào)用父類方法進(jìn)行基礎(chǔ)操作(具體不清楚做什么,但是這一步必須要有,可以放在最前,也可以放在最后)。

            第4行: 要顯示的Item。 我們的Item都是Data::DataItem類型的,所以要進(jìn)行類型轉(zhuǎn)換。這里注意,WinRT中所有的類都是從Platform::Object^ 繼承而來(lái),我們可以用(DataItem^)(item)進(jìn)行轉(zhuǎn)換,也可以用safe_cast<DataItem^>(item)來(lái)進(jìn)行轉(zhuǎn)換。

            第5行: 指定的element。這里轉(zhuǎn)換成UIElement類型。

            7--10行:將綁定的source(源)設(shè)置為我們的item,綁定的path(路徑)設(shè)置為VariableSizedGridView的ItemColSpanPropertyPath。這里容易產(chǎn)生混淆:一般情況下,我們?cè)谶M(jìn)行數(shù)據(jù)綁定的時(shí)候,path一般是source的一個(gè)屬性,比如說(shuō),一般情況下應(yīng)該是類似于這樣:colBinding->Source = viewMode; colBinding->Path = ref new PropertyPath(viewMode->propertyOfViewMode);  這里竟然設(shè)置成了另外一個(gè)類的屬性,所以之前我迷惑了很長(zhǎng)一段時(shí)間。但是如果你去XAML文件里面看一下的話,就知道它為什么這么做了。我們先不要著急看XAML文件,還有第10行。

            Associates a Binding with a target property on a target object. This method is the code equivalent to declaring a {Binding} in markup.
            將目標(biāo)對(duì)象的目標(biāo)屬性進(jìn)行綁定。
              
            1 
            2 public:
            3 static void SetBinding(
            4   DependencyObject^ target, 
            5   DependencyProperty^ dp, 
            6   BindingBase^ binding
            7 )
            8 
            9 
                
            第10行的意思是說(shuō):將uiElment的VariableSizedWrapGrid::ColumnSpan屬性同該item的itemColSpanPropertyPath進(jìn)行綁定。但是item沒(méi)這個(gè)屬性。現(xiàn)在是時(shí)候來(lái)看看XAML文件了:

             1  <common:VariableGridView
             2             x:Name="itemGridView"
             3             AutomationProperties.AutomationId="ItemGridView"
             4             AutomationProperties.Name="Grouped Items"
             5             Padding="0"
             6             ItemsSource="{Binding Source={StaticResource groupedItemsViewSource}}"
             7             ItemTemplateSelector="{StaticResource myDataTemplateSelector}"
             8             SelectionMode="None"
             9             IsSwipeEnabled="false"
            10             IsItemClickEnabled="True"
            11             ItemClick="ItemView_ItemClick"
            12             ItemColSpanPropertyPath="ColumnSpan"
            13             ItemRowSpanPropertyPath="RowSpan" Grid.Row="2"
            14             Margin="30,20,20,10" ItemTemplate="{StaticResource BigDateTemplate}">

            我們看到ItemColSpanPropertyPath被賦值成了ColumnSpan,而item中正好有這么個(gè)屬性:

             1 namespace Data
             2 {
             3 [Windows::UI::Xaml::Bindable]
             4 public ref class DataItem
             5 {
             6 //
             7 //            
             8                         property int RowSpan{ int get(); void set(int);}
             9             property int ColumnSpan{ int get(); void set(int);}
            10 //
            11 //
            12 };
            13 }
            那么一切都說(shuō)的過(guò)去了,原來(lái)綁定的Source是DataItem,path是ColumnSpan。

                  那么這個(gè)重載的方法的最終目的就相當(dāng)于是這么一個(gè)語(yǔ)句:
            1 <common:VariableGridView            VariableSizedWrapGrid.ColumnSpan="{Binding Source={data::DataItem}, Path=ColumnSpan}"/>
            即,在初始化DataItem的時(shí)候,只要設(shè)置了ColumnSpan這個(gè)值,就能使這個(gè)Item的列進(jìn)行相應(yīng)地改變。
                  
                  其實(shí)整個(gè)過(guò)程非常之簡(jiǎn)單,我們的目的就只是上面的一個(gè)語(yǔ)句而已,為了達(dá)到這個(gè)目的,我們?cè)O(shè)置了兩個(gè)依賴屬性來(lái)接收字符串,并且重載PrepareContainerForItemOverride方法進(jìn)行綁定。大家可以通過(guò)示例代碼進(jìn)行領(lǐng)會(huì)。
                  OK,這一篇是補(bǔ)上周六的。盡量做到每天一篇,保質(zhì)保量。
                  下期提示:剛剛看過(guò)了微軟提供的模板,下一篇講述我們自己的方法。該方法同微軟的方法大同小異,但是,是網(wǎng)上的一位牛人自己寫的,他也是用C#寫出來(lái),我把它改成C++版本。
            posted on 2012-10-14 17:46 Dino-Tech 閱讀(2171) 評(píng)論(7)  編輯 收藏 引用

            FeedBack:
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 15:31 英明神武可愛(ài)
            auto viewMode = (Data::DataItem^)(item);
            這句話里的 DataItem^ 是什么,
            我編譯一直提示 Data 沒(méi)有成員 DataItem  回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 15:45 英明神武可愛(ài)
            你要看到留言,可以加我的QQ:1045330487;,我有問(wèn)題請(qǐng)教。
            這個(gè)溝通真是太不方便。 。。。  回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 15:51 Dino-Tech
            @英明神武可愛(ài)
            Hello, DataItem是我自己定義的一個(gè)類,在自定義的Data命名空間中。這句話的意思是把一個(gè)item轉(zhuǎn)換成我自己的DataItem類型。  回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 16:16 英明神武可愛(ài)
            你可以加我的qq嗎,我按你的方法繼承了gridview,但是編譯不過(guò)。  回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 16:23 英明神武可愛(ài)
            我現(xiàn)在用GridView 控件生成了界面。現(xiàn)在想用你的方法更改某一個(gè)item;
            colBinding -> Path = ref new PropertyPath( this -> ItemColSpanPropertyPath);

            ItemColSpanPropertyPath 是什么東西?
              回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 17:23 Dino-Tech
            @英明神武可愛(ài)
            額,這樣,你可以參考一下C#版本。
            打開(kāi)你的VS2012,打開(kāi)File->New Project, 點(diǎn)擊Online->Templates->Visual C#, 其中有一個(gè)Variable Sized Grid Template,里面的代碼跟C++的方法是類似的。
            我現(xiàn)在不能上qq,晚上加吧。  回復(fù)  更多評(píng)論
              
            # re: Windows 8 學(xué)習(xí)筆記(四)--創(chuàng)建Variable Sized GridView之PrepareContainerForItemOverride方法 2013-01-08 17:28 英明神武可愛(ài)
            @Dino-Tech
            @Dino-Tech

            OK,期待你加我的QQ.
              回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲日韩欧美一区久久久久我 | 久久精品无码一区二区无码| 亚洲午夜福利精品久久| 精品久久久久久久久免费影院| 日本加勒比久久精品| 久久这里只有精品首页| 青青草国产精品久久| 久久亚洲精品无码观看不卡| 亚洲综合伊人久久大杳蕉| 国产高潮久久免费观看| 丁香色欲久久久久久综合网| 国产精品久久久天天影视| 亚洲国产成人久久一区WWW| 91精品国产高清久久久久久io| 久久久久国色AV免费看图片| 久久国产高潮流白浆免费观看| 亚洲а∨天堂久久精品| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产成人乱码精品女人久久久不卡| 少妇久久久久久久久久| 青春久久| 国产精品gz久久久| 欧美久久精品一级c片片| AV无码久久久久不卡蜜桃| 久久久精品无码专区不卡| 国产精品久久久久aaaa| 怡红院日本一道日本久久 | 久久精品免费观看| 亚洲av成人无码久久精品| 色综合久久88色综合天天 | 99国内精品久久久久久久| 久久久久久国产精品无码超碰| 亚洲精品无码久久久| 久久人妻少妇嫩草AV蜜桃| 狠狠人妻久久久久久综合| 亚洲国产精品久久久久婷婷软件| 久久综合九色综合网站| 久久久精品人妻一区二区三区蜜桃| 亚洲欧美成人综合久久久| 久久久久国产精品人妻| 亚洲色婷婷综合久久|