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
Escludere alcuni file da GitHub Copilot
Configurare OpenAI in .NET Aspire
Agentic Workflows in GitHub
Modificare lo stile in una QuickGrid Blazor
Utilizzare le View Transition API di JavaScript
Ridurre il reflow cambiando il CSS
Montare Azure Blob Storage su Linux con BlobFuse2
Raggruppamento degli aggiornamenti di dipendenze tra directory in un monorepo con Dependabot
Controllare la velocità di spostamento su una pagina HTML
Nuova modale riconnessione Blazor
Controllare la telemetria con .NET Aspire
Impostare la content-visibility in CSS per ottimizare il rendering iniziale di una pagina




