Nelle applicazioni tipiche "da ufficio", potrebbe venire comodo per i partecipanti di un meeting, prendere appunti su documenti condivisi da una precedente email come, ad esempio, un file PDF. In casi come questo, quindi, viene utile, oltre a mostrare il PDF nella sua interezza, renderizzare una singola pagina come immagine, così che sia "zoomabile" e così che ci si possa interagile con ink e touch.
Supponendo di aver già a disposizione il PDF ottenuto come StorageFile, possiamo caricarlo in memoria sfruttando la classe PdfDocument, dalla quale possiamo anche estrapolare la pagina che ci interessa renderizzare:
private async Task<BitmapImage> CreateImageFromPdfPageAsync(StorageFile file, int pageNumber) { var document = await PdfDocument.LoadFromFileAsync(file); using var memoryStream = new InMemoryRandomAccessStream(); await document.GetPage((uint)pageNumber).RenderToStreamAsync(memory); // ... }
Una volta ottenuta la pagina come stream, possiamo facilmente recuperare l'array di byte, sfruttando anche a livello di sintassi le ultime novità di C# 8:
using var reader = new DataReader(memoryStream); await reader.LoadAsync((uint)memoryStream.Size); var imageAsBytes = new byte[memoryStream.Size]; reader.ReadBytes(imageAsBytes);
Così facendo abbiamo già un oggetto contenente la nostra immagine che possiamo utilizzare per salvarla, ad esempio, sul disco.
Qualora invece volessimo semplicemente visualizzarla a schermo, potremmo sostituire il metodo precedente con il seguente, che va a caricare lo stream letto dalla classe PdfDocument come Source dell'oggetto di tipo BitmapImage:
var bitmapImage = new BitmapImage(); await bitmapImage.SetSourceAsync(memoryStream);
L'immagine caricata può quindi essere associata ad un controllo Image pre-costruito a livello di XAML.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare due extension method per serializzare un oggetto in JSON e viceversa utilizzando la libreria System.Text.Json
Utilizzare la deconstruction in combinazione con l'operatore rest di Javascript
Accedere da un App Service ad Azure SQL Database tramite AAD
Blazor: WebAssembly
Creare un effetto di ombra sui controlli della Universal Windows Platform
Utilizzare il metodo TrackGraph per impostare lo stato degli oggetti in un grafo in Entity Framework Core
Progressive Web Apps with Angular
Uso dei design-time data nelle applicazioni della Universal Windows Platform
UI testing in applicazioni .NET desktop e mobile
Blazor: Forms
Utilizzare al meglio gli oggetti HTML input sfruttando i nuovi type
Winget: un nuovo package manager per Windows
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Creare un record in C#
- Winget: un nuovo package manager per Windows
- il 18/02 c'è il #container & #devops day! https://aspit.co/ContainerDevOpsDay-21 Le iscrizioni sono sempre aperte e la Call For Paper è attiva fino al 28/01! #aspilive #cfp
- Attesa e validazione manuale nelle pipeline YAML di Azure DevOps
- Utilizzare il CSS Grid Model per creare il layout di un sito
- Montare una file share con Azure Container Instance
- Container & DevOps Day - Online