原創(chuàng)|其它|編輯:郝浩|2012-09-27 14:29:33.000|閱讀 422 次
概述:默認情況下, 由于表格是一個“所見即所得”的控件,DXGrid以一種簡單的表格格式被導出和打印。但是你仍然可以調節(jié)表格打印的外觀。這篇文章講述了怎樣使用表格 的打印模板和選項來創(chuàng)建你自己特定的打印外觀。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
默認情況下, 由于表格是一個“所見即所得”的控件,DXGrid以一種簡單的表格格式被導出和打印。但是你仍然可以調節(jié)表格打印的外觀。這篇文章講述了怎樣使用表格 的打印模板和選項來創(chuàng)建你自己特定的打印外觀。但是, 如果你想得到全部的自定義數(shù)據打印外觀,歡迎你考慮使用我們的 產品,它會提供給你一種創(chuàng)建自定義報告的強大而靈活的方式 。
默認情況下, 表格是作為一個簡單的表來打印 。它的寬度被調節(jié)成適應一個報告頁面,你能夠通過設置打印自動寬度為False來切換自動寬度。
你可以通過分別設置打印列表頭和打印總摘要屬性為false來從打印視圖上移除頭部和底部
每一個表格打印部分的外觀可以被重定義。因此,你能使用PrintHeaderTemplate 屬性來設置自定義表頭。
[XML]
<dxg:GridControl.Resources> <DataTemplate x:Key="CustomPrintHeaderTemplate"> <Grid> <Rectangle RadiusX="5" RadiusY="5" Fill="Red" dxp:ExportSettings.TargetType="Image"/> <dxe:TextEdit Text="Custom header template" IsPrintingMode="True" Width="{Binding Path=Content.(dxg:GridPrintingHelper.PrintRowInfo).TotalHeaderWidth}" FontSize="20"/> </Grid> </DataTemplate> you </dxg:GridControl.Resources> <dxg:GridControl.View> <dxg:TableView PrintHeaderTemplate="{StaticResource CustomPrintHeaderTemplate}"/> </dxg:GridControl.View>
如果你想獲取表頭模板的 column headers文本,你可以使用以下的綁定聲明:
[XML]
<dxe:TextEdit Text="{Binding Path=Content.View.DataControl.Columns[ColumnName].HeaderCaption}"/>
注意:被放置在表頭模板中的TextEdit 擁有一個設置為true的 IsPrintMode屬性,Rectangle控件有一個ExportSettings.TargetType。打印模板中所使用的所有控件必須被調整以便打印。因此,任何從BaseEdit繼承的控件都必須將IsPrintingMode屬性設置為true。
其他的每個控件必須通過ExportSettings 屬性來調節(jié)打印。因此,它必須要提供ExportSettings.TargetType屬性值。這個屬性被定義在 xmlns:dxp="http://schemas.devexpress.com/winfx/2008/xaml/printing" 命名空間中,并指定如何利用打印系統(tǒng)來利用該控件。
例如, 如果你想打印TextBlock, 必須將ExportSettings.TargetType指定為文本,這樣TextBlock才會被打印。如果你想設置一些控件的背景和前景,你應該分別設置ExportSettings.Background和ExportSettings.Foreground。
[XML]
<TextBlock Text="Textblock text" Margin="10" Foreground="Red" dxp:ExportSettings.TargetType="Text" dxp:ExportSettings.Background="White" dxp:ExportSettings.Foreground="Red" />
形狀和復合控件可以作為圖形導出:
[XML]
<Ellipse Fill="Yellow" Width="15" Height="15" dxp:ExportSettings.TargetType="Image" dxp:ExportSettings.Background="Transparent" />
如何你的打印模板內有一些面板,你應該在面板中設置ExportSettings.TargetType屬性,以便打印的子系統(tǒng)處理子元素。
[XML]
<StackPanel Orientation="Horizontal" dxp:ExportSettings.TargetType="Panel"> <TextBlock Text="Property: " Margin="2" dxp:ExportSettings.TargetType="Text"/> <TextBlock Text="Value" Margin="2" dxp:ExportSettings.TargetType="Text"/> </StackPanel>
如果一個控件沒有指定導出設置類型,控件將會被打印子系統(tǒng)忽視,它將會在打印文檔中丟失。這也適用于在IsPrintingMode屬性沒有設置的編輯器中。
表格底部模板可以以它在頭部模板中定義的方式來同樣被定義。
[XML]
<dxg:GridControl.Resources> <DataTemplate x:Key="CustomPrintFooterTemplate"> <dxe:TextEdit IsPrintingMode="True" Width="{Binding Path=Content.(dxg:GridPrintingHelper.PrintRowInfo).TotalHeaderWidth}" Text="{Binding Path=Path=Content.View.DataControl.Columns[ColumnName].TotalSummaryText, Mode=OneWay}" /> </DataTemplate> </dxg:GridControl.Resources>
PrintRowTemplate屬性定義了一個用于顯示每一行表格的模板。在這里你可以放置你的行單元值去顯示一個行內容。模板的DataContext.Content屬性中有一個RowData類對象。為了簡化針對在這個模板上行單元值的綁定表達式 ,你可以通過以下的代碼來定義模板布局:
[XML]
<DataTemplate x:Key="CustomPrintRowTemplate"> <ContentControl Foreground="{Binding Foreground, RelativeSource={RelativeSource TemplatedParent}}"> <Grid DataContext="{Binding DataContext.Content.Row, RelativeSource={RelativeSource TemplatedParent}}" Width="{Binding Path=DataContext.Content.(dxg:GridPrintingHelper.PrintRowInfo).TotalHeaderWidth, ElementName=contentControl}" > <Rectangle RadiusX="5" RadiusY="5" Fill="Red" dxp:ExportSettings.TargetType="Image"/> <dxe:ImageEdit Source="{Binding Path=Photo}" IsPrintingMode="True"/> <dxe:TextEdit EditValue="{Binding FirstName}" IsPrintingMode="True"/> </Grid> </ContentControl> </DataTemplate>
本站文章除注明轉載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:DevExpress中文網