青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 55  文章 - 15  trackbacks - 0
<2013年1月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿

隨筆分類

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

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

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

怎么理解?看代碼理解:
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來表現(xiàn)該item,繼而顯示這個item。一般情況下,我們的GridView里面都會有N個Item,那么,該方法會執(zhí)行N遍,使每個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)用父類方法進行基礎(chǔ)操作(具體不清楚做什么,但是這一步必須要有,可以放在最前,也可以放在最后)。

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

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

7--10行:將綁定的source(源)設(shè)置為我們的item,綁定的path(路徑)設(shè)置為VariableSizedGridView的ItemColSpanPropertyPath。這里容易產(chǎn)生混淆:一般情況下,我們在進行數(shù)據(jù)綁定的時候,path一般是source的一個屬性,比如說,一般情況下應(yīng)該是類似于這樣:colBinding->Source = viewMode; colBinding->Path = ref new PropertyPath(viewMode->propertyOfViewMode);  這里竟然設(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.
將目標對象的目標屬性進行綁定。
  
1 
2 public:
3 static void SetBinding(
4   DependencyObject^ target, 
5   DependencyProperty^ dp, 
6   BindingBase^ binding
7 )
8 
9 
    
第10行的意思是說:將uiElment的VariableSizedWrapGrid::ColumnSpan屬性同該item的itemColSpanPropertyPath進行綁定。但是item沒這個屬性。現(xiàn)在是時候來看看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中正好有這么個屬性:

 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 }
那么一切都說的過去了,原來綁定的Source是DataItem,path是ColumnSpan。

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

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

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

OK,期待你加我的QQ.
  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              午夜一区二区三视频在线观看| 麻豆91精品91久久久的内涵| 亚洲人午夜精品| 国内外成人免费激情在线视频| 99在线精品免费视频九九视| 欧美.日韩.国产.一区.二区| 久久精品视频在线观看| 午夜精品婷婷| 在线一区二区日韩| 国产精品成人一区二区网站软件| 亚洲乱码久久| 一本色道精品久久一区二区三区 | 狂野欧美性猛交xxxx巴西| 亚洲精品乱码久久久久久| 久久综合九色综合欧美就去吻| 国产日韩欧美日韩大片| 亚洲一区三区在线观看| 亚洲欧洲一区二区三区| 欧美二区视频| 国产精品五区| 欧美一区二区视频97| 一区二区久久久久| 一区二区三区日韩欧美| 国产精品久久久久久久久久免费看| 亚洲新中文字幕| 9久re热视频在线精品| 日韩系列在线| 亚洲视频在线观看网站| 午夜精品一区二区三区四区 | 亚洲精品久久7777| 亚洲作爱视频| 久久超碰97人人做人人爱| 久久国产天堂福利天堂| 亚洲午夜一级| 免费成人av在线| 亚洲日本免费| 欧美1区3d| 9色精品在线| 久久激情视频久久| 国产精品成人一区二区艾草| 国产在线视频欧美| 国产精品一区二区你懂的| 欧美综合国产精品久久丁香| 欧美成人在线免费观看| 国产精品v亚洲精品v日韩精品| 亚洲国产老妈| 久久不见久久见免费视频1| 看欧美日韩国产| 国产精品qvod| 国产精品99久久久久久宅男| 久久久久久久91| 亚洲三级视频| 农村妇女精品| 韩日精品视频一区| 亚洲一级特黄| 亚洲精品资源| 蜜臀av性久久久久蜜臀aⅴ| 欧美日韩国产综合在线| 91久久中文| 美女国内精品自产拍在线播放| 亚洲欧洲日韩女同| 免费看av成人| 夜夜嗨av色一区二区不卡| 亚洲自拍偷拍麻豆| 国产精品久久久91| 日韩午夜电影av| 毛片基地黄久久久久久天堂| 欧美在线播放视频| 国产欧美一区二区精品性| 午夜欧美理论片| 亚洲五月婷婷| 美女网站在线免费欧美精品| 亚洲韩日在线| 欧美国产日韩一区二区| 日韩西西人体444www| 欧美日韩精品免费在线观看视频| 亚洲精品一区二区网址| 久久精品一二三区| 久久久久一区二区三区| 一色屋精品视频免费看| 亚洲欧美激情在线视频| 亚洲欧美日韩综合| 国产农村妇女精品| 欧美伦理91i| 91久久精品美女高潮| 免费中文日韩| 亚洲欧美韩国| 亚洲新中文字幕| 国产精品自拍在线| 老司机免费视频一区二区| 久久精品一区蜜桃臀影院 | 亚洲精品色图| 亚洲狠狠婷婷| 欧美日韩午夜在线视频| 欧美一区二区三区日韩视频| 午夜精品一区二区三区电影天堂| 国产婷婷色一区二区三区| 久久躁日日躁aaaaxxxx| 久久久久久久激情视频| 亚洲高清色综合| 一区二区三区你懂的| 国产亚洲精品久久久| 蜜桃av综合| 欧美亚州在线观看| 久久国产一二区| 老司机午夜精品视频| 亚洲欧美高清| 久久亚洲风情| 亚洲一区二区三区在线播放| 久久综合伊人77777| 亚洲线精品一区二区三区八戒| 欧美一二三区精品| 在线一区二区视频| 欧美一区二区女人| 国内精品视频一区| 中日韩美女免费视频网址在线观看 | 亚洲精品在线观看视频| 国产乱理伦片在线观看夜一区| 欧美第一黄色网| 午夜精品久久久久久久蜜桃app | 亚洲国产欧美国产综合一区| 国产欧美精品一区二区色综合 | 日韩天堂在线视频| 在线精品视频一区二区| 一本色道久久综合亚洲精品婷婷 | 欧美精品久久久久久久| 久久综合激情| 国产精品成人观看视频免费 | 亚洲一区在线直播| 亚洲人成7777| 久久久久久精| 久色成人在线| 国产精品一区在线观看| 亚洲另类一区二区| 亚洲欧洲精品成人久久奇米网| 亚洲欧美日韩视频一区| 在线亚洲精品| 欧美三级在线| 亚洲黄页一区| 欧美另类高清视频在线| 亚洲成色www8888| 国产一区二区三区成人欧美日韩在线观看 | 国产精品欧美日韩一区二区| 亚洲丶国产丶欧美一区二区三区 | 欧美一区二区三区精品电影| 亚洲淫片在线视频| 欧美激情视频一区二区三区免费| 亚洲九九精品| 免费成人黄色av| 麻豆av一区二区三区久久| 中日韩高清电影网| 亚洲色无码播放| 欧美日韩1区| 日韩一区二区精品视频| 日韩一级精品| 欧美日本在线看| 在线中文字幕不卡| 亚洲一级免费视频| 欧美日韩一视频区二区| 亚洲综合视频1区| 性感少妇一区| 国产模特精品视频久久久久| 久久久99精品免费观看不卡| 亚洲国产一区二区三区a毛片 | 日韩视频在线免费| 国产精品99久久久久久久久久久久| 国产精品v欧美精品v日韩精品| 亚洲最黄网站| 欧美一区二区三区四区在线 | 国产精品入口麻豆原神| 欧美在线播放一区| 免费在线亚洲| 亚洲综合视频网| 在线成人亚洲| 国产精品久久精品日日| 久久精品一区二区三区中文字幕| 亚洲大片一区二区三区| 亚洲一区二区三区高清| 国自产拍偷拍福利精品免费一| 免费欧美在线| 亚洲欧美日韩一区二区在线| 欧美福利在线| 夜夜爽99久久国产综合精品女不卡| 国产亚洲欧洲| 欧美成人69| 欧美淫片网站| 91久久精品网| 欧美专区日韩视频| 中文高清一区| 国内精品久久久久久| 欧美大片免费久久精品三p| 中国女人久久久| 亚洲日本无吗高清不卡| 久久精品成人欧美大片古装| 亚洲欧洲日本国产| 精品88久久久久88久久久| 欧美人牲a欧美精品| 欧美亚洲一区二区在线| 美国十次成人| 久久综合一区二区|