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
Gestire condizioni complesse in JavaScript
Gestire il fallimento di uno step in un workflow di GitHub
Aggiungere le issue di più repository in una board in GitHub
Creare moduli CSS in React
Semplificare il deployment di siti statici con Azure Static Web App
Effettuare il deploy di immagini solo da container registry approvati in Kubernetes
Determinare lo stato di un pod in Kubernetes
Ottenere il riferimento alla finestra che ha aperto un'altra finestra con HTML5 e JavaScript
Definire una tabella come memory optimized su Sql Server tramite EF Core
Usare il versioning con i controller di ASP.NET Core Web API
.NET 7 Live Q&A
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP