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
Il nuovo controllo Range di Blazor 9
Creare una libreria CSS universale: Immagini
Change tracking e composition in Entity Framework
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Proteggere le risorse Azure con private link e private endpoints
Creare una libreria CSS universale - Rotazione degli elementi
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Simulare Azure Cosmos DB in locale con Docker
Disabilitare automaticamente un workflow di GitHub
I più letti di oggi
- Build 2015: segui con noi tutte le novità per gli sviluppatori in diretta da San Francisco
- Speciale Windows Live Services: come integrarli nelle proprie applicazioni
- Rilasciata la RTM di SQL Server 2012, la versione Express subito in download
- Build 2014: tutte le novità per gli sviluppatori in diretta da San Francisco
- .NET Managed provider per MySQL
- WS-I approva Basic Profile 1.0
- Due regali dal Tech-Ed USA 2004: WSE 2.0 e VS 2005 Team System
- VS 2005 e SQL Server 2005 Express da scaricare
- Microsoft aggiorna WinFS beta 1 per VS 2005
- Utilizzare CLEditor per consentire l'input di HTML in ASP.NET MVC