Integrazione con Microsoft Report Viewer in modalità locale
Microsoft Report Viewer è un potente controllo .NET che consente di utilizzare i report RDL e RDLC nelle applicazioni WinForms e ASP.NET. Consente agli utenti di visualizzare ed esportare report in diversi formati. Il controllo è incluso con Microsoft Visual Studio 2005 e 2008 ed è disponibile anche come download gratuito da Microsoft.
Visualizzatore report può generare report in modo indipendente utilizzando un motore integrato (noto come “modalità locale”) oppure può visualizzare report generati su un server di report di SQL Server Reporting Services Microsoft (“modalità remota”):
- In modalità remota, Report Viewer può esportare report in tutti i formati installati sul Report Server a cui è connesso. Pertanto, per esportare i report in più formati Excel Microsoft è sufficiente installare Aspose.Cells for Reporting Services sul server.
- In modalità locale, tuttavia, Visualizzatore report non si connette a un server di report e l’elenco dei formati di esportazione è limitato solo a pochi formati incorporati.
Installando Aspose.Cells for Reporting Services su un computer di sviluppo e seguendo i passaggi seguenti, è possibile esportare in più formati Excel Microsoft da Report Viewer lavorando in modalità locale.
Lavorare con Aspose.Cells in modalità locale
-
RiferimentoAspose.Cells.ReportingServices.dll nel progetto:
-
Apri il progetto in Visual Studio.
-
Fare clic con il pulsante destro del mouse suRiferimenti cartella e selezionareAggiungi riferimento.
-
Selezionare ilNavigare scheda e passare al seguente assieme:
/ReportView/Aspose.Cells.ReportingServices.dll (dove è la directory in cui hai installato o decompresso Aspose.Cells for Reporting Services. Aggiunta di un riferimento a Aspose.Cells.ReportingServices.dll a un progetto
- Copia e incolla il seguente metodo AddExtension nel progetto. Questo metodo aggiunge l’estensione per il rendering specificata all’elenco delle estensioni supportate in Visualizzatore report Microsoft utilizzando la riflessione privata.
C#
using System.Collections;
using System.Reflection;
using Microsoft.ReportingServices.ReportRendering;
// Use one of the two namespaces below depending on whether you are developing
// a WinForms or WebForms application.
using Microsoft.Reporting.WinForms;
// -- or --
// using Microsoft.Reporting.WebForms;
/// <summary>
/// Adds the specified rendering extension to the specified ReportViewer instance.
/// </summary>
/// <param name="viewer">A ReportViewer control instance.</param>
/// <param name="formatName">The name of the export format to appear on the dropdown list.</param>
/// <param name="extensionType">The class of the rendering extension to add.</param>
private static void AddExtension(ReportViewer viewer, string formatName, Type extensionType)
{
const BindingFlags flags = BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance;
// CommonService.ListRenderingExtension is an internal method that returns a list of supported
// rendering extensions. This list is also stored in a class field so we can simply get this list
// and add Aspose.Cells for Reporting Services rendering extensions to make Microsoft Excel
// export formats appear on the dropdown.
// Get the service type.
FieldInfo previewService = viewer.LocalReport.GetType().GetField("m_previewService", flags);
// Get the ListRenderingExtensions method info.
MethodInfo listRenderingExtensions = previewService.FieldType.GetMethod("ListRenderingExtensions", flags);
// Obtan a list of existing rendering extensions.
IList extensions = listRenderingExtensions.Invoke(previewService.GetValue(viewer.LocalReport), null) as IList;
// LocalRenderingExtensionInfo is a class that holds information about a rendering extension.
// We should create an instance of this class to add the info about the specified extension.
// Since the IRenderingExtension interface is defined in the Microsoft.ReportViewer.Common
// assembly, use this trick to obtain the corresponding Assembly instance. This will work for
// both Report Viewer 2005 (8.0) and 2008 (9.0).
Assembly commonAssembly = typeof(IRenderingExtension).Assembly;
// Now, get the LocalRenderingExtensionInfo type as it is defined in the same assembly.
Type localRenderingExtensionInfoType = commonAssembly.GetType("Microsoft.Reporting.LocalRenderingExtensionInfo");
// Get the LocalRenderingExtensionInfo constructor info.
ConstructorInfo ctor = localRenderingExtensionInfoType.GetConstructor(flags,
null,
new Type[] { typeof(string), typeof(string), typeof(bool), typeof(Type), typeof(bool) },
null);
// Create an instance of LocalRenderingExtensionInfo.
object instance = ctor.Invoke(new object[] { formatName, formatName, true, extensionType, true });
// Finally, add the info about our rendering extension to the list.
extensions.Add(instance);
}
V.B. .NET
Imports System.Collections
Imports System.Reflection
Imports Microsoft.ReportingServices.ReportRendering
// Use one of the two namespaces below depending on whether you are developing
// a WinForms or WebForms application.
Imports Microsoft.Reporting.WinForms
// -- or --
// Imports Microsoft.Reporting.WebForms
'' Adds the specified rendering extension to the specified ReportViewer instance.
Private Shared Sub AddExtension(ByVal viewer As ReportViewer, ByVal formatName As String, ByVal extensionType As Type)
Const flags As BindingFlags = BindingFlags.NonPublic Or BindingFlags.Public Or BindingFlags.Instance
' CommonService.ListRenderingExtension is an internal method that returns a list of supported
' rendering extensions. This list is also stored in a class field so we can simply get this list
' and add Aspose.Cells for Reporting Services rendering extensions to make Microsoft Excel
' export formats appear on the dropdown.
' Get the service type.
Dim previewService As FieldInfo = viewer.LocalReport.GetType().GetField("m_previewService", flags)
' Get the ListRenderingExtensions method info.
Dim listRenderingExtensions As MethodInfo = previewService.FieldType.GetMethod("ListRenderingExtensions", flags)
' Obtan a list of existing rendering extensions.
Dim extensions As IList = TryCast(listRenderingExtensions.Invoke(previewService.GetValue(viewer.LocalReport), Nothing), IList)
' LocalRenderingExtensionInfo is a class that holds information about a rendering extension.
' We should create an instance of this class to add the info about the specified extension.
' Since the IRenderingExtension interface is defined in the Microsoft.ReportViewer.Common assembly, use this trick
' to obtain the corresponding Assembly instance. This will work for both Report Viewer 2005 (8.0) and 2008 (9.0).
Dim commonAssembly As System.Reflection.Assembly = GetType(IRenderingExtension).Assembly
' Now, get the LocalRenderingExtensionInfo type as it is defined in the same assembly.
Dim localRenderingExtensionInfoType As Type = commonAssembly.GetType("Microsoft.Reporting.LocalRenderingExtensionInfo")
' Get the LocalRenderingExtensionInfo constructor info.
Dim ctor As ConstructorInfo = localRenderingExtensionInfoType.GetConstructor(flags, Nothing, New Type() { GetType(String), GetType(String), GetType(Boolean), GetType(Type), GetType(Boolean) }, Nothing)
' Create an instance of LocalRenderingExtensionInfo.
Dim instance As Object = ctor.Invoke(New Object() { formatName, formatName, True, extensionType, True })
' Finally, add the info about our rendering extension to the list.
extensions.Add(instance)
End Sub
- Richiamare il metodo AddExtension dal codice. È possibile chiamare AddExtension (mostrato nel passaggio precedente) ogni volta che è necessario aggiungere i formati di esportazione Aspose.Cells for Reporting Services a un’istanza di controllo Visualizzatore report. Prendi in considerazione la possibilità di chiamare dal modulo_Carica o Pagina_Carica il gestore eventi di un’applicazione WinForms o ASP .NET.
- È possibile aggiungere tutti o solo alcuni formati di esportazione Aspose.Cells for Reporting Services. È possibile specificare qualsiasi nome visualizzato per i formati da visualizzare in Report Viewer. Per aggiungere i formati di esportazione Aspose.Cells for Reporting Services al Visualizzatore report Microsoft in modalità locale, utilizzare il seguente codice:
C#
AddExtension(reportViewer1, "Xls - Xls via Aspose.Cells", typeof(Aspose.Cells.ReportingServices.XlsRenderer));
AddExtension(reportViewer1, "Xlsx - Xlsx via Aspose.Cells", typeof(Aspose.Cells.ReportingServices.Excel2007XlsxRenderer));
AddExtension(reportViewer1, "CSV - CSV via Aspose.Cells", typeof(Aspose.Cells.ReportingServices.CSVRenderer));
AddExtension(reportViewer1, "SpreadsheetML - SpreadsheetML via Aspose.Cells", typeof(Aspose.Cells.ReportingServices.SpreadsheetMLRenderer));
AddExtension(reportViewer1, "Txt - TabDelimited text via Aspose.Cells", typeof(Aspose.Cells.ReportingServices.TabDelimitedRenderer));
V.B. .NET
AddExtension(reportViewer1, "Xls - Xls via Aspose.Cells", GetType (Aspose.Cells.ReportingServices.XlsRenderer));
AddExtension(reportViewer1, "Xlsx - Xlsx via Aspose.Cells", GetType (Aspose.Cells.ReportingServices.Excel2007XlsxRenderer));
AddExtension(reportViewer1, "CSV - CSV via Aspose.Cells", GetType (Aspose.Cells.ReportingServices.CSVRenderer));
AddExtension(reportViewer1, "SpreadsheetML - SpreadsheetML via Aspose.Cells", GetType (Aspose.Cells.ReportingServices.SpreadsheetMLRenderer));
AddExtension(reportViewer1, "Txt - TabDelimited text via Aspose.Cells", GetType (Aspose.Cells.ReportingServices.TabDelimitedRenderer));
- Prova i nuovi formati di esportazione.
- Esegui la tua applicazione. Dovresti notare una serie di nuovi formati di esportazione disponibili inEsportare menu nel Visualizzatore rapporti.
- Selezionare uno dei formati ed eseguire l’esportazione.
- Verificare che il documento sia stato creato nel modo previsto.
I nuovi formati di esportazione vengono visualizzati nel Visualizzatore report in esecuzione in modalità locale