Windows 10では、個別のオーディオプロファイルを保持できますさまざまなオーディオデバイス。接続するオーディオデバイスごとに、異なる音量レベルを設定できます。デバイスが接続されると、音量が自動的に調整されます。もちろん、オーディオデバイスを常にミュート状態に保つ人はいません。音量は増減しますが、オーディオデバイスを習慣的にミュートする人はいません。デスクトップでヘッドフォンを使用していて、多くの場合それらを切断する必要がある場合は、ヘッドフォンを取り外したときに自動的に音を消す小さなPowerShellスクリプトを使用できます。
これは、携帯電話が行うことです。、ヘッドフォンのプラグを抜くと、音楽が自動的に停止します。この背後にあるロジックは、音楽を聴き終わったか、誤ってヘッドフォンを取り外したため、すぐにオフにする方法が必要だということです。このスクリプトは基本的に、GEEKEEFYのPrateek Singhが同じ原則に基づいて作成しました。

音声を自動的にミュートする
メモ帳を開き、次を貼り付けます。
[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スクリプトを自動実行し、PCを起動するたびにスケジュールされたタスクを使用してスクリプトを開始します。
または、システムの起動時に手動でスクリプトを実行できます。私はそれを30分未満使用してきましたが、それなしではどのように生きていたのかわかりません。
コメント