Associare controlli WPF a un servizio di dati WCF
In questa procedura dettagliata, verrà creata un'applicazione WPF contenente i controlli associati a dati. I controlli sono associati ai record dei clienti incapsulati in un servizio dati WCF. Verranno inoltre aggiunti i pulsanti che i clienti possono usare per visualizzare e aggiornare i record.
In questa procedura dettagliata sono illustrati i task seguenti:
Creazione di un modello Entity Data Model generato dai dati nel database di esempio AdventureWorksLT.
Creazione di un servizio dati WCF che espone i dati in Entity Data Model a un'applicazione WPF.
Creazione di un set di controlli associati a dati mediante il trascinamento di elementi dalla finestra Origini dati in WPF Designer.
Creazione di pulsanti per spostarsi avanti e indietro tra i record cliente.
Creazione di un pulsante che salva le modifiche ai dati nei controlli nel servizio dati WCF e nell'origine dati sottostante.
Nota
I nomi o i percorsi visualizzati per alcuni elementi dell'interfaccia utente di Visual Studio in questo articolo potrebbero essere diversi nel computer in uso. È possibile usare un'edizione diversa di Visual Studio o impostazioni di ambiente diverse. Per altre informazioni, vedere Personalizzare l'IDE.
Prerequisiti
Per completare questa procedura dettagliata, è necessario disporre dei componenti seguenti:
Visual Studio
Accesso a un'istanza in esecuzione di SQL Server o SQL Server Express con il database di esempio AdventureWorksLT associato. Per scaricare il database, vedere Database di esempio AdventureWorks
Per completare la procedura dettagliata è inoltre consigliabile conoscere già i concetti seguenti:
Modelli di dati in WCF Data Services.
Modelli di Entity Data Model e ADO.NET Entity Framework. Per altre informazioni, vedere Panoramica di Entity Framework.
Data binding WPF. Per altre informazioni, vedere Panoramica sul data binding.
Creare il progetto di servizio
Per iniziare questa procedura dettagliata, creare un progetto di applicazione Web C# o Visual Basic ASP.NET. Denominare il progetto AdventureWorksService.
In Esplora soluzioni fare clic con il pulsante destro del mouse su Default.aspx e scegliere Elimina. Questo file non è necessario per la procedura dettagliata.
Creare un modello di dati di entità per il servizio
Per esporre i dati a un'applicazione usando un servizio dati WCF, è necessario definire un modello di dati per il servizio. WCF Data Service supporta due tipi di modelli di dati: Entity Data Models e modelli di dati personalizzati definiti tramite oggetti CLR (Common Language Runtime) che implementano l'interfaccia IQueryable<T> . In questa procedura dettagliata, viene creato un modello Entity Data Model per il modello di dati.
Dal menu Progetto fare clic su Aggiungi nuovo elemento.
Nell'elenco Modelli installati fare clic su Dati, quindi selezionare l'elemento di progetto ADO.NET Entity Data Model.
Modificare il nome in
AdventureWorksModel.edmx
e fare clic su Aggiungi.Verrà aperta la Procedura guidata Entity Data Model.
Nella pagina Scegli contenuto del modello fare clic su Genera da database, quindi su Avanti.
Nella pagina Seleziona connessione dati selezionare una delle opzioni seguenti:
Se nell'elenco a discesa è disponibile una connessione dati al database di esempio AdventureWorksLT, selezionarla.
Fare clic su Nuova connessione e creare una connessione al database AdventureWorksLT.
Nella pagina Scegli connessione dati verificare che l'opzione Salva le impostazioni di connessione entità in App.Config sia selezionata e quindi selezionare Avanti.
Nella pagina Seleziona oggetti di database espandere Tabelle, quindi selezionare la tabella SalesOrderHeader.
Fare clic su Fine.
Creare il servizio
Creare un servizio dati WCF per esporre i dati in Entity Data Model a un'applicazione WPF:
Nel menu Progetto selezionare Aggiungi nuovo elemento.
Nell'elenco Modelli installati fare clic su Web, quindi selezionare l'elemento di progetto WCF Data Services.
Nella casella Nome digitare
AdventureWorksService.svc
e fare clic su Aggiungi.Visual Studio aggiunge l'oggetto
AdventureWorksService.svc
al progetto.
Configurare il servizio
È necessario configurare il servizio in modo da usare il modello Entity Data Model creato:
Nel file di
AdventureWorks.svc
codice sostituire la dichiarazione di classe AdventureWorksService con il codice seguente.public class AdventureWorksService : DataService<AdventureWorksLTEntities> { // This method is called only once to initialize service-wide policies. public static void InitializeService(IDataServiceConfiguration config) { config.SetEntitySetAccessRule("SalesOrderHeaders", EntitySetRights.All); } }
Questo codice aggiorna la classe AdventureWorksService , in modo che derivi da un DataService<T> oggetto che opera sulla classe di contesto dell'oggetto
AdventureWorksLTEntities
nel modello di dati di entità. Aggiorna inoltre il metodoInitializeService
per consentire ai client del servizio l'accesso completo in lettura/scrittura all'entitàSalesOrderHeader
.Compilare il progetto e verificare che non siano presenti errori.
Creare l'applicazione client WPF
Per visualizzare i dati dal servizio dati WCF, creare una nuova applicazione WPF con un'origine dati basata sul servizio. Più avanti in questa procedura dettagliata, verranno aggiunti all'applicazione i controlli associati a dati.
In Esplora soluzioni fare clic con il pulsante destro del mouse sul nodo della soluzione, scegliere Aggiungi e selezionare Nuovo progetto.
Nella finestra di dialogo Nuovo progetto espandere Visual C# o Visual Basic, quindi selezionare Finestre.
Selezionare il modello di progetto Applicazione WPF.
Nella casella Nome digitare
AdventureWorksSalesEditor
e fare clic su OK.Visual Studio aggiunge il
AdventureWorksSalesEditor
progetto alla soluzione.Scegliere Mostra origini dati dal menu Dati.
Verrà visualizzata la finestra Origini dati.
Nella finestra Origini dati fare clic su Aggiungi nuova origine dati.
Verrà avviata la Configurazione guidata origine dati.
Nella pagina Scegliere un tipo di origine dati della procedura guidata selezionare Servizio e quindi selezionare Avanti.
Nella finestra di dialogo Aggiungi riferimento al servizio fare clic su Individua.
Visual Studio cerca i servizi disponibili nella soluzione corrente e aggiunge
AdventureWorksService.svc
all'elenco dei servizi disponibili nella casella Servizi .Nella casella Spazio dei nomi digitare AdventureWorksService.
Nella casella Servizi fare clic su AdventureWorksService.svc e quindi selezionare OK.
Visual Studio scarica le informazioni sul servizio, quindi torna alla Configurazione guidata origine dati.
Nella pagina Aggiungi riferimento al servizio fare clic su Fine.
Visual Studio aggiunge i nodi che rappresentano i dati restituiti dal servizio nella finestra Origini dati.
Definire l'interfaccia utente
Aggiungere alcuni pulsanti alla finestra modificando il codice XAML in WPF Designer. Più avanti in questa procedura dettagliata, verrà aggiunto il codice che consente agli utenti di visualizzare e aggiornare i record delle vendite tramite questi pulsanti.
In Esplora soluzioni fare doppio clic su MainWindow.xaml.
La finestra verrà aperta in WPF Designer.
Nella visualizzazione XAML della finestra di progettazione aggiungere il codice seguente tra i
<Grid>
tag:<Grid.RowDefinitions> <RowDefinition Height="75" /> <RowDefinition Height="525" /> </Grid.RowDefinitions> <Button HorizontalAlignment="Left" Margin="22,20,0,24" Name="backButton" Width="75"><</Button> <Button HorizontalAlignment="Left" Margin="116,20,0,24" Name="nextButton" Width="75">></Button> <Button HorizontalAlignment="Right" Margin="0,21,46,24" Name="saveButton" Width="110">Save changes</Button>
Compilare il progetto.
Creare i controlli associati a dati
Creare controlli che visualizzano i record dei clienti trascinando il SalesOrderHeaders
nodo dalla finestra Origini dati alla finestra di progettazione.
Nella finestra Origini dati fare clic sul menu a discesa per il nodo SalesOrderHeaders e selezionare Dettagli.
Espandere il nodo SalesOrderHeaders.
Per questo esempio, alcuni campi non verranno visualizzati, quindi fare clic sul menu a discesa accanto ai nodi seguenti e selezionare Nessuno:
CreditCardApprovalCode
ModifiedDate
OnlineOrderFlag
RevisionNumber
rowguid
Questa azione impedisce a Visual Studio di creare i controlli associati a dati per questi nodi nel passaggio successivo. Per questa procedura dettagliata, si supponga che l'utente finale non debba visualizzare questi dati.
Dalla finestra Origini dati trascinare il nodo SalesOrderHeaders nella riga della griglia sotto la riga contenente i pulsanti.
Visual Studio genera l'XAML e il codice che crea un set di controlli associati a dati nella tabella Product. Per altre informazioni su XAML e codice generati, vedere Associare controlli WPF ai dati in Visual Studio.
Nella finestra di progettazione fare clic sulla casella di testo accanto all'etichetta Customer ID.
Nella finestra Proprietà selezionare la casella di controllo accanto alla proprietà IsReadOnly.
Impostare la proprietà IsReadOnly per ognuna delle caselle di testo seguenti:
Purchase Order Number
Sales Order ID
Sales Order Number
Caricare i dati dal servizio
Usare l'oggetto proxy del servizio per caricare i dati di vendita dal servizio. Assegnare quindi i dati restituiti all'origine dati per nella CollectionViewSource finestra WPF.
Nella finestra di progettazione, per creare il
Window_Loaded
gestore eventi, fare doppio clic sul collegamento: MainWindowSostituire il gestore eventi con il codice seguente. Assicurarsi di sostituire l'indirizzo
localhost
in questo codice con l'indirizzo host locale nel computer di sviluppo.private AdventureWorksService.AdventureWorksLTEntities dataServiceClient; private System.Data.Services.Client.DataServiceQuery<AdventureWorksService.SalesOrderHeader> salesQuery; private CollectionViewSource ordersViewSource; private void Window_Loaded(object sender, RoutedEventArgs e) { // TODO: Modify the port number in the following URI as required. dataServiceClient = new AdventureWorksService.AdventureWorksLTEntities( new Uri("http://localhost:45899/AdventureWorksService.svc")); salesQuery = dataServiceClient.SalesOrderHeaders; ordersViewSource = ((CollectionViewSource)(this.FindResource("salesOrderHeadersViewSource"))); ordersViewSource.Source = salesQuery.Execute(); ordersViewSource.View.MoveCurrentToFirst(); }
Esplorare i record di vendita
Aggiungere il codice che consente agli utenti di scorrere i record delle vendite usando i pulsanti < e >.
Nella finestra di progettazione fare doppio clic sul pulsante < nell'area della finestra.
Visual Studio apre il file code-behind e crea un nuovo gestore eventi
backButton_Click
per l'evento Click.Aggiungere il codice seguente al gestore eventi
backButton_Click
generato:Tornare alla finestra di progettazione e fare doppio clic sul pulsante >.
Visual Studio apre il file code-behind e crea un nuovo gestore eventi
nextButton_Click
per l'evento Click.Aggiungere il codice seguente al gestore eventi
nextButton_Click
generato:
Salvare le modifiche apportate ai record di vendita
Aggiungere il codice che consente agli utenti di visualizzare e salvare le modifiche ai record delle vendite usando il pulsante Salva modifiche:
Nella finestra di progettazione fare doppio clic sul pulsante Salva modifiche.
Visual Studio apre il file code-behind e crea un nuovo gestore eventi
saveButton_Click
per l'evento Click.Aggiungere il codice seguente al gestore eventi
saveButton_Click
.
Testare l'applicazione
Compilare ed eseguire l'applicazione per verificare che sia possibile visualizzare e aggiornare i record cliente:
Scegliere Compila soluzione dal menu Compila. Verificare che la soluzione venga compilata senza errori.
Premere CTRL+F5.
Visual Studio avvia il progetto AdventureWorksService senza eseguirne il debug.
In Esplora soluzioni fare clic con il pulsante destro del mouse sul progetto AdventureWorksSalesEditor.
Nel menu di scelta rapida del menu di scelta rapida fare clic su Avvia nuova istanza in Debug.
Verrà eseguita l'applicazione. Verificare quanto segue:
Nelle caselle di testo vengono visualizzati campi di dati diversi dal primo record di vendite il cui ID ordine vendite è 71774.
È possibile fare clic sui pulsanti > o < per spostarsi tra gli altri record delle vendite.
In uno dei record di vendita digitare un testo nella casella Commento e quindi selezionare Salva modifiche.
Chiudere l'applicazione, quindi avviarla di nuovo da Visual Studio.
Passare al record delle vendite modificato e verificare che la modifica sia presente dopo avere chiuso e riaperto l'applicazione.
Chiudere l'applicazione.
Passaggi successivi
Dopo avere completato questa procedura dettagliata, è possibile eseguire le attività correlate seguenti:
Imparare a usare la finestra Origini dati in Visual Studio per associare i controlli WPF ad altri tipi di origini dati. Per altre informazioni, vedere Associare controlli WPF a un set di dati.
Imparare a usare la finestra Origini dati in Visual Studio per visualizzare i dati correlati, ovvero i dati in una relazione padre-figlio, nei controlli WPF. Per altre informazioni, vedere Procedura dettagliata: Visualizzazione di dati correlati in un'applicazione WPF.