vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
NEU! sevCoolbar 3.0 - Professionelle Toolbars im modernen Design!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Ein- und Umsteiger
Report Viewer mit Subreports -> could not be shown 
Autor: CLL
Datum: 26.05.10 15:45

Ich habe mich gerade an einem Report mit Subreports versucht, habe aber die bekannte "...could not be shown"-Fehlermeldung anstatt der Subreports in meinem Hauptreport. Die Standartlösung von MSDN habe ich bereits durchgearbeitet, die hat nichts geholfen.

Ich poste jetzt mal meinen Code, vielleicht sieht ja jemand meinen Fehler!

Der "normale" Report (Subreport): UC_Report
Public Class UC_Report
 
    Private m_Reportname As String
    Public WriteOnly Property Reportname() As String
        Set(ByVal value As String)
            m_ReportName = value
        End Set
    End Property
 
...
 
    Public Sub p_Load()
 
        Try
 
            Me.ReportViewer.Reset()
            Me.ReportViewer.ShowProgress = True
            Me.ReportViewer.ShowRefreshButton = False
            Me.ReportViewer.ProcessingMode = ProcessingMode.Local
            Me.ReportViewer.LocalReport.EnableExternalImages = True
 
            Dim oResStream As System.IO.Stream
            oResStream = _
              System.Reflection.Assembly.GetExecutingAssembly.GetManifestResour_
              ceStream(m_Reportname)
            Me.ReportViewer.LocalReport.LoadReportDefinition(oResStream)
 
            Me.ReportViewer.LocalReport.DataSources.Clear()
            Me.ReportViewer.LocalReport.DataSources.Add(New ReportDataSource( _
              m_ReportDatasetname, m_ReportDatatable))
 
            Dim oRepParmsList As New System.Collections.Generic.List(Of _
              ReportParameter)
            oRepParmsList.Add(New ReportParameter("FilterText", m_ReportFilter))
            If Not IsNothing(oRepParmsList) Then
                Me.ReportViewer.LocalReport.SetParameters(oRepParmsList)
            End If
 
            Me.ReportViewer.LocalReport.Refresh()
            Me.ReportViewer.RefreshReport()
            Me.ReportViewer.Refresh()
 
        Catch ex As System.Exception
            Dim strMsg As String = String.Format("{0} - {1}.{2}", ex.Message, _
              MyBase.Name, "p_Load")
            gLogFile.Write(strMsg, True)
        End Try
 
    End Sub
 
    Private Sub ReportViewer_RenderingComplete(ByVal sender As Object, _
                                               ByVal e As _
                                               Microsoft.Reporting.WinForms.Ren_
                                               deringCompleteEventArgs) _
                                               Handles _
                                               ReportViewer.RenderingComplete
 
        Static bPrintLayout As Boolean = False
        If Not bPrintLayout Then
            Me.ReportViewer.SetDisplayMode(DisplayMode.PrintLayout)
            bPrintLayout = True
        End If
 
    End Sub
 
    Private Sub ReportViewer_ReportErReportViewer_ReportErrorror(ByVal sender _
      As Object, _
                                         ByVal e As _
                                         Microsoft.Reporting.WinForms.ReportErr_
                                         orEventArgs) _
                                         Handles ReportViewer.ReportError
 
        Dim strMsg As String = String.Format("{0} - {1}.{2}", _
          e.Exception.Message, MyBase.Name(), "ReportViewer_ReportError")
        '-------------
        gLogFile.Write(strMsg, True)
        '-------------
 
    End Sub
 
End Class
Als darüberliegenden Report habe ich die Klasse kopiert und UC_Report_mS genannt. Darin ist zusätzlich der Code:

Private Subreport As New UC_Report
 
    Private sub_Reportname As String
    Public WriteOnly Property subReportname() As String
        Set(ByVal value As String)
            Subreport.Reportname = value
        End Set
    End Property
 
    Private sub_ReportDatatable As DataTable
    Public WriteOnly Property subReportDatatable() As DataTable
        Set(ByVal value As DataTable)
            Subreport.ReportDatatable = value
        End Set
    End Property
 
    Private sub_ReportDatasetname As String
    Public WriteOnly Property subReportDatasetname() As String
        Set(ByVal value As String)
            Subreport.ReportDatasetname = value
        End Set
    End Property
 
    Private sub_ReportFilter As String
    Public WriteOnly Property subReportFilter() As String
        Set(ByVal value As String)
            Subreport.ReportFilter = value
        End Set
    End Property
 
    Public Sub SubreportProcessingEventHandler(ByVal sender As Object, ByVal e _
      As SubreportProcessingEventArgs)
        e.DataSources.Add(New ReportDataSource(m_ReportDatasetname))
    End Sub
Und im Load:
AddHandler ReportViewer.LocalReport.SubreportProcessing, AddressOf _
  Me.SubreportProcessingEventHandler
Im Report habe ich dann in eine Spalte im Zeilenbereich einen Subreport gezogen und unter Properties sowohl den Reportnamen, als auch den notwendigen Parameter angegeben.

Kann mir jemand sagen was noch fehlt / falsch ist?
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Report Viewer mit Subreports -> could not be shown2.695CLL26.05.10 15:45
Re: Report Viewer mit Subreports -> could not be shown1.462CLL08.06.10 14:31
Re: Report Viewer mit Subreports -> could not be shown1.483CLL08.06.10 15:18

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel