Fineex 发表于 2020-8-12 18:44:58

页面报表脚本解析Base64图片

如下图:
是区域报表(基于代码)写的。把入参的 base64图片,转换成图片显示到报表控件中。


请问: 页面报表,要怎么来实现?这样的业务场景? 通过脚本?请帮忙给个demo

Lenka.Guo 发表于 2020-8-12 19:16:39

您好,转换Base64 图片操作步骤如下,AR本身不直接支持该格式需要转换:
体操作方法如下:

(1) 数据库表设计字符型字段。如下图:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/164632h3ph3oizeh9pj5gz.png
图中的Base64字段类型为varchar(MAX),就是用于保存图片的Base64内容的。

(2)准备Base64字段内容
实际项目中,数据库中的Base64字符串都是通过程序代码转换得到的。
如果想要手工讲一个图片转成Base64字符串,可使用网上的图片转Base64的工具,一般上传一个图片文件,转换之后就能得到下面这样的字符串:
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAARMAAAGB....
将这个字符串从转换工具的网页上拷贝下来,去掉最前面的 data:image/png;base64, (包括最后的逗号),再粘贴到数据库的字段中,如下图:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/165933geag1mjm7sa7jsmj.png
当然使用insert语句也可以。

(3) 拖放图片元素到报表
如下图,在一个表格的单元格中拖放一个图片元素:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/170230su05310w1z0n500a.png

(4)设置图片的数据
先展开图片元素的【图片】属性,以便看到更多设置选项,如下图:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/170352tohredrjkjyxkdd2.png
再点击【数据】右侧的小方块图标,打开表达式编辑器,输入下面这样的表达式:
=Convert.FromBase64String(Fields!Base64.Value)
如下图:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/171115kxdxvx9vwd0w4v88.png
这个表达式的含义是:将Base64字段值转成二进制的图片。
这样设置后,就可以预览报表了,效果如下图:
https://gcdn.grapecity.com.cn/data/attachment/forum/202003/18/172034o883t7nxxi58iftt.png
其中表格第三列是显示Base64字段的实际字符串内容,最后一列的红色块是实际的图片。
页: [1]
查看完整版本: 页面报表脚本解析Base64图片