Intégrer Reporting Services à l’aide de l’accès URL - Application Windows
Même si l'accès URL à un serveur de rapports est optimisé pour un environnement Web, vous pouvez également utiliser l'accès URL pour incorporer des rapports Reporting Services dans une application Microsoft Windows. Toutefois, l'accès URL qui nécessite des Windows Forms requiert toujours l'utilisation de la technologie du navigateur Web. Vous pouvez utiliser les scénarios d'intégration suivants avec l'accès URL et les Windows Forms :
Afficher un rapport dans une application Windows Form en démarrant un navigateur Web par programme.
Utiliser le contrôle WebBrowser sur un Windows Form pour afficher un rapport.
Démarrer Internet Explorer à partir d’un Windows Form
Vous pouvez utiliser la classe Process pour accéder à un processus qui s'exécute sur un ordinateur. La classe Process est une construction Microsoft .NET Framework utile pour démarrer, arrêter, contrôler et surveiller des applications. Pour consulter un rapport spécifique dans votre base de données du serveur de rapports, vous pouvez démarrer le processus IExplore, en passant l’URL au rapport. L’exemple de code suivant peut être utilisé pour démarrer Microsoft Internet Explorer et passer une URL de rapport spécifique lorsque l’utilisateur sélectionne un bouton sur un Windows Form.
Private Sub viewReportButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles viewReportButton.Click
' Build the URL access string based on values supplied by a user
Dim url As String = serverUrlTextBox.Text + "?" & reportPathTextBox.Text & _
"&rs:Command=Render" & "&rs:Format=HTML4.0"
' If the user does not select the toolbar check box,
' turn the toolbar off in the HTML Viewer
If toolbarCheckBox.Checked = False Then
url += "&rc:Toolbar=False"
End If
' load report in the Web browser
Try
System.Diagnostics.Process.Start("IExplore", url)
Catch
MessageBox.Show("The system could not start the specified report using Internet Explorer.", _
"An error has occurred", MessageBoxButtons.OK, MessageBoxIcon.Error)
End Try
End Sub 'viewReportButton_Click
// Sample click event for a Button control on a Windows Form
private void viewReportButton_Click(object sender, System.EventArgs e)
{
// Build the URL access string based on values supplied by a user
string url = serverUrlTextBox.Text + "?" + reportPathTextBox.Text +
"&rs:Command=Render" + "&rs:Format=HTML4.0";
// If the user does not check the toolbar check box,
// turn the toolbar off in the HTML Viewer
if (toolbarCheckBox.Checked == false)
url += "&rc:Toolbar=False";
// load report in the Web browser
try
{
System.Diagnostics.Process.Start("IExplore", url);
}
catch (Exception)
{
MessageBox.Show(
"The system could not open the specified report using Internet Explorer.",
"An error has occurred", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
Incorporer un contrôle de navigateur sur un Windows Form
Si vous ne souhaitez pas afficher votre rapport dans un navigateur Web externe, vous pouvez incorporer un navigateur Web de manière transparente dans le cadre de votre Windows Form à l’aide du WebBrowser contrôle.
Pour ajouter le contrôle WebBrowser à votre Windows Form
Créez une application Windows dans Microsoft C# ou Microsoft Visual Basic.
Localisez le contrôle WebBrowser dans la boîte de dialogue Boîte à outils.
Si la boîte à outils n’est pas visible, vous pouvez y accéder en sélectionnant l’élément de menu Affichage et en sélectionnant Boîte à outils.
Faites glisser le contrôle WebBrowser vers l’aire de conception de votre Windows Form.
Le contrôle WebBrowser nommé webBrowser1 est ajouté au Formulaire
Dirigez le contrôle WebBrowser vers une URL en appelant sa méthode Navigate. Vous pouvez assigner une chaîne d'accès URL spécifique à votre contrôle WebBrowser au moment de l'exécution comme l'illustre l'exemple suivant.
Dim url As String = "https://localhost/reportserver?/" & _
"AdventureWorks Sample Reports/" & _
"Company Sales&rs:Command=Render"
WebBrowser1.Navigate(url)
string url = "https://localhost/reportserver?/" +
"AdventureWorks Sample Reports/" +
"Company Sales&rs:Command=Render";
webBrowser1.Navigate(url);