wp8.1 Study7: ListView 和GridView应用
对于列表控件,WP8.1常用的是ListView、GridView、ListBox控件。其中前两个是从第三个继承来的。
1、ListView控件
它是展示垂直列表的,如下图所示。它十分适合展示数据。
2、GridView控件
它是行列表展示数据的控件,排列图如下。通常用来展示基于图片的数据。
3、控件的Templates
常用的有HeaderTemplate、FooterTemplate、ItemTemplate。本文最下面有相关代码。
(其中还有ItemContainerStyle、ItemsPanel
4、属性:重新排序Reordering
WP8.1中:MyListView.ReorderMode = ListViewReorderMode.Enabled;
Win8.1中:MyListView.CanReorderItems = false;
但Grouped Lists (分组列表)不能重新排序。
5、属性:多种选定MultiSelection
当开启MultiSelection后,列表会变为下图。开启MultiSelection代码为:MyListView.SelectionMode = ListViewSelectionMode.Multiple;
6、运用实例:
xaml代码:
<Grid Grid.Row="1" x:Name="ContentRoot" Margin="19,9.5,19,0">
<ListView Name="view1"
SelectionMode="None"
AllowDrop="True"
CanDragItems="True"
IsSwipeEnabled="True">
<ListView.HeaderTemplate>
<DataTemplate>
<StackPanel>
<Canvas Height="15" Background="#962381E0">
<TextBlock Text="header">
<TextBlock.Foreground>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="Black" Offset="0"/>
<GradientStop Color="#FFF9F5F5" Offset="1"/>
</LinearGradientBrush>
</TextBlock.Foreground>
</TextBlock>
</Canvas>
</StackPanel>
</DataTemplate>
</ListView.HeaderTemplate>
<ListView.ItemTemplate>
<DataTemplate>
<StackPanel Orientation="Horizontal">
<TextBlock Text="{Binding Id}" Style="{ThemeResource ListViewItemTextBlockStyle}" Width="100"/>
<TextBlock Text="{Binding Name}" Style="{ThemeResource ListViewItemTextBlockStyle}"/>
</StackPanel> </DataTemplate>
</ListView.ItemTemplate>
<ListView.FooterTemplate>
<DataTemplate>
<TextBlock Foreground="Red" Text="这是个学习的好例子"/>
</DataTemplate>
</ListView.FooterTemplate>
</ListView>
</Grid>
</Grid>
<Page.BottomAppBar>
<CommandBar>
<CommandBar.SecondaryCommands>
<AppBarButton Label="appbarbutton"/>
</CommandBar.SecondaryCommands>
<AppBarButton Name="AllApps" Icon="AllApps" Label="多选" Click="AllApps_Click"/>
<AppBarButton Name="viewall" Icon="ViewAll" Label="appbarbutton" Click="viewall_Click"/>
</CommandBar>
</Page.BottomAppBar>
相应的部分C#代码:
List<School> items = new List<School>();
public string[] str=new string[]{"华农","华工","中大","华师","暨大","广工","广外","广大","深大","广中医","南医大"};
Random random = new Random(); for (int i = ; i < ; i++)
{
items.Add(new School { Id = i, Name = str[random.Next(,)] });
}
this.view1.ItemsSource = items; ... private void AllApps_Click(object sender, RoutedEventArgs e)
{
if (view1.SelectionMode == ListViewSelectionMode.Multiple)
{
view1.SelectionMode = ListViewSelectionMode.Single;
}
else
view1.SelectionMode = ListViewSelectionMode.Multiple;
} private void viewall_Click(object sender, RoutedEventArgs e)
{
if ( view1.ReorderMode == ListViewReorderMode.Enabled)
{
view1.ReorderMode = ListViewReorderMode.Disabled;
}
else
view1.ReorderMode = ListViewReorderMode.Enabled;
} private void gotopage2_Click(object sender, RoutedEventArgs e)
{
Frame.Navigate(typeof(Page2));
}
}
---------------------------------------------------------------------------------------------------------------------------------------------
2015年2月26号添加
一、ListView或GridView控件的GroupStyle
使用GroupStyle属性可以更好为App展示数据,效果图如下:
这种样式十分容易弄出来,步骤如下:
step1:
在Page.Resoures添加
<CollectionViewSource x:Name="collectionItems" IsSourceGrouped="True" Source="{Binding Items}" ItemsPath="Codes"/>
step2:
添加GroupStyle
<ListView Name="listCode" ItemClick="listViewCode_ItemClick"
ItemsSource="{Binding Source={StaticResource collectionItems}}"
ItemTemplate="{StaticResource StandardTripleLineItemTemplate}"
IsItemClickEnabled="True">
<ListView.GroupStyle>
<GroupStyle>
<GroupStyle.HeaderTemplate>
<DataTemplate>
<Grid>
<Border Opacity="0.8" Width="350" CornerRadius="0,30,30,0" Background="{StaticResource MyFavoriteBrush}">
<TextBlock Text="{Binding Title}" FontSize="30" Padding="5"/>
</Border>
</Grid>
</DataTemplate>
</GroupStyle.HeaderTemplate>
</GroupStyle>
</ListView.GroupStyle>
</ListView>
即可
ps:collectionItems绑定的数据格式可参考https://msdn.microsoft.com/en-us/library/windows/apps/xaml/hh780627.aspx?f=255&MSPPError=-2147217396
还可以使用SemanticZoom控件加强用户体验,demo地址:https://msdn.microsoft.com/zh-cn/library/windows/apps/xaml/hh781234
wp8.1 Study7: ListView 和GridView应用的更多相关文章
- WP8.1学习系列(第二十七章)——ListView和GridView入门
快速入门:添加 ListView 和 GridView 控件 (XAML) 在本文中 先决条件 选择 ListView 或 GridView 将项添加到项集合 设置项目源 指定项目的外观 指定视图 ...
- [Android Pro] listView和GridView的item设置的高度和宽度不起作用
referece to : http://blog.csdn.net/beibeixiao/article/details/9032569 1. 在Android开发中会发现,有时listVi ...
- android 有弹性的ScrollView 简单实现,与处理ScrollView和ListView,GridView之间的冲突
处理ScrollView和ListView,GridView之间的冲突, 最好的办法就是继承这两个类,重写他们的onMeasure方法即可: ListView: import android.widg ...
- Android之ScrollView嵌套ListView和GridView冲突
由于ListView,GridView本身都继承于ScrollView,一旦在ScrollView中嵌套ScrollView, 在ScrollView中嵌套使用ListView或者GridView,L ...
- [安卓] 16、ListView和GridView结合显示单元实现自定义列表显示效果
List在各种手机应用中都有体现,是安卓UI设计的必修课. 本文将介绍在开发中如何利用ListView和GridView设计自定义列表. 下面分别是用ListView和GridView做的效果: 上面 ...
- android listView嵌套gridview的使用心得
在开发的过程中可能需要用到listview嵌套gridview的场景,但是在Android中, 不能在一个拥有Scrollbar的组件中嵌入另一个拥有Scrollbar的组件,因为这不科学,会混淆滑动 ...
- (转)解决ScrollView嵌套ListView或者GridView导致只显示一行的方法
即动态获取ListView和GridView的高度 一.对于ListView ListView listview= new ListView(this); setListViewHeightBased ...
- Listview和Gridview自定义分割线
1,ListView和GridView中的每一个条目都有分割线,属性android:footerDividersEnabled表示是否显示分割线,默认是为true,即可见.可以自定义的设置分割线的颜色 ...
- android 项目学习随笔十七(ListView、GridView显示组图)
ListView.GridView显示组图,处理机制相同 <?xml version="1.0" encoding="utf-8"?> <Li ...
随机推荐
- 认识Service
Service相对于Activity可在后台运行,五显示界面,在activity退出的情况下仍能运行. 一.新建一个空的工程,命名为learnService 二.新建一个service,并添加如下所示 ...
- STM32学习笔记(三) STM32的GPIO的深入学习
STM32的开发学习主要涉及软硬件两个部分的实现,包含众多外设和总线的理解配置.STM32的整个学习曲线并不陡峭,但入门却相当困难,因此在学习之初,多动手实验和测试相当重要,GPIO作为整个STM32 ...
- easyui 进度条
进度条创建 $.messager.progress({ title:'请稍后', msg:'正在努力...' }); 进度条关闭 $.messager.progress('close'); 弹窗对话框 ...
- 转载---jboss简单使用
初学Jboss,对于Jboss的基础认识以及配置做一些记录 Jboss基础: JBoss是什么–基于J2EE的应用服务器–开放源代码–JBoss核心服务不包括支持servlet/JSP的WEB容器,一 ...
- Boostrap学习心得
进入新公司,前端用到各种页面元素几乎都是bootStrap框架里的,下面介绍下某些页面控件怎么运用,作为知识点备份,提供有需要人观看: 首先下载bootstrap,地址http://www.bootc ...
- IE浏览器GET传参后台乱码
ie里面 get传递的字符串 为 gb2312 ,后台用的是utf-8类型 所以用 POST传递字符串到后端 否则进行js参数转码 encodeURI(""); 后端解码
- css-高度自适应的问题(body高度问题)
css-高度自适应的问题 对象height:100%并不能直接产生效果,是因为跟其父对象有关. #center{ height:100%; } 上面的css样式是无效的,不会产生任何效果. 需要改写: ...
- 【转】loading 三种实现方式
转载:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=76872 一.通过动画实现 定义res/anim/loading.xml如 ...
- python2 httplib 笔记
python2 httplib 笔记 #coding=utf-8 ''' Created on 2014年9月25日 @author: cocoajin ''' import httplib,url ...
- MHA的几种死法-叶良辰
master不通 找到最新slave 找到有所有其他slave缺失relay log的 slave 选主 配置文件指定 ...