Tra le funzionalità presenti in Windows Phone 8, è presente la possibilità di lanciare app di terze parti direttamente dalla camera, opportunità resa ancora più facile nell'ultimo aggiornamento nominato Amber, poiché permette di impostare l'applicazione predefinita da lanciare alla pressione del pulsante fotocamera.
Questo tipo di app, nominate lens app, sono caratterizzate dal fatto che sfruttano la fotocamera e per supportare questa caratteristica lo sforzo da fare è minimo. Prima di tutto dobbiamo creare un'icona da mostrare nella lista delle lens app. L'icona va creata nelle tre dimensioni supportate dall'app nominando ogni rispettivo file nel seguente modo: Lens.Screen-WVGA.png, Lens.Screen-720p.png, Lens.Screen-WXGA.png.
Creata l'icona, dobbiamo modificare manualmente il file WMAppManifest.xml inserendo nella sezione Extensions la seguente voce, senza alcuna modifica:
<Extensions> <Extension ExtensionName="Camera_Capture_App" ConsumerID="{5B04B775-356B-4AA0-AAF8-6491FFEA5631}" TaskID="_default" /> </Extensions>
Fatto questo troveremo l'app tra quelle disponibili nella camera. Quando l'utente preme sull'icona l'app verrà lanciata (o ripristinata se abbiamo supportato il fast app resume) lanciando la pagina principale ponendo in query string la voce Action=ViewfinderLaunch. E' opportuno gestire questo parametro per far sì che all'utente venga mostrata la camera. Se la pagina principale lo fa già, possiamo ignorare il parametro, in caso contrario invece, dobbiamo rimandare l'utente alla pagina specifica della camera. Il metodo più comodo si basa sull'uso dell'UriMapperBase, classe con la quale possiamo decidere l'Uri di navigazione a fronte dell'Uri originale. Dobbiamo quindi creare una nostra classe come nell'esempio seguente:
class LensUriMapper : UriMapperBase { private string tempUri; public override Uri MapUri(Uri uri) { // Guardo se attivato da lens if (uri.ToString().Contains("Action=ViewfinderLaunch")) { // Lancio la pagina con la camera return new Uri("/cameraPage.xaml", UriKind.Relative); } // Otherwise perform normal launch. return uri; } }
A questo punto possiamo istruire il RootFrame, inizializzato nell'App.xaml.cs, come nell'esempio.
// ... RootFrame.Navigated += CompleteInitializePhoneApplication; // Assegno il mapper RootFrame.UriMapper = new LensUriMapper();
Raccomandiamo infine di visionare le guide line consigliate da Microsoft per creare una lens app ottimale.
http://msdn.microsoft.com/en-us/library/windowsphone/design/jj662922(v=vs.105).aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
Usare le variabili per personalizzare gli stili CSS
Installare le Web App site extension tramite una pipeline di Azure DevOps
Utilizzare gli snapshot con Azure File shares
Utilizzare le Cache API di JavaScript per salvare elementi nella cache del browser
Creazione di plugin per Tailwind CSS: espandere le Funzionalità del Framework
Definire stili a livello di libreria in Angular
Semplificare il deployment di siti statici con Azure Static Web App
Utilizzare Tailwind CSS all'interno di React: primi componenti
Controllare gli accessi IP alle app con Azure Container Apps
Utilizzare i primary constructor di C# per inizializzare le proprietà
Applicare il versioning ai nostri endpoint ASP.NET Core Minimal API