找回密码
 立即注册

QQ登录

只需一步,快速开始

Lenka.Guo 讲师达人认证 悬赏达人认证
超级版主   /  发表于:2021-9-2 10:21  /   查看:2743  /  回复:0
ActiveReports 报表的图片元素支持外部图片、内嵌图片、数据库二进制图片(Image字段),只需简单绑定数据集字段即可。
如果数据库字段值不是二进制的Image,而是字符型的Base64格式的字符串,那么可以使用Convert.FromBase64String表达式来转换。

实现方法
具体操作方法如下:

(1) 数据库表设计字符型字段。如下图:


图中的Base64字段类型为varchar(MAX),就是用于保存图片的Base64内容的。

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




当然使用insert语句也可以。


(3) 拖放图片元素到报表
如下图,在一个表格的单元格中拖放一个图片元素:


(4)  设置图片的数据
先展开图片元素的【图片】属性,以便看到更多设置选项,如下图:

再点击【数据】右侧的小方块图标,打开表达式编辑器,输入下面这样的表达式:
{Convert.FromBase64String(Base64)}
如下图:

这个表达式的含义是:将Base64字段值转成二进制的图片。
这样设置后,就可以预览报表了,效果如下图:

其中表格第三列是显示Base64字段的实际字符串内容,最后一列的红色块是实际的图片。










0 个回复

您需要登录后才可以回帖 登录 | 立即注册
返回顶部