Windows 10 може зберігати окремі аудіопрофілі для різних аудіопристроїв. Для кожного підключеного аудіопристрою можна встановити інший рівень гучності, і коли пристрій підключено, гучність буде регулюватися автоматично. Звичайно, ніхто не тримає звук на аудіопристрої весь час. Вони збільшують або зменшують гучність, але ніхто зазвичай не вимикає звук аудіопристрою.
Якщо ви використовуєте пару навушників зі своїм робочим столом, і вам часто доводиться відключати їх, ви можете використовувати невеликий сценарій PowerShell, який автоматично вимикає звук, коли ви від’єднуєте навушники.
Це те, що роблять мобільні телефони, тобто коли ви відключаєте навушники, музика автоматично припиняється. Логіка цього полягає в тому, що ви або закінчили слухати музику, або випадково зняли навушники, і вам потрібен швидкий спосіб їх вимкнути. Сценарій був в основному написаний за таким же принципом Пратік Сінгх із GEEKEEFY.
Автоматичне вимкнення звуку
Відкрийте Блокнот і вставте наступне;
[cmdletbinding()] Param() #Adding definitions for accessing the Audio API Add-Type -TypeDefinition @' using System.Runtime.InteropServices; [Guid("5CDF2C82-841E-4546-9722-0CF74078229A"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)] interface IAudioEndpointVolume { // f(), g(), ... are unused COM method slots. Define these if you care int f(); int g(); int h(); int i(); int SetMasterVolumeLevelScalar(float fLevel, System.Guid pguidEventContext); int j(); int GetMasterVolumeLevelScalar(out float pfLevel); int k(); int l(); int m(); int n(); int SetMute([MarshalAs(UnmanagedType.Bool)] bool bMute, System.Guid pguidEventContext); int GetMute(out bool pbMute); } [Guid("D666063F-1587-4E43-81F1-B948E807363F"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)] interface IMMDevice { int Activate(ref System.Guid id, int clsCtx, int activationParams, out IAudioEndpointVolume aev); } [Guid("A95664D2-9614-4F35-A746-DE8DB63617E6"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)] interface IMMDeviceEnumerator { int f(); // Unused int GetDefaultAudioEndpoint(int dataFlow, int role, out IMMDevice endpoint); } [ComImport, Guid("BCDE0395-E52F-467C-8E3D-C4579291692E")] class MMDeviceEnumeratorComObject { } public class Audio { static IAudioEndpointVolume Vol() { var enumerator = new MMDeviceEnumeratorComObject() as IMMDeviceEnumerator; IMMDevice dev = null; Marshal.ThrowExceptionForHR(enumerator.GetDefaultAudioEndpoint(/*eRender*/ 0, /*eMultimedia*/ 1, out dev)); IAudioEndpointVolume epv = null; var epvid = typeof(IAudioEndpointVolume).GUID; Marshal.ThrowExceptionForHR(dev.Activate(ref epvid, /*CLSCTX_ALL*/ 23, 0, out epv)); return epv; } public static float Volume { get {float v = -1; Marshal.ThrowExceptionForHR(Vol().GetMasterVolumeLevelScalar(out v)); return v;} set {Marshal.ThrowExceptionForHR(Vol().SetMasterVolumeLevelScalar(value, System.Guid.Empty));} } public static bool Mute { get { bool mute; Marshal.ThrowExceptionForHR(Vol().GetMute(out mute)); return mute; } set { Marshal.ThrowExceptionForHR(Vol().SetMute(value, System.Guid.Empty)); } } } '@ -Verbose While($true) { #Clean all events in the current session since its in a infinite loop, to make a fresh start when loop begins Get-Event | Remove-Event -ErrorAction SilentlyContinue #Registering the Event and Waiting for event to be triggered Register-WmiEvent -Class Win32_DeviceChangeEvent Wait-Event -OutVariable Event |Out-Null $EventType = $Event.sourceargs.newevent | ` Sort-Object TIME_CREATED -Descending | ` Select-Object EventType -ExpandProperty EventType -First 1 #Conditional logic to handle, When to Mute/unMute the machine using Audio API If($EventType -eq 3) { [Audio]::Mute = $true Write-Verbose "Muted [$((Get-Date).tostring())]" } elseif($EventType -eq 2 -and [Audio]::Mute -eq $true) { [Audio]::Mute = $false Write-Verbose "UnMuted [$((Get-Date).tostring())]" } }
Збережіть його з розширенням файлу PS1. Переконайтеся, що ви вибрали «Усі файли» зі спадного списку типу файлу. Дайте файлу ім’я, яке з першого погляду покаже, що він робить. Збережіть його в тому місці, де ви навряд чи видалите його випадково, але також де ви можете легко знайти його, якщо вам потрібно.
Запуск сценарію
PowerShell не може просто автоматично запустити сценарій. Існує вбудований захід безпеки, який запобігає цьому, але є спосіб обійти це. У нас є детальна стаття про те, як це зробити. Дотримуйтесь інструкцій, щоб автоматично запустити щойно створений сценарій PowerShell, і використовуйте заплановану задачу, щоб запускати сценарій щоразу під час завантаження ПК.
Крім того, ви можете вручну запустити сценарій під час завантаження системи. Я використовую його менше 30 хвилин, і я не знаю, як я жив без нього раніше.