Compartir a través de


Clase LocalReport

Representa un informe que se procesa y se representa localmente sin conectarse a un servidor de informes.

Espacio de nombres: Microsoft.Reporting.WinForms
Ensamblado: Microsoft.ReportViewer.WinForms (en microsoft.reportviewer.winforms.dll)

Sintaxis

'Declaración
<SerializableAttribute> _
Public NotInheritable Class LocalReport
    Inherits Report
    Implements ISerializable
'Uso
Dim instance As LocalReport
[SerializableAttribute] 
public sealed class LocalReport : Report, ISerializable
[SerializableAttribute] 
public ref class LocalReport sealed : public Report, ISerializable
/** @attribute SerializableAttribute() */ 
public final class LocalReport extends Report implements ISerializable
SerializableAttribute 
public final class LocalReport extends Report implements ISerializable

Comentarios

La clase LocalReport representa los informes que se procesan y se representan localmente sin conectarse a un servidor de informes. Esta clase es el mismo objeto que utiliza el control ReportViewer, pero también se puede utilizar independientemente como un objeto no visual que encapsula la principal funcionalidad del control ReportViewer.

El objeto LocalReport puede abrir los archivos de definición de informes de cliente (RDLC) desde el sistema de archivos, o el archivo RDLC puede suministrarse como Stream o TextReader.

El objeto LocalReport no posee la capacidad para ejecutar consultas o capturar datos, sino que los datos deben suministrarse como instancias de DataTables de ADO.NET o como una colección de objetos empresariales.

El objeto LocalReport admite el uso de parámetros de informe, pero no parámetros de consulta.

Ejemplo

En el siguiente fragmento de código, se utiliza un objeto LocalReport para cargar y exportar un informe.

private void button1_Click(object sender, EventArgs e)
{

   Microsoft.Reporting.WinForms.LocalReport lr = new Microsoft.Reporting.WinForms.LocalReport();

   string deviceInfo =
     "<DeviceInfo>" +
     "<SimplePageHeaders>True</SimplePageHeaders>" + 
     "</DeviceInfo>";

   lr.ReportPath = @"C:\My Reports\Monthly Sales.rdlc";

   lr.DataSources.Add(new ReportDataSource("Sales", GetSalesData()));

   byte[] bytes = lr.Render("Excel", deviceInfo, out mimeType, 
     out encoding, out streamids, out warnings);

      using (FileStream fs = = new FileStream(@"c:\My Reports\Monthly Sales.xls", FileMode.Create))
      {
        fs.Write(bytes, 0, bytes.Length);
        fs.Close();
      }
}
Private Sub Button1_Click(ByVal sender As System.Object, _
   ByVal e As System.EventArgs) Handles Button1.Click
   Dim warnings As Warning() = Nothing
   Dim streamids As String() = Nothing
   Dim mimeType As String = Nothing
   Dim encoding As String = Nothing
   Dim extension As String = Nothing
   Dim deviceInfo as string
   Dim bytes As Byte()

   deviceInfo = "< deviceInfo ><SimplePageHeaders>True</SimplePageHeaders></DeviceInfo>"

   bytes = ReportViewer1.LocalReport.Render("Excel", Nothing, _
     mimeType,encoding, extension, streamids, warnings)

   Dim fs As New FileStream("c:\output.xls", FileMode.Create)
   fs.Write(bytes, 0, bytes.Length)
   fs.Close()

   MessageBox.Show("Report exported to output.xls", "Info")
End Sub

Jerarquía de herencia

System.Object
   Microsoft.Reporting.WinForms.Report
    Microsoft.Reporting.WinForms.LocalReport

Seguridad de subprocesos

Todos los miembros estáticos (compartidos en Visual Basic) públicos de este tipo tienen subprocesos seguros. Los miembros de ninguna instancia tienen la garantía de que los subprocesos sean seguros.

Consulte también

Referencia

Miembros LocalReport
Espacio de nombres Microsoft.Reporting.WinForms