WPF:ListView 分页
- 布局MainWindow.xaml
<ListView Name="list_Reg" ItemsSource="{Binding Source={StaticResource Data}}" Style="{StaticResource ListViewStyle}">
<ListView.View>
<GridView>
<!--列头style-->
<GridView.ColumnHeaderContainerStyle>
<Style TargetType="GridViewColumnHeader">
<Setter Property="Background" Value="CadetBlue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="FontSize" Value="25"/>
<Setter Property="Padding" Value="10,0"/>
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="#FF1975A0"/>
</Trigger>
</Style.Triggers>
</Style>
</GridView.ColumnHeaderContainerStyle> <GridViewColumn Header="科室" DisplayMemberBinding="{Binding DeptName}"/>
<GridViewColumn Header="开诊科目" DisplayMemberBinding="{Binding RegName}"/>
<GridViewColumn Header="周一" DisplayMemberBinding="{Binding Show1}" Width="150"/>
<GridViewColumn Header="周二" DisplayMemberBinding="{Binding Show2}" Width="150"/>
<GridViewColumn Header="周三" DisplayMemberBinding="{Binding Show3}" Width="150"/>
<GridViewColumn Header="周四" DisplayMemberBinding="{Binding Show4}" Width="150"/>
<GridViewColumn Header="周五" DisplayMemberBinding="{Binding Show5}" Width="150"/>
</GridView>
</ListView.View>
</ListView>
</Canvas> <StackPanel Grid.Row="2" Grid.Column="1" Orientation="Horizontal">
<ItemsControl ItemsSource="{Binding Pages}">
<ItemsControl.ItemTemplate>
<DataTemplate>
<Button Name="but_Pages" Content="{Binding Name}"
Margin="5" Foreground="White" Background="CadetBlue" Padding="10,5" Click="but_Pages_Click"></Button>
</DataTemplate>
</ItemsControl.ItemTemplate> <ItemsControl.ItemsPanel>
<ItemsPanelTemplate>
<WrapPanel/>
</ItemsPanelTemplate>
</ItemsControl.ItemsPanel>
</ItemsControl> <TextBlock VerticalAlignment="Center">
<TextBlock Text="【共"/>
<TextBlock Text="{Binding Total}" Foreground="Yellow"/>
<TextBlock Text="页】"/> <TextBlock Text="【当前"/>
<TextBlock Text="{Binding CurrentSize}" Foreground="Yellow"/>
<TextBlock Text="页】"/>
</TextBlock>
</StackPanel>- 每隔10秒翻页,循环
public partial class MainWindow : Window
{
ViewPages viewPages = new ViewPages();
Timer timer = new Timer();
int _currCount=1;
public MainWindow()
{
InitializeComponent();
this.DataContext = viewPages;
} private void window_Loaded(object sender, RoutedEventArgs e)
{
if (viewPages.Total > 1)
{//当总页数大于1时才翻页
timer.Interval = 10000;//5秒变换一次
timer.Enabled = true;
timer.Elapsed += new ElapsedEventHandler(timer_Elapsed);
}
} private void but_Pages_Click(object sender, RoutedEventArgs e)
{//单击按钮时也翻页
viewPages.Fun_Pager(((sender as Button).DataContext as Page).PageSize);
} void timer_Elapsed(object sender, ElapsedEventArgs e)
{
Dispatcher.BeginInvoke(new Action(() =>
{
//翻页
_currCount = viewPages.CurrentSize+1;
if (_currCount > viewPages.Total)
{
viewPages.CurrentSize = 1;
_currCount = viewPages.CurrentSize;
}));
}
}
- 翻页函数 ViewPages.cs
public class ViewPages:INotifyPropertyChanged
{
private int _number;
public int Number
{
get { return _number; }
set
{
_number = value;
NotifyPropertyChanged("Number");
}
} private int _currentSize;
public int CurrentSize
{
get { return _currentSize; }
set
{
_currentSize = value;
NotifyPropertyChanged("CurrentSize");
}
} private int _total;
public int Total
{
get { return _total; }
set
{
_total = value;
NotifyPropertyChanged("Total");
}
} private List<Page> _pages;
public List<Page> Pages
{
get { return _pages; }
set
{
_pages = value;
NotifyPropertyChanged("Pages");
}
} private List<WPF_OPRegDept.DataOP.Reg> _listRegDept;
public List<WPF_OPRegDept.DataOP.Reg> ListRegDept
{
get { return _listRegDept; }
set
{
_listRegDept = value;
NotifyPropertyChanged("ListRegDept");
}
} private List<WPF_OPRegDept.DataOP.Reg> _listBind;
public List<WPF_OPRegDept.DataOP.Reg> ListBind
{
get { return _listBind; }
set
{
_listBind = value;
NotifyPropertyChanged("ListBind");
}
} #region INotyfyPropertyChanged 成员
public event PropertyChangedEventHandler PropertyChanged;
public void NotifyPropertyChanged(string PropertyName)
{
if(PropertyChanged!=null)
{
PropertyChanged(this,new PropertyChangedEventArgs(PropertyName));
}
}
#endregion public ViewPages()
{
DataOP dataOP=new DataOP();
this.Number = 14;//设置每页显示数目
this.ListRegDept = new List<DataOP.Reg>();//初始化数据
ListRegDept = dataOP.GetRegDept(); this.Total = ListRegDept.Count() / this.Number + 1;//获取总页数 this.Pages = new List<Page>();//初始化所有页数数组
for (int i = 1; i <= this.Total; i++)
{
this.Pages.Add(new Page {Name=i.ToString(),PageSize=i });
}
this.CurrentSize = 1;//设置当前显示页面
Fun_Pager(this.CurrentSize); }
/// <summary>
/// 分页方法
/// </summary>
/// <param name="CurrentSize">当前页数</param>
public void Fun_Pager(int CurrentSize)
{
this.CurrentSize = CurrentSize;
this.ListBind = this.ListRegDept.Take(this.Number*this.CurrentSize)
.Skip(this.Number*(this.CurrentSize-1)).ToList();
}
} public class Page
{
public string Name { get; set; }
public int PageSize { get; set; }
}
}
WPF:ListView 分页的更多相关文章
- WPF ListView 选中问题
WPF ListView 选中问题 摘自:http://www.cnblogs.com/BBHor/archive/2013/04/28/VisualTreeHelper-PreviewMouseD ...
- Android --ListView分页
参考博客:Android ListView分页加载(服务端+android端)Demo 监听OnScrollListener事件 class OnListScrollListener implemen ...
- Android中ListView分页加载数据
public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...
- [WPF]ListView点击列头排序功能实现
[转] [WPF]ListView点击列头排序功能实现 这是一个非常常见的功能,要求也很简单,在Column Header上显示一个小三角表示表示现在是在哪个Header上的正序还是倒序就可以了. ...
- android中listview分页载入数据
前段时间做的新浪微博项目一直想实现listview分页载入数据,今天最终实现了,哈哈!感觉挺好的,今天又写了个demo给大家分享下. 首先说下listview的优化方案,这也是面试中常考的题目.优化方 ...
- 【Android进阶】Listview分页加载数据的实现
Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...
- Android ListView分页载入(服务端+android端)Demo
Android ListView分页载入功能 在实际开发中经经常使用到,是每一个开发人员必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了測试. 服务端使用MyEcli ...
- ListView分页显示
出在:http://blog.csdn.net/tu_bingbing/article/details/13275107 当ListView要显示的数据过多时,为了更快的响应用户,这个 ...
- ListView 分页 排序、编辑、插入和删除
摘自网络地址:http://msdn.microsoft.com/zh-cn/magazine/cc337984.aspx ListView 基础 ListView 是模板驱动的控件,这意味着它默认情 ...
随机推荐
- Hadoop学习笔记: 全排序
在Hadoop中实现全排序有如下三种方法: 1. 只使用一个reducer 2. 自定义partitioner 3. 使用TotalOrderPartitioner 其中第一种方法显然违背了mapre ...
- MySQL字符编码
数据表tb的col列编码为latin1.而实际存储的字符是gbk编码时,用下面的语句可以查看到非乱码的原始字符串. select convert( binary(col) using gbk) fro ...
- 使用inherit属性值继承其父元素样式来覆盖UA自带样式。
像button.input这样的表单控件,不同的浏览器都会有自己的样式风格(UA样式).我们可以使用inherit继承其父元素样式,从而覆盖浏览器的UA样式. button, input, selec ...
- IDEA14下多jdk编译时,enum不支持;多个project共用在一个workplace下每个module时引用外部包
idea多个工程如何在一个项目中管理: 把多个多个项目放在一个叫work目录下,那么打开IntelliJ IDEA编译器,点击菜单 File->Open...,选择刚刚的work目录,即可. 在 ...
- MongoDb 聚合报错
聚合框架它是数据聚合的一个新框架,其概念类似于数据处理的管道. 每个文档通过一个由多个节点组成的管道,每个节点有自己特殊的功能(分组.过滤等),文档经过管道处理后,最后输出相应的结果. 管道基本的功能 ...
- Pyhton 学习总结 20 :执行系统命令
在Python中执行系统命令有os.system().os.popen().commands.getstatusoutput().subprocess.Popen等 1.os.system() ...
- Qt信号与槽应用实例一
..... connect(m_pGlobelWidget,signal(globeControlClick(object,object)),this,slot(globeControlClick(o ...
- ECMAScript 6教程 (一)
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出 原文连接,博客地址为 http://www.cnblogs.com/jasonnode/ .该系列课程是 ...
- Visual C++ 2008进行MySQL编程
visual c++ 2008进行MySQL编程(ODBC) -- (一) 套装安装 visual c++ 2008进行MySQL编程(ODBC) --(二) CDatabase操作数据库 visua ...
- 机器学习:异常检测算法Seasonal Hybrid ESD及R语言实现
Twritters的异常检测算法(Anomaly Detection)做的比较好,Seasonal Hybrid ESD算法是先用STL把序列分解,考察残差项.假定这一项符合正态分布,然后就可以用Ge ...