Reporting Service报表水印的添加
上一篇文章寫到了自帶報表的製作,現在來談談報表水印的添加
1:水印產生代碼
- using System;
- using System.Data;
- using System.Configuration;
- using System.Drawing;
- using System.Drawing.Imaging;
- /// <summary>
- /// WatermarkCreater 的摘要描述
- /// </summary>
- public class WatermarkCreater
- {
- public WatermarkCreater()
- {
- //
- // TODO: 在此加入建構函式的程式碼
- //
- }
- private Bitmap CreateImage(string code, string width, string height, string pLeft, string pTop, string font, string fColor, string bColor, string r)
- {
- Color cF = Color.FromArgb(int.Parse(fColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier), int.Parse(fColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier), int.Parse(fColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier));
- Color cB = Color.FromArgb(int.Parse(bColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier), int.Parse(bColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier), int.Parse(bColor.Substring(, ), System.Globalization.NumberStyles.AllowHexSpecifier));
- System.Drawing.SolidBrush sb = new SolidBrush(cF);
- string[] fstr = font.Split(',');
- Font f = new Font(fstr[].Split('=')[], (float)Convert.ToInt32(fstr[].Split('=')[]), FontStyle.Regular, (GraphicsUnit)Convert.ToInt32(fstr[].Split('=')[]), Convert.ToByte(fstr[].Split('=')[]), Convert.ToBoolean(fstr[].Split('=')[]));
- Bitmap bmp = new Bitmap(Convert.ToInt32(width), Convert.ToInt32(height));
- Graphics g = Graphics.FromImage(bmp);
- g.Clear(Color.White);
- g.RotateTransform((float)Convert.ToDouble(r));
- g.DrawString(code, f, sb, new PointF(Convert.ToInt32(pLeft), Convert.ToInt32(pTop)));
- return bmp;
- }
- public byte[] GetImageByte(string code, string config)
- {
- string[] configs = config.Split(';');
- Bitmap im = CreateImage(code, configs[].Split(':')[], configs[].Split(':')[], configs[].Split(':')[], configs[].Split(':')[], configs[], configs[].Split(':')[], configs[].Split(':')[], configs[].Split(':')[]);
- System.IO.MemoryStream ms = new System.IO.MemoryStream();
- im.Save(ms, ImageFormat.Bmp);
- return ms.GetBuffer();
- }
- }
2:把水印保存到數據庫,數據庫類型為image
3:把水印查詢出來,作為數據源傳進報表,然後在報表的背景添加即可
Reporting Service报表水印的添加的更多相关文章
- Dynamic CRM 2013学习笔记(二十九)报表设计:reporting service 报表开发常见问题
在报表开发过程中,经常会遇到各种各样的问题,比如The report cannot be displayed. (rsProcessingAborted),一点有意义的提示都没有:再就是分页问题,经常 ...
- Reporting Service报表项默认可见+号和-号的显示问题
在Reporting Service里面可以设置报表项(组.tablix行.tablix列.文本框等所有SSRS报表项)的可见性,并且可以设置某个报表项的可见性由点击另外一个报表项来控制,比如报表项A ...
- Dynamic CRM 2013学习笔记(二十六)报表设计:Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色
上次介绍过CRM里开始报表的一些注意事项:Dynamic CRM 2013学习笔记(十五)报表入门.开发工具及注意事项,本文继续介绍报表里的一些动态效果:动态显示参数,参数是从数据库里查询出来的:参数 ...
- SQL Server性能计数器收集汇总方案(Reporting Service)
通过收集计数器信息,并将计数器信息汇总为不同粒度存储,以Reporting Service报表服务器显示.以下是计数器收集汇总的基本架构. 笔者需要收集的SQL Server计数器包括:SQL Ser ...
- Reporting Service 2008 “报表服务器数据库内出错。此错误可能是因连接失败、超时或数据库中磁盘空间不足而导致的”
今天遇到了两个关于Reporting Service的问题, 出现问题的环境为Microsoft SQL Server 2008 R2 (SP2) - 10.50.4000.0 (X64) .具体情况 ...
- SQL Server Reporting Service(SSRS) 第二篇 SSRS数据分组Parent Group
SQL Server Reporting Service(SSRS) 第一篇 我的第一个SSRS例子默认使用Table进行简单的数据显示,有时为了进行更加直观的数据显示,我们需要按照某个字段对列表进行 ...
- SQL Server Reporting Service(SSRS) 第一篇 我的第一个SSRS例子
很早就知道SQL SERVER自带的报表工具SSRS,但一直没有用过,最近终于需要在工作中一展身手了,于是我特地按照自己的理解做了以下总结: 1. 安装软件结构 SSRS全称SQL Server Re ...
- 【解决】SharePoint集成模式下Reporting Service—为用户授予的权限不足,无法执行此操作。 (rsAccessDenied)
环境:Windows Server 2008 R2 SP1,SharePoint 2010 企业版,SQL Server 2008 R2 Reporting Service(SharePoint集成模 ...
- Reporting Service部署之访问权限
原文:Reporting Service部署之访问权限 SQL Server Reporting Services 并非专门设计用于 Internet 报表部署方案,但是您可以成功地将 Reporti ...
随机推荐
- qq登录面板
- win7重装后恢复grub和ubuntu14
没有光盘和优盘启动盘,可以在win7下安装easybcd,添加一个启动选项为linux grub2,启动后进入ubutnu,执行如下: sudo -i //取得root权限 fdisk -l ...
- 《Cracking the Coding Interview》——第13章:C和C++——题目3
2014-04-25 19:42 题目:C++中虚函数的工作原理? 解法:虚函数表?细节呢?要是懂汇编我就能钻的再深点了.我试着写了点测大小.打印指针地址之类的代码,能起点管中窥豹的作用,从编译器的外 ...
- CSS系列(6) CSS通配符详解
通配符使用星号*表示,意思是“所有的”. 平时使用电脑,比如要搜索C盘里所有的网页,可以使用 *.html来搜索,.html是网页的后缀名,*代表了所有网页的名称: 也就是使用 * 加后缀名,就可以在 ...
- ffifdyop
题目地址:http://www.shiyanbar.com/ctf/2036 后台登陆 上来看到这个界面,果断先看一波源代码. 看到是拼接字符串进行sql查询,就想到了注入了. 但是很不幸的是md5( ...
- Unity-SendMessage
每一个对象都有SendMessage,BroadcastMessage,SendMessageUpwards 三个发送消息的方法! 1.功能: 执行某个对象中的某个方法! 2.实现原理 反射 ...
- css深入理解vertical-align
第一讲:vertical-align家族基本认识 了解vertical-align支持的属性值以及组成 属性: 1.inherit 2.线类 baseline,top,middle,bottom 3. ...
- django orderby
https://www.douban.com/group/topic/44329052/
- 【linux】如何解决VMWare上linux虚拟机连不上外网的问题?
>>>故障现象:虚拟机连接不到外网? >>>故障背景: Centos7.4发行版本: 虚拟机和VM软件都是nat模式: 注意这里默认的VMWare的DHCP服务时开 ...
- nagios服务端安装
系统环境:操作系统:CentOS-5.7 x86_64Apache版本: Apache-2.2.22Nagios版本: nagios-3.3.1GD库: gd-2.0.33 2.安装前准备:2.1.安 ...