0--设计时默认页面设置.rdlc
初始报表设计器画板大小及一些默认值,主要是在rd:InitialDimensions中描述页面大小及默认单位,提供英吋和厘米两种单位,关系约为1Inch = 2.5厘米,注意仅仅是大约,以rd:标记开头,页面大小及左右顶底页边距见名知义。ColumnSpacing描述的是分栏间隔,默认1CM.在Report中定义的Width及Body\Height,其实就是在画板中设计的报表宽与高。
<?xml version="1.0" encoding="utf-8"?>
<Report xmlns="http://schemas.microsoft.com/sqlserver/reporting/2005/01/reportdefinition" xmlns:rd="http://schemas.microsoft.com/SQLServer/reporting/reportdesigner">
<Width>6.5in</Width>
<Body>
<Height>2in</Height>
</Body>
<rd:InitialLanguage>true</rd:InitialLanguage>
<rd:InitialDimensions>
<rd:UnitType>Inch</rd:UnitType>
<rd:LeftMargin>1in</rd:LeftMargin>
<rd:RightMargin>1in</rd:RightMargin>
<rd:TopMargin>1in</rd:TopMargin>
<rd:BottomMargin>1in</rd:BottomMargin>
<rd:PageWidth>8.5in</rd:PageWidth>
<rd:PageHeight>11in</rd:PageHeight>
<rd:ColumnSpacing>0.5in</rd:ColumnSpacing>
</rd:InitialDimensions>
<rd:InitialDimensions>
<rd:UnitType>Cm</rd:UnitType>
<rd:Width>16cm</rd:Width>
<rd:Height>5cm</rd:Height>
<rd:LeftMargin>2.5cm</rd:LeftMargin>
<rd:RightMargin>2.5cm</rd:RightMargin>
<rd:TopMargin>2.5cm</rd:TopMargin>
<rd:BottomMargin>2.5cm</rd:BottomMargin>
<rd:GridSpacing>0.25cm</rd:GridSpacing>
<rd:PageWidth>21cm</rd:PageWidth>
<rd:PageHeight>29.7cm</rd:PageHeight>
<rd:ColumnSpacing>1cm</rd:ColumnSpacing>
</rd:InitialDimensions>
</Report>
这些信息可以单击画板,然后右健查看属性就可以看到Report。
1--Body及页面边框样式及背景设置.rdlc
单击画板上的报表体,然后右健查看属性就可以看到报表真正的页面设置信息了,
其中包括:
分栏信息如分栏数、分栏之间的间距、宽与高(栏,当不分栏时实际就是报表宽高)
格式信息如背景颜色、背景图片、边框(颜色、线样式、线粗),在Style中描述。
我倒觉得Report\Width应放到Report\Body中,也就是类似Report\Body\Height。
这里说说边框,Html中,有个亮边框和暗边框,亮边框就是左边和顶边线,暗边框就是右边和底边线,它们的属性就是颜色。这里搞出一个默认的边框颜色,和Html保持一致,但没有亮、暗边框要领概念了,它搞的更广,干脆就矩形的四边即左、右、顶、底边分析描述。线样式、线粗同样也可以门针对四边进行描述。
值得一提的是,如果指定的图像但图像文件不存在,运行报表时会提示出错。其实没必要嘛,直接跳过去得了,本机的倒好,Internet谁能保证那个图片提供的服务器不Down机啊。于是设置了本机的一个有效图片,运行时提示报表包含外部图片,还要设置EnableExternalImages属性,真是罗嗦:)。
<?xml version="1.0" encoding="utf-8"?>
<Report xmlns="http://schemas.microsoft.com/sqlserver/reporting/2005/01/reportdefinition" xmlns:rd="http://schemas.microsoft.com/SQLServer/reporting/reportdesigner">
<InteractiveWidth>21cm</InteractiveWidth>
<InteractiveHeight>29.7cm</InteractiveHeight>
<rd:GridSpacing>0.25cm</rd:GridSpacing>
<rd:SnapToGrid>true</rd:SnapToGrid>
<rd:ReportID>d9dddd8a-9336-41fb-ad58-7071ffac1a5a</rd:ReportID>
<rd:DrawGrid>true</rd:DrawGrid>
<Language>zh-CN</Language>
<LeftMargin>2.5cm</LeftMargin>
<RightMargin>2.5cm</RightMargin>
<TopMargin>2.5cm</TopMargin>
<BottomMargin>2.5cm</BottomMargin>
<PageHeight>29.7cm</PageHeight>
<PageWidth>21cm</PageWidth>
<Width>8cm</Width>
<Body>
<Columns>2</Columns>
<ColumnSpacing>1cm</ColumnSpacing>
<Height>6cm</Height>
<Style>
<BackgroundColor>Pink</BackgroundColor>
<BackgroundImage>
<Value>MISGoldPrinter.JPG</Value>
<Source>External</Source>
<BackgroundRepeat>NoRepeat</BackgroundRepeat>
</BackgroundImage>
<BorderColor>
<Default>DarkGray</Default>
<Top>Silver</Top>
<Default>DarkGray</Default>
<Left>Lime</Left>
<Right>Red</Right>
</BorderColor>
<BorderStyle>
<Default>Dotted</Default>
</BorderStyle>
<BorderWidth>
<Default>2pt</Default>
</BorderWidth>
</Style>
</Body>
</Report>
2--页眉页脚.rdlc
页眉页脚的概念我想就不用说了,用过word和Excel的都知道。它的属性同Body的Style一样,这里不敖述。
主要是增加特有属性PrintOnFirstPage、PrintOnLastPage表示是否在第一页和最后一页显示。虽然可以指定Width和Height属性,但是Width并不保存在XML文件中,不难不理解,页眉页脚宽就是打印页的宽。
出现With出现在属性中的原因可以想象是由于同一体系中继承的问题。就像MIS金质打印通XML解析器,所有类统一继承并实现一个接口,提供Rectang表示元素所在的打印区,即使是描述一条直线,我们同样也可以看到X、Y、Width和Height属性。
这些信息可以单击画板,然后右健查看PageHeader/Footer属性就可以看到Report。
Body与页眉页脚的区别和联系:
相同点:都是画板即页面的一个打印区,都可作为报表元素的容器,既然是这样,那当然都可以设置样式。
不同点:Body可以分栏,而页眉页脚只是一栏;Body每页都打印,而页眉页脚可以选择首尾页是否打印。
<?xml version="1.0" encoding="utf-8"?>
<Report >
<PageHeader>
<Height>1.25cm</Height>
<PrintOnLastPage>true</PrintOnLastPage>
<PrintOnFirstPage>true</PrintOnFirstPage>
</PageHeader>
<PageFooter>
<Height>1.5cm</Height>
<PrintOnLastPage>true</PrintOnLastPage>
<PrintOnFirstPage>true</PrintOnFirstPage>
</PageFooter>
</Report>
报表元素
上面说了Body与页眉页脚都可作为报表元素的容器。报表元素包括Textbox、Line、Table、Rectangle,其中Rectangle也可作为报表元素的容器。报表元素全部在ReportItems中描述。
3--TextBox.rdlc
同Body一样,TextBox同样具有Style,另外就是描述文本的Value及文本所有矩形区Left、Top、Width、Height,可以指定CanGrow、CanShrink自适应。文本字体、颜色、对齐及边框等在Style中描述,其中PaddingLeft/Right/Top/Bottom描述文本距边框的起点位置。
<Body>
<ReportItems>
<Textbox Name="textbox1">
<Value>Hello World!</Value>
<Left>1cm</Left>
<Top>0.75cm</Top>
<Width>5.5cm</Width>
<Height>0.75cm</Height>
<CanShrink>true</CanShrink>
<CanGrow>true</CanGrow>
<Style>
<Color>SpringGreen</Color>
<FontFamily>宋体</FontFamily>
<FontStyle>Italic</FontStyle>
<FontWeight>700</FontWeight>
<TextDecoration>Underline</TextDecoration>
<TextAlign>Left</TextAlign>
<VerticalAlign>Bottom</VerticalAlign>
<Direction>RTL</Direction>
<PaddingLeft>20pt</PaddingLeft>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>10pt</PaddingTop>
<PaddingBottom>2pt</PaddingBottom>
<BorderColor>
<Default>Red</Default>
</BorderColor>
<BorderStyle>
<Default>Inset</Default>
</BorderStyle>
</Style>
</Textbox>
</ReportItems>
</Body>
4--Line.rdlc
Location和EndPoint存入XML文件时,计算并转换为矩形区Left、Top、Width、Height。
LineColor、LineStyle、LineWidth存入XML文件时保存为Style,相应的对应为BoderColor、BoderStyle、BoderWidth并存入Default标记。
<Body>
<ColumnSpacing>1cm</ColumnSpacing>
<ReportItems>
<Line Name="line1">
<Left>5cm</Left>
<Top>1.25cm</Top>
<Width>6cm</Width>
<Height>0.75cm</Height>
<Label>这是线</Label>
<Visibility>
<Hidden>true</Hidden>
</Visibility>
<Style>
<BorderColor>
<Default>Red</Default>
</BorderColor>
<BorderStyle>
<Default>Dotted</Default>
</BorderStyle>
<BorderWidth>
<Default>2pt</Default>
</BorderWidth>
<FontFamily>宋体</FontFamily>
</Style>
</Line>
</ReportItems>
<Height>5cm</Height>
</Body>
5--Rectangle.rdlc
和Body一样,它可作为报表元素的容器,因此,也有Style下的Boder相关属性,当然,既然是一个矩形,少不了Left、Top、Width、Height属性。PageBreakAtStart、PageBreakAtEnd表示中否在这这前或之后换页。可以在此Rectangle后画一个Line后运行看看效果。但它的有组合在运行时有的却并不是我们想像的。
<Body>
<ReportItems>
<Rectangle Name="rectangle1">
<Left>5.5cm</Left>
<Top>0.75cm</Top>
<Width>7.01058cm</Width>
<Height>2.98942cm</Height>
<PageBreakAtStart>true</PageBreakAtStart>
<PageBreakAtEnd>false</PageBreakAtEnd>
<Style>
<BorderStyle>
<Default>Inset</Default>
</BorderStyle>
<FontFamily>宋体</FontFamily>
<BorderColor>
<Default>DarkOrange</Default>
</BorderColor>
</Style>
</Rectangle>
</ReportItems>
</Body>
6--Image.rdlc
它是在一个矩形区内,所以基本上具有Rectangle的固有属性,只是把把背景图片这个属性专门拿出来。
<Body>
<ReportItems>
<Image Name="image1">
<Source>External</Source>
<Value>c:\MISGoldPrinter.JPG</Value>
<Sizing>AutoSize</Sizing>
<Left>6cm</Left>
<Top>1cm</Top>
<Width>5.74074cm</Width>
<Height>5cm</Height>
</Image>
</ReportItems>
</Body>
7--Char.rdlc
Char基本具有Rectangle的固有属性和TextBox属性,需要数据源的支持。
对于列表(list)和子报表(SubReport),list可作为其它元素的容器。
表格Table,在列数固定和行数可变的网格中显示数据,由TableRows和TableColumns两部分组成。
TableRows在Header、Details、Footer三个部分中描述,每个TableRow由多个TableCell构成,TableCell的内容一般为TextBox,也可以是其它的报表元素,如Rectangle等,唯一不能的是Line。
8--Table.rdlc
Table:
表格在一个矩形区,所以具有Rectangle的属性,当然,它不具有Height,想一想,为什么?同时默认情况下具有TextBox属性,以用来从整体上改变单元格的格式。RepeatHeaderOnNewPage、RepeatFooterOnNewPage属性值分别保存于Header、Footer中的RepeatOnNewPage属性中。
TableColumn:
路径为Report\Body\ReportItems\Table\TableColumns,包含背景、边框、列宽(Width)及是否为固定列FixedHeader。
当然,这是以Body为容器的路径,如果是其它元素或嵌套情况,Report\Body相应的改为容器的路径。以下表示路径时不再特别说明。
如:
<TableColumns>
<TableColumn>
<Width>3cm</Width>
<FixedHeader>true</FixedHeader>
</TableColumn>
...
<TableColumns>
其它的属性一般为所在该列报表元素特有属性,如果设置,则直接保存到特定的报表元素属性描述中,而不是保存在TableColumn中。
Header、Details、Footer:
根据名字可知,它们是描述表头表底固定行数据及表中间可变的数据行。因为有可变行,所以,没有Table不具有Height。RepeatOnNewPage表示是否每页都打印。
以Header为例,路么为Report\Body\ReportItems\Table\Header。
Table及相关的元素的XML文件主体描述如下:
<Body>
<ReportItems>
<Table Name="table1">
<Left>5cm</Left>
<Top>0.75cm</Top>
<Width>7.75132cm</Width>
<PageBreakAtStart>true</PageBreakAtStart>
<PageBreakAtEnd>true</PageBreakAtEnd>
<Style>
<TextAlign>Left</TextAlign>
<FontFamily>宋体</FontFamily>
<Direction>RTL</Direction>
<Color>Red</Color>
<TextDecoration>Underline</TextDecoration>
<FontStyle>Italic</FontStyle>
</Style>
<TableColumns>
<TableColumn>
<Width>3cm</Width>
<FixedHeader>true</FixedHeader>
</TableColumn>
<TableColumn>
<Width>2.24868cm</Width>
</TableColumn>
<TableColumn>
<Width>2.24868cm</Width>
</TableColumn>
</TableColumns>
<Footer>
<RepeatOnNewPage>true</RepeatOnNewPage>
<TableRows>
<TableRow>
<TableCells>
<TableCell>
<ReportItems>
<Textbox Name="textbox7">
<rd:DefaultName>textbox7</rd:DefaultName>
<ZIndex>5</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox8">
<rd:DefaultName>textbox8</rd:DefaultName>
<ZIndex>4</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox9">
<rd:DefaultName>textbox9</rd:DefaultName>
<ZIndex>3</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
</TableCells>
<Height>1.08466cm</Height>
</TableRow>
</TableRows>
</Footer>
<Details>
<TableRows>
<TableRow>
<TableCells>
<TableCell>
<ReportItems>
<Textbox Name="textbox4">
<rd:DefaultName>textbox4</rd:DefaultName>
<ZIndex>2</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox5">
<rd:DefaultName>textbox5</rd:DefaultName>
<ZIndex>1</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox6">
<rd:DefaultName>textbox6</rd:DefaultName>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
</TableCells>
<Height>1.08466cm</Height>
</TableRow>
</TableRows>
</Details>
<Header>
<RepeatOnNewPage>true</RepeatOnNewPage>
<TableRows>
<TableRow>
<TableCells>
<TableCell>
<ReportItems>
<Textbox Name="textbox1">
<rd:DefaultName>textbox1</rd:DefaultName>
<ZIndex>8</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox2">
<rd:DefaultName>textbox2</rd:DefaultName>
<ZIndex>7</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
<TableCell>
<ReportItems>
<Textbox Name="textbox3">
<rd:DefaultName>textbox3</rd:DefaultName>
<ZIndex>6</ZIndex>
<Style>
<PaddingLeft>2pt</PaddingLeft>
<PaddingBottom>2pt</PaddingBottom>
<FontFamily>宋体</FontFamily>
<PaddingRight>2pt</PaddingRight>
<PaddingTop>2pt</PaddingTop>
</Style>
<CanGrow>true</CanGrow>
<Value />
</Textbox>
</ReportItems>
</TableCell>
</TableCells>
</TableRow>
</TableRows>
</Header>
</Table>
</ReportItems>
</Body>
相关连接:
作者Blog:
http://blog.csdn.net/flygoldfish
声明:本文版权为周方勇所有,欢迎转载,请保留完整的内容及出处。
[email protected]