Silencie o Áudio do Windows 10 ao Desconectar Fones: Script PowerShell!

Foto do autor

By luis

O Windows 10 oferece a capacidade de manter configurações de áudio distintas para diferentes dispositivos sonoros. Isso significa que você pode ajustar o volume de cada dispositivo conectado individualmente, e o sistema lembrará essas configurações, ajustando automaticamente o volume quando o dispositivo for reconectado. Contudo, usualmente, ninguém mantém seus dispositivos de áudio completamente silenciados o tempo todo, alternando o volume conforme necessário.

Se você usa fones de ouvido com frequência em seu computador e precisa desconectá-los ocasionalmente, pode empregar um script simples em PowerShell que silenciará automaticamente o som quando eles forem desconectados.

Essa funcionalidade é similar ao comportamento de smartphones, onde a música é pausada automaticamente quando os fones de ouvido são desconectados. A ideia é que você terminou de ouvir ou os fones foram desconectados acidentalmente e, portanto, é conveniente silenciar o áudio imediatamente. O script foi desenvolvido com base nesse princípio por Prateek Singh do GEEKEEFY.

Silenciamento automático do som

Abra o Bloco de Notas e insira o seguinte código:

[cmdletbinding()]
Param()

#Adicionando definições para acessar a API de Áudio
Add-Type -TypeDefinition @'
using System.Runtime.InteropServices;
[Guid("5CDF2C82-841E-4546-9722-0CF74078229A"), InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
interface IAudioEndpointVolume {
// f(), g(), ... são slots de métodos COM não utilizados. Defina-os se precisar
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(); // Não utilizado
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)
{
#Limpa todos os eventos na sessão atual, já que está em um loop infinito, para começar de novo quando o loop começar
Get-Event | Remove-Event -ErrorAction SilentlyContinue

#Registrando o Evento e Aguardando o evento ser disparado
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

#Lógica condicional para manipular, quando silenciar/desativar o som da máquina usando a API de áudio
If($EventType -eq 3) 
{
[Audio]::Mute = $true
Write-Verbose "Silenciado [$((Get-Date).tostring())]"
}
elseif($EventType -eq 2 -and [Audio]::Mute -eq $true)
{
[Audio]::Mute = $false
Write-Verbose "Som ativado [$((Get-Date).tostring())]"
}
}

Salve o arquivo com a extensão .ps1. Certifique-se de selecionar “Todos os arquivos” no menu suspenso de tipo de arquivo. Dê ao arquivo um nome que seja fácil de identificar e salve-o em um local onde não será excluído por engano, mas que seja fácil de acessar.

Executando o script

O PowerShell não executa scripts automaticamente por padrão. Há uma medida de segurança que impede isso, mas existem maneiras de contorná-la. Temos um guia detalhado sobre como fazer isso. Siga as instruções para executar automaticamente o script que você acabou de criar, utilizando o Agendador de Tarefas para iniciar o script sempre que o computador for ligado.

Como alternativa, você pode executar o script manualmente ao iniciar o sistema. Após usá-lo por um curto período, fica difícil imaginar como era antes.