La Universal Windows Platform consente non solo di costruire applicazioni che siano in grado di girare su più categorie di device differenti (immaginiamo al PC, Surface Hub, XBox e altri), ma anche di costruire applicazioni specifiche per una determinata categoria: solitamente negli script parliamo di quello che succede nel mondo Desktop, ma anche il mondo IoT ha molta importanza e possiamo sfruttare anche in questo settore gli stessi vantaggi di un runtime sicuro e una metodologia di sviluppo che già conosciamo.
Poter controllare un device da remoto e spegnerlo (o mandarlo in standby), in caso di consumi eccessivi (o in caso di errori non risolvibili), può essere fondamentale. La Universal Windows Platform ci consente di farlo attraverso l'installazione delle estensioni per Windows IoT. Per aggiungerle è sufficiente cliccare con il tasto destro sulle reference del progetto e selezionare "Windows IoT Extensions for the UWP" dal menù Universal Windows -> Extensions per creare un'applicazione tailor-made.
Per evitare di incorrere in eccezioni dovute alla mancanza di permessi, è necessario aggiungere al file di manifest un'apposita capability:
<Package ... xmlns:iot="http://schemas.microsoft.com/appx/manifest/iot/windows10" IgnorableNamespaces="uap mp iot"> <Capabilities> <iot:Capability Name="systemManagement" /> </Capabilities> <!-- ... -->
Per spegnere il device è quindi sufficiente chiamare il metodo BeginShutdown esposto dalla classe ShutdownManager a cui possiamo passare eventualmente un tempo per ritardare l'operazione (utile se dobbiamo prima effettuare un salvataggio di dati o operazioni simili):
private void Shutdown(int delay) { ShutdownManager.BeginShutdown(ShutdownKind.Shutdown, TimeSpan.FromSeconds(delay)); }
In alternativa allo spegnimento, possiamo anche effettuare un riavvio forzato, semplicemente cambiando la modalità di shutdown:
private void Shutdown(int delay) { ShutdownManager.BeginShutdown(ShutdownKind.Restart, TimeSpan.FromSeconds(delay)); }
In entrambi i casi, l'operazione può essere annullata a patto che la richiesta venga eseguita prima del termine del delay (e dell'esecuzione del comando stesso):
private void CancelShutdown() { ShutdownManager.CancelShutdown(); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Recuperare un elemento inserito nella cache del browser tramite API JavaScript
Utilizzare domini personalizzati gestiti automaticamente con Azure Container Apps
Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
Ottimizzazione dei block template in Angular 17
Short-circuiting della Pipeline in ASP.NET Core
Gestire i null nelle reactive form tipizzate di Angular
.NET Conference Italia 2023
Implementare l'infinite scroll con QuickGrid in Blazor Server
Utilizzare la libreria Benchmark.NET per misurare le performance
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
Code scanning e advanced security con Azure DevOps
Utilizzare l'operatore GroupBy come ultima istruzione di una query LINQ in Entity Framework
I più letti di oggi
- Utilizzare Docker Compose con Azure App Service
- Utilizzare QuickGrid di Blazor con Entity Framework
- Modernizzare le applicazioni WPF e Windows Forms con Blazor
- ASP 3 per esempi
- annunciato #netstandard 2.1. .NET Core lo supporterà a partire da #netcore3, così come le prossime versione di #xamarin, #mono e #unity.il supporto per #netfx 4.8, invece, non ci sarà. https://aspit.co/bq2
- Steel Style CheckBox per Silverlight 4.0