- - A hang automatikus elnémítása, ha a fejhallgató ki van húzva a Windows 10 rendszeren

A hang automatikus elnémítása, ha a fejhallgató ki van húzva a Windows 10 rendszeren

A Windows 10 külön audio profilokat képes tárolnikülönböző audio eszközök. Minden egyes csatlakoztatott audioeszközhöz beállíthat különféle hangerőt, és amikor az eszköz csatlakoztatva van, a hangerő automatikusan beállítódik. Természetesen senki sem tartja folyamatosan elnémítva az audioeszközt. Növelik vagy csökkentik a hangerőt, de senki sem szokott némítani az audioeszközt. Ha pár fejhallgatót használ az asztalához, és gyakran le kell választania őket, akkor használjon egy kis PowerShell-parancsfájlt, amely automatikusan elnémítja a hangot, amikor kihúzza a fejhallgatót.

Ezt a mobiltelefonok teszik, azaz, amikor kihúzza a fejhallgatót, a zene automatikusan leáll. Ennek logikája az, hogy vagy zenét hallgatott, vagy véletlenül eltávolította a fejhallgatót, és szüksége van egy gyors módra annak kikapcsolásához. A forgatókönyvet alapvetően ugyanazon az elv alapján írta Prateek Singh, a GEEKEEFY.

A hang automatikus elnémítása

Nyissa meg a Jegyzettömböt, és illessze be a következőket;

[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())]"
}
}

Mentse el a PS1 fájlkiterjesztéssel. Ügyeljen arra, hogy a fájltípus legördülő menüből válassza az „Összes fájl” lehetőséget. Adjon nevet a fájlnak, amely egy pillanat alatt elmondja, mit csinál. Mentse el egy olyan helyre, amelyet valószínűleg nem véletlenül töröl, de ott is, ahol könnyedén megtalálhatja.

A forgatókönyv futtatása

A PowerShell nem csak egy parancsfájlt engedélyezhet automatikusan. Van egy beépített biztonsági intézkedés, amely megakadályozza ezt, de megkerülhető a helyzet. Van egy részletes cikkünk arról, hogyan lehet ezt megtenni. Kövesse az utasításokat az éppen létrehozott PowerShell-szkript automatikus futtatásához, és egy ütemezett feladat segítségével indítsa el a szkriptet minden egyes indításakor.

Alternatív megoldásként manuálisan is futtathatja a szkriptet a rendszer indításakor. Kevesebb, mint 30 percig használtam, és nem tudom, hogyan éltem nélküle korábban.

Hozzászólások