• 布局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 分页的更多相关文章

  1. WPF ListView 选中问题

    WPF ListView 选中问题  摘自:http://www.cnblogs.com/BBHor/archive/2013/04/28/VisualTreeHelper-PreviewMouseD ...

  2. Android --ListView分页

    参考博客:Android ListView分页加载(服务端+android端)Demo 监听OnScrollListener事件 class OnListScrollListener implemen ...

  3. Android中ListView分页加载数据

    public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...

  4. [WPF]ListView点击列头排序功能实现

    [转]   [WPF]ListView点击列头排序功能实现 这是一个非常常见的功能,要求也很简单,在Column Header上显示一个小三角表示表示现在是在哪个Header上的正序还是倒序就可以了. ...

  5. android中listview分页载入数据

    前段时间做的新浪微博项目一直想实现listview分页载入数据,今天最终实现了,哈哈!感觉挺好的,今天又写了个demo给大家分享下. 首先说下listview的优化方案,这也是面试中常考的题目.优化方 ...

  6. 【Android进阶】Listview分页加载数据的实现

    Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...

  7. Android ListView分页载入(服务端+android端)Demo

    Android ListView分页载入功能 在实际开发中经经常使用到,是每一个开发人员必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了測试. 服务端使用MyEcli ...

  8. ListView分页显示

    出在:http://blog.csdn.net/tu_bingbing/article/details/13275107         当ListView要显示的数据过多时,为了更快的响应用户,这个 ...

  9. ListView 分页 排序、编辑、插入和删除

    摘自网络地址:http://msdn.microsoft.com/zh-cn/magazine/cc337984.aspx ListView 基础 ListView 是模板驱动的控件,这意味着它默认情 ...

随机推荐

  1. mysql中OPTIMIZE TABLE的作用

    在使用mysql的时候有时候,可能会发现尽管一张表删除了许多数据,但是这张表表的数据文件和索引文件却奇怪的没有变小.这是因为mysql在删除数据(特别是有Text和BLOB)的时候,会留下许多的数据空 ...

  2. Oracle的日期时间范围查询

    Oracle日期时间范围查询 Sql代码 /* 日期时间范围查询 */ ---------- 创建日期时间测试表-------------------------------------------- ...

  3. MySQL主键删除/添加

    2修改数据库和表的字符集alter database maildb default character set utf8;//修改数据库的字符集alter table mailtable defaul ...

  4. VirtualBox Win7 虚拟机 共享文件夹设置

    1.主机(Win10) 点击共享文件夹,例如D:\VMs\Sharefolder\,选择'属性->共享->共享',选择'Everyone',点击'添加',权限级别'读取/写入',然后一路点 ...

  5. c++网络编程错误(WSAStartup)

    在使用CodeBlocks编译C++程序时, 编译程序的时候出现如下错误: undefined reference to `inet_addr@4'undefined reference to `ge ...

  6. IIS 服务没有及时响应启动或控制请求

    微软刚发布的补丁的原因,据说补丁KB939373.KB942831都会影响iis的正常运行,但是我在“添加或删除程序里”(要勾选:显示更新,才能会显示所打的补丁)没有发现以上两个补丁.最后,我发现把K ...

  7. java.lang.OutOfMemoryError: PermGen space

    Exception in thread ""http-bio-8080"-exec-1" java.lang.OutOfMemoryError: PermGen ...

  8. 如何生成DLL文件

    1.打开项目工程,点击Rebuild 2.Rebuild成功后,打开该项目所在文件目录 3.在路径里,在bin->Debug文件下可以看到刚生成成功的dll文件.

  9. Ajax实现原理详解

    Ajax:Asynchronous javascript and xml,实现了客户端与服务器进行数据交流过程.使用技术的好处是:不用页面刷新,并且在等待页面传输数据的同时可以进行其他操作. 这就是异 ...

  10. window resize的时候禁止频繁触发事件

    $(window).resize(function(){ var value=+new Date; assistantForSyncTask.execute(value); assistantForA ...