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登录面板
- Trident学习笔记(一)
1. Trident入门 Trident ------------------- 三叉戟 storm高级抽象,支持有状态流处理: 好处是确保消费被处理一次: 以小批次方式处理输入流,得到精准一次性处理 ...
- Java 基本数据类型总结一
Java基本数据类型总结一 基本类型,或者叫做内置类型,是JAVA中不同于类的特殊类型.它们是我们编程中使用最频繁的类型.java是一种强类型语言,第一次申明变量必须说明数据类型,第一次变量赋值称为变 ...
- Git从入门到熟练
Git的特性 1. 分布式版本控制 集中式VS分布式 保存更新时的文件快照而非差异 (快照 :是文件系统中的概念或者技术:来自照相领域的概念,是指特定时间点的一个状态) 其他系统在每个版本中记录着各个 ...
- 用CSS伪元素制作箭头
现在让我们开始制作箭头吧! 在开始前,你要知道如何用CSS去画一个三角形,如果还不清楚可以看看这里纯CSS画各种图形 我们用到两个CSS伪元素,before和after,它们属于行内元素,但可以用di ...
- 剑指Offer - 九度1362 - 左旋转字符串(Move!Move!!Move!!!)
剑指Offer - 九度1362 - 左旋转字符串(Move!Move!!Move!!!)2013-11-23 03:05 题目描述: 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任 ...
- Python全栈工程师(exercises)
# # 练习: # # 1. 用map函数求: # # 1**3 + 2**3 + 3 ** 3 + .... 9**3 的和 def add_(x): return x ** 3 print(sum ...
- UEFI
UEFI,全称Unified Extensible Firmware Interface,即“统一的可扩展固件接口”,是一种详细描述全新类型接口的标准,是适用于电脑的标准固件接口,旨在代替BIOS(基 ...
- 剑指offer-替换空格02
题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. class Solution: ...
- NodeJs01 文件浏览器
ES6常用新语法 前言 是时候学点新的JS了! 为了在学习NodeJs之前,能及时用上语言的新特性,我们打算从一开始先学习一下JavaScript语言的最基本最常用新语法.本课程的内容,是已经假设你有 ...