Spread Studio 表格控件:动态单元格类型

Spread 表格控件提供了丰富的单元格类型。AnimatedCellType 是继承自 ImageCellType 单元格类型。本篇文章将阐述如何实现动态图像单元格类型。我们需要创建自定义单元格类型来加载动态图片。

发布于 2013/08/09 00:00

SpreadJS

Spread 表格控件提供了丰富的单元格类型。AnimatedCellType 是继承自 ImageCellType 单元格类型。

本篇文章将阐述如何实现动态图像单元格类型。我们需要创建自定义单元格类型来加载动态图片。

可以分两步实现:

1.使用 PaintCell() 方法,绘制单元格。

2.使用 OnFrameChanged() 刷新动态图片。

Paint Cells

这里会使用 .Net Framework’s ImageAnimator 类,以下方法将使图片每秒都变化一次。

  1: public override void PaintCell(Graphics g, Rectangle r, 
FarPoint.Win.Spread.Appearance appearance, object value, 
bool isSelected, bool isLocked, float zoomFactor)
  2: {
  3:   if (currentImage == null)
  4:   {
  5:     base.PaintCell(g, r, appearance, value, isSelected, isLocked, zoomFactor);
  6:     StartAnimate(value);
  7:   }
  8:   else lock (currentImage)
  9:       base.PaintCell(g, r, appearance, currentImage, 
isSelected, isLocked, zoomFactor);
 10: }

 

使用 OnFrameChanged() 刷新动态图片。

  1: void OnFrameChanged(object sender, EventArgs e)
  2: {
  3:   lock (currentImage)
  4:     ImageAnimator.UpdateFrames(currentImage);
  5:   int rv = sheet.FpSpread.GetRowViewportCount();
  6:   int cv = sheet.FpSpread.GetColumnViewportCount();
  7:   Rectangle spreadRect = sheet.FpSpread.Bounds;
  8:   for (int r = -1; r < rv; r++)
  9:     for (int c = -1; c < cv; c++)
 10:     {
 11:       Rectangle rect = sheet.FpSpread.GetCellRectangle(r, c, rowIndex, columnIndex);
 12:       rect.Intersect(spreadRect);
 13:       if (!rect.IsEmpty)
 14:         sheet.FpSpread.Invalidate();
 15:     }
 16: }

Demo1

Demo 下载:VS2010 + C# + Spread Studio 7 + .NET 4.0: 点击下载:

Demo 下载:VS2010 + VB.NET + Spread Studio 7 + .NET 4.0: 点击下载

SpreadJS | 下载试用

纯前端表格控件SpreadJS,兼容 450 种以上的 Excel 公式,具备“高性能、跨平台、与 Excel 高度兼容”的产品特性,备受华为、苏宁易购、天弘基金等行业龙头企业的青睐,并被中国软件行业协会认定为“中国优秀软件产品”。SpreadJS 可为用户提供类 Excel 的功能,满足表格文档协同编辑、 数据填报、 类 Excel 报表设计等业务场景需求,极大的降低企业研发成本和项目交付风险。

如下资源列表,可以为您评估产品提供帮助:

相关产品
推荐相关案例
推荐相关资源
关注微信
葡萄城社区二维码

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态