Passa ai contenuti principali

Caliburn.Micro, NuGet, Visual Basic.Net e Windows Phone 7

No, non mi sono sbagliato e ho ripubblicato un precedente post, semplicemente si tratta della versione del precedente post per WP7.

Anche in questo caso, se tentiamo di utilizzare Caliburn.Micro tramite NuGet in un progetto VB.NET per WP7, otteniamo che le classi che il package NuGet genera sono per C#.

Ma procediamo con ordine, per cominciare accertiamoci di aver installato ed abilitato NuGet tra le estensioni di VS (basta vedere se con il tasto destro su un progetto appare il menù contestuale “Add Library Package Reference…”). Se non abbiamo NuGet, possiamo installarlo utilizzando l’Extension Manager del menù Tools.

Come secondo passo creiamo un nuovo progetto WP7 e, una volta che Visual Studio ha terminato la procedura di creazione, selezioniamo il nostro progetto e scegliamo il comando “Manage NuGet Packages…” che compare con la pressione del tasto destro del mouse.

image

Digitiamo “Caliburn” nella casella di ricerca della finestra di NuGet che appare subito dopo:

SNAGHTMLcccd77d

Premendo il tasto install, il package NuGet provvede a creare le opportune classi (che abbiamo detto essere in C#) che servono per il funzionamento di Caliburn.Micro su WP7. In particolare, come possiamo vedere nella figura in seguito, vengono create due classi: AppBoostraper.cs e MainPageViewModel.cs

image

Ovviamente, noi VB-isti non possiamo farci nulla delle classi generate quindi le cancelliamo e le sostituiamo con le seguenti:

AppBoostrapper.vb

  1. Imports Caliburn.Micro
  2.  
  3. Public Class AppBootstrapper
  4.     Inherits PhoneBootstrapper
  5.  
  6.     Dim container As PhoneContainer
  7.  
  8.     Protected Overrides Sub Configure()
  9.         container = New PhoneContainer(RootFrame)
  10.  
  11.         container.RegisterPhoneServices()
  12.         container.PerRequest(Of MainPageViewModel)()
  13.  
  14.         AddCustomConventions()
  15.     End Sub
  16.  
  17.     Protected Overrides Function GetInstance(service As System.Type, key As String) As Object
  18.         Return container.GetInstance(service, key)
  19.     End Function
  20.  
  21.     Protected Overrides Function GetAllInstances(service As System.Type) As System.Collections.Generic.IEnumerable(Of Object)
  22.         Return container.GetAllInstances(service)
  23.     End Function
  24.  
  25.     Protected Overrides Sub BuildUp(instance As Object)
  26.         container.BuildUp(instance)
  27.     End Sub
  28.  
  29.  
  30.     Public Shared Sub AddCustomConventions()
  31.         ConventionManager.AddElementConvention(Of Pivot)(Pivot.ItemsSourceProperty, "SelectedItem", "SelectionChanged").ApplyBinding = _
  32.             New Func(Of System.Type, String, System.Reflection.PropertyInfo, System.Windows.FrameworkElement, Caliburn.Micro.ElementConvention, Boolean) _
  33.             (Function(viewModelType, path, [property], element, convention)
  34.                  If (ConventionManager.GetElementConvention(GetType(ItemsControl)).ApplyBinding(viewModelType, path, [property], element, convention)) Then
  35.                      ConventionManager.ConfigureSelectedItem(element, Pivot.SelectedItemProperty, viewModelType, path)
  36.                      ConventionManager.ApplyHeaderTemplate(element, Pivot.HeaderTemplateProperty, viewModelType)
  37.                      Return True
  38.                  End If
  39.                  Return False
  40.              End Function)
  41.  
  42.         ConventionManager.AddElementConvention(Of Panorama)(Panorama.ItemsSourceProperty, "SelectedItem", "SelectionChanged").ApplyBinding = _
  43.                  New Func(Of System.Type, String, System.Reflection.PropertyInfo, System.Windows.FrameworkElement, Caliburn.Micro.ElementConvention, Boolean) _
  44.                  (Function(viewModelType, path, [property], element, convention)
  45.                       If (ConventionManager.GetElementConvention(GetType(ItemsControl)).ApplyBinding(viewModelType, path, [property], element, convention)) Then
  46.                           ConventionManager.ConfigureSelectedItem(element, Panorama.SelectedItemProperty, viewModelType, path)
  47.                           ConventionManager.ApplyHeaderTemplate(element, Panorama.HeaderTemplateProperty, viewModelType)
  48.                           Return True
  49.                       End If
  50.  
  51.                       Return False
  52.                   End Function)
  53.     End Sub
  54. End Class

MainPageViewModel.vb

  1. Public Class MainPageViewModel
  2.  
  3.    
  4. End Class

A questo punto possiamo seguire i passi descritti nel tutorial per poter configurare la nostra app all’utilizzo di Caliburn.Micro.

Il suggerimento che vi posso dare è quello di ristrutturare le cartelle dell’applicazione creando le cartelle Views e ViewModels in cui inserire le views e i viewmodels (inizialmente MainPage e MainPageViewModel) nel seguente modo:

image

Infine, visto che ci siamo, modifichiamo i namespace delle classi MainPage (namespace CaliburnMicroWP7.Views) e MainPageViewModel (namespace CaliburnMicroWP7.ViewModels).

In allegato al post trovate la soluzione completa con le classi e le modifiche.


Commenti

Post popolari in questo blog

VB.NET: SplashScreen con effetto fade-in

In questo post vorrei proporvi un modo per realizzare una splash screen per le nostre applicazioni Windows Form che appare progressivamente con un effetto fade. Supponiamo di avere il nostro progetto VB.NET in una soluzione Visual Studio 2008 in cui abbiamo il sorgente della nostra applicazione Windows Form. Inseriamo una splash screen utilizzando il menù Progetto->Aggiungi Nuovo Elemento e selezionando il tipo di elemento “Schermata Iniziale” A questo punto Visual Studio creerà, automaticamente, la schermata iniziale che possiamo personalizzare graficamente come vogliamo. Per poter fare in modo che questa finestra appaia nel momento in cui avviamo l’applicazione, è necessario aprire le proprietà del progetto e impostare la maschera di avvio: In questo modo, all’avvio dell’applicazione, la schermata appare immediatamente e scompare un attimo prima della visualizzazione della finestra dell’applicazione. Possiamo far apparire la schermata iniziale con un ef

VB.NET for Dummies: Gli Eventi

Vorrei iniziare con questo post una serie dedicata ad aspetti di VB.NET di base che possono essere utile a coloro che si avvicinano al mondo .NET e che, in genere, non vengono trattati a livello base. La serie di post non ha la pretesa di essere assolutamente esaustivi sugli argomenti che tratterò In questo primo post parleremo degli eventi. Cosa sono e a cosa servono Un evento è la “notifica” dell’accadimento di qualcosa. Quando, ad esempio, premiamo un bottone della finestra di un’applicazione, dietro le quinte, il bottone stesso “notifica” al mondo circostante che qualcuno, in quell’istante, lo ha premuto. Sta, poi, al mondo circostante preoccuparsi di “intercettare” l’evento stesso per gestirlo (tramite un gestore di evento). Attenzione a non confondere la pressione del tasto con la “notifica” della pressione del tasto: l’evento è la “notifica” dell’accadimento, non l’accadimento stesso. Ma a cosa serve tutto ciò? Utilizzare gli eventi è un modo per disaccoppiare

Alla scoperta del Kinect: presentazioni e convenevoli

Oggi è arrivato un Kinect nuovo nuovo su cui cominciare a fare sperimentazione ed ho, quindi, deciso di condividere tutto ciò che scopro, le cavolate che faccio e i segreti che scopro con chi mi segue. I post che cercherò di scrivere con frequenza sono post di un neofita che si avvicina all’”Aggeggio” e che quindi sono diretti a chi nulla dell’argomento. Gli esperti troveranno noiosi e banali questi post, ma non si può aver tutto dalla vita. Per cominciare, scartato l’”Aggeggio” ho cominciato a preparare l’ambiente di sviluppo: 1) Visual Studio 2010 Ultimate (che uso normalmente ma che non è necessario in quanto si può sviluppare tranquillamente con la express edition); 2) Kinect SDK, scaricabile all’indirizzo http://research.microsoft.com/en-us/um/redmond/projects/kinectsdk/download.aspx 3) DirectX Software Development Kit scaricabile all’indirizzo http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=6812 A questo punto vi basta connettere il Kinect al