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
Ottenere un token di accesso per una GitHub App
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Gestire domini wildcard in Azure Container Apps
Definire stili a livello di libreria in Angular
Cancellare una run di un workflow di GitHub
Gestione dei nomi con le regole @layer in CSS
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Utilizzare gRPC su App Service di Azure
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Triggerare una pipeline su un altro repository di Azure DevOps
Gestire la cancellazione di una richiesta in streaming da Blazor