WinRT porta con se un set ricco di API che coprono la maggior parte delle esigenze che possiamo avere sui dispositivi mobili e non. Alcune di queste possono essere esclusiva di Windows 8.1 o di Windows Phone 8.1. Per questo dispositivo troviamo a disposizione la classe ScreenCapture, la quale ci permette di cattura l'audio e il video dell'intera app, permettendoci di salvare clip, utili per diagnostica o per generare video usando direttamente lo XAML.
Utilizzarla è piuttosto semplice, perché la procedura è del tutto simile alla cattura di una foto o di un video. Ciò che cambia è la sorgente che appunto viene dallo ScreenCapture. Partiamo quindi dall'ottenere tale oggetto chiedendo l'autorizzazione all'utente con un'interfaccia fornita automaticamente dal sistema.
// Ottengo l'istanza per l'app corrente // Scatta l'autorizzazione da parte dell'utente ScreenCapture screenCapture; try { screenCapture = ScreenCapture.GetForCurrentView(); } catch (UnauthorizedAccessException) { // Permesso negato return; }
Ottenuta la sorgente possiamo istanziare un MediaCapture specificando come sorgente audio/video lo ScreenCapture stesso.
// Impostazioni di cattura var settings = new MediaCaptureInitializationSettings(); if (!screenCapture.IsVideoSuspended) settings.VideoSource = screenCapture.VideoSource; settings.StreamingCaptureMode = StreamingCaptureMode.Video;
A questo punto possiamo inizializzare la sessione e procedere, per esempio, alla registrazione diretta su un file MP4, come nell'esempio.
// Inizializzo la sessione di cattura this.mediaCapture = new MediaCapture(); await this.mediaCapture.InitializeAsync(settings); // Registro su file var file = await KnownFolders.CameraRoll.CreateFileAsync("screen.mp4", CreationCollisionOption.ReplaceExisting); var profile = MediaEncodingProfile.CreateMp4(VideoEncodingQuality.Auto); await this.mediaCapture.StartRecordToStorageFileAsync(profile, file);
Dobbiamo precisare che la sessione di cattura funziona solo se l'app è in foreground e si interrompe automaticamente nel momento in cui l'utente esce dall'app. Non possiamo quindi catturare sequenze esterne alla nostra app. Inoltre, la cattura non funziona se l'app sta riproducendo un video protetto con DRM.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare le navigation property in QuickGrid di Blazor
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Usare una container image come runner di GitHub Actions
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Eseguire una query su SQL Azure tramite un workflow di GitHub
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Utilizzare il nuovo modello GPT-4o con Azure OpenAI
Esportare ed analizzare le issue di GitHub con la CLI e GraphQL
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Eseguire script pre e post esecuzione di un workflow di GitHub
I più letti di oggi
- Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
- Eseguire script pre e post esecuzione di un workflow di GitHub
- Creare una libreria CSS universale: Cards
- Migliorare l'organizzazione delle risorse con Azure Policy