使用FastReport报表动态更新人员签名图片

简介: 使用FastReport报表动态更新人员签名图片

在一些报表模块中,需要我们根据用户操作的名称,来动态根据人员姓名,更新报表的签名图片,也就是电子手写签名效果,本篇随笔介绍一下使用FastReport报表动态更新人员签名图片。

1、设计FastReport报表,使用图片来代替签名效果

例如我们设计了以上的FastReport报表,其中签字盖章哪里,我们用来图片组件来承载相关医生的电子签名,电子签名的图片,根据数据库记录的图片地址,进行生成时刻的替换即可。

报表以PDF的方式生成,手机端利用PDF.js库可以查看PDF文件。

我们看到以上的签字图片,设计的时候用一张默认图片代替效果,我们切换报表的C#代码部分,来实现报表签名的动态更新。

各个部分的图片替换处理逻辑是一样的,都是首先根据传递的参数名称,来设置图片的路径即可。

 

2、动态根据数据库配置的图片地址,进行参数处理

FastReport报表呈现,可以赋值参数,以及数据源等,我们可以通过再数据库获取到图片信息后赋值给参数名称,以及数据记录作为数据源绑定到报表即可,如下是相关的处理代码。

//定义参数和数据格式
var dict = new Dictionary<string, object>();

然后封装一个根据医生名称,读取里面的数据库图片地址的函数,如下所示。

/// <summary>
        /// 获取医生的签名图片,如果没有,则返回空图片文件
        /// </summary>
        /// <param name="doctorName">医生姓名</param>
        /// <returns></returns>
        private string GetDoctorSign(string doctorName)
        {
            //转换为物理路径
            string signImage = "/Report/EmptySign.png";
            var signImagePath = Server.MapPath(signImage);
            if(!string.IsNullOrEmpty(signImage))
            {
                var signInfo = BLLFactory<DoctorSign>.Instance.FindSingle($"DoctorName='{doctorName}'");
                if(signInfo != null && !string.IsNullOrEmpty(signInfo.PicturePath))
                {
                    signImagePath = signInfo.PicturePath;
                }
            }
            return signImagePath;
        }

接着就是把这些图片地址作为对应医生的参数赋值到字典集合。

//相关医生签名图片
    dict.Add("SignChufang", GetDoctorSign(info.ShopDoctor));
    dict.Add("SignShenfang", GetDoctorSign(info.CheckPharmacistName));
    dict.Add("SignTiaopei", GetDoctorSign(info.Tiaopei));
    dict.Add("SignFuhe", GetDoctorSign(info.Fayao));

而处方单的记录,我们可以构建一个DataTable的数据集合,根据数据库记录写入DataTable赋值即可。

var dt = DataTableHelper.CreateTable("ProductName,Quantity|int,Unit,Specification,HowTo,Frequency,UseAmount");
foreach (var item in detailList)
{
    var dr = dt.NewRow();
    var displayName = item.ProductName;
    if(!string.IsNullOrEmpty(item.Specification))
    {
        displayName += $"({item.Specification})";
    }
    dr["ProductName"] = displayName;
    dr["Quantity"] = item.Quantity;
    dr["Unit"] = item.Unit;
    dr["Specification"] = item.Specification;
    dr["HowTo"] = item.HowTo;
    dr["Frequency"] = item.Frequency;
    dr["UseAmount"] = item.UseAmount;
    dt.Rows.Add(dr);
}

有了参数和数据源,赋值给报表对象进行处理即可,如下代码。

//刷新数据源
    report.RegisterData(dt, "Detail");
    foreach (string key in dict.Keys)
    {
        report.SetParameterValue(key, dict[key]);
    }
    //运行报表
    report.Prepare();

最后使用PDFExport生成PDF文件,如下所示。

生成PDF文件,我们在服务端的API接口返回路径给pdf.js前端处理显示。

//导出PDF的相对文件路径
string exportPdfPath = string.Format("/GenerateFiles/Pres/NewReport_{0}.pdf", id);
//转换为物理路径
string realPath = Server.MapPath(exportPdfPath);
var export = new PDFExport();
report.Export(export, realPath);
report.Dispose();

最后报表的H5界面显示效果如下。

以上就是基于FastReport对报表处理的过程,FastReport还可以用在Winform、Vue的BS端,以及WPF应用程序上,我的博客里面都有相关的介绍,因此利用FastReport设计的报表,可以重用在多个终端上,非常方便。

 

专注于代码生成工具、.Net/.NetCore 框架架构及软件开发,以及各种Vue.js的前端技术应用。著有Winform开发框架/混合式开发框架、微信开发框架、Bootstrap开发框架、ABP开发框架、SqlSugar开发框架等框架产品。
 转载请注明出处:撰写人:伍华聪  http://www.iqidi.com

相关文章
|
3月前
|
开发框架 前端开发 JavaScript
利用FastReport传递图片参数,在报表上展示签名信息
利用FastReport传递图片参数,在报表上展示签名信息
|
6月前
基于jeecgboot流程管理平台的在线表单设计修改成formdesigner(二)
基于jeecgboot流程管理平台的在线表单设计修改成formdesigner(二)
148 1
|
6月前
|
前端开发
基于jeecgboot流程管理平台的在线表单设计修改成formdesigner正式发布
基于jeecgboot流程管理平台的在线表单设计修改成formdesigner正式发布
45 0
|
前端开发 定位技术
百度地图开发自定义信息窗口openInfoWindow样式的解决方案
百度地图开发自定义信息窗口openInfoWindow样式的解决方案
1276 0
|
SQL Oracle 数据可视化
报表自动生成软件有哪些?热门报表自动生成软件推荐
报表自动生成软件有哪些?热门报表自动生成软件推荐
|
数据可视化 Oracle 关系型数据库
报表功能升级|新增的这4项图表组件太太太好用了吧!
你们要的交叉透视表、词云、日历热力图、雷达图安排上啦~
512 0
报表功能升级|新增的这4项图表组件太太太好用了吧!
|
前端开发 数据可视化 缓存
网站验收新标准:所有颜色均可以在可视化后台修改
网站验收新标准:所有颜色均可以在可视化后台修改 在大部分用户的概念中,定制网站比起比尔云标准化模板建站要高大上,但阅读完本文后,或许你会认识到这是一种不太科学的认识!为什么?请问你的网站上线后自己可以在可视化编辑界面任意调整各种颜色吗? “这个蓝色需要调整,我觉得浅了一点”,于是乎网络公.
1412 0
|
BI JavaScript 数据可视化
报表怎样实现滚动的公告效果?
报表怎样实现滚动的公告效果
1172 0
|
JavaScript BI 定位技术
|
BI 开发框架 自然语言处理