当前位置: 移动技术网 > IT编程>开发语言>c# > DevExpress GridView自动滚动效果

DevExpress GridView自动滚动效果

2019年07月18日  | 移动技术网IT编程  | 我要评论

引言

最新有一个winform项目使用的是devexpress的控件,所以最近都在摸索使用这套控件,实在是佩服整套控件的强大,同时代码写起来也简洁。客户有一个需求,希望报表结果能在外接的大屏幕上定时滚动。这个报表我们使用的控件就是gridcontrol,查询结果一屏不能显示完全,增加一个定时器,指定时间让gridview自动滚动显示下一屏的信息。

同事的实现

但是看到同事实现的代码时,却觉得有点不舒服。他大概的代码如下:

/// <summary>
/// 当前的行索引
/// </summary>
private int currentrowhandle = 0;
/// <summary> 
/// 总共含有的行
/// </summary> 
private int totalrowcount = 0; 
/// <summary>
/// 定时器定时事件
/// </summary>
private void timerscroll_tick(object sender, eventargs e)
{
   if (currentrowhandle == totalrowcount)
     currentrowhandle = 0;
   else
   {
     currentrowhandle += 40;
     if (currentrowhandle > totalrowcount)
       currentrowhandle = totalrowcount;
   }

   gridview1.focusedrowhandle = currentrowhandle;
}

为了实现gridview自动滚动的功能,代码引入了2个字段,而且将每次滚动的行数写死成40,当窗体和控件的大小进行缩放的时候,有可能一个屏幕无法显示40行数据,就有可能有些数据永远也显示不了。

我的实现

通过查阅devexpress的手册,发现gridview已经有提供方法可以直接使用来达到滚动翻页的效果,而且代码一如既往的简洁,无需引入任何字段。改进的代码如下:

/// <summary>
/// 定时器定时事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void timerscroll_tick(object sender, eventargs e)
{
   if (gridview1.islastrow)
   {
     gridview1.movefirst();
   }
   else
   {
     gridview1.movenextpage();
   }
}

最后送上测试的结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网