Windows 10 के लिए अलग ऑडियो प्रोफ़ाइल रख सकते हैंविभिन्न ऑडियो उपकरणों। प्रत्येक ऑडियो डिवाइस है कि आप कनेक्ट के लिए, आप एक अलग ध्वनि के स्तर को निर्धारित कर सकते हैं और जब डिवाइस जुड़ा हुआ है, मात्रा स्वचालित रूप से समायोजित करेगा। बेशक, कोई भी एक ऑडियो डिवाइस हर समय को मौन रहता है। वे वॉल्यूम को बढ़ाने या लेकिन कोई भी आदतन म्यूट एक ऑडियो डिवाइस को कम करेगा। आप अपने डेस्कटॉप के साथ हेडफोन की एक जोड़ी का उपयोग, और अक्सर उन्हें डिस्कनेक्ट करने के लिए है, तो आप एक छोटे से PowerShell स्क्रिप्ट कि जब आप अपने हेडफोन अनप्लग स्वचालित रूप से मूक ध्वनि जाएगा उपयोग कर सकते हैं।
यह कुछ ऐसा है जो मोबाइल फोन करते हैं यानी, जब आप अपने हेडफ़ोन को अनप्लग करते हैं, तो संगीत अपने आप बंद हो जाता है। इसके पीछे तर्क यह है कि आपने या तो संगीत सुना है या आपने गलती से अपने हेडफ़ोन को हटा दिया है और आपको इसे बंद करने के लिए एक त्वरित तरीका चाहिए। स्क्रिप्ट मूल रूप से GEEKEEFY के प्रतीक सिंह द्वारा उसी सिद्धांत पर लिखी गई थी।
![](/images/windows/how-to-automatically-mute-sound-when-headphones-are-unplugged-on-windows-10.jpg)
स्वचालित रूप से म्यूट ध्वनि
नोटपैड खोलें और निम्नलिखित पेस्ट करें;
[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 फ़ाइल एक्सटेंशन के साथ सहेजें। सुनिश्चित करें कि आपने फ़ाइल प्रकार ड्रॉपडाउन से Files सभी फ़ाइलें ’का चयन किया है। फ़ाइल को एक नाम दें जो आपको एक नज़र में बताएगा कि यह क्या करता है। इसे किसी स्थान पर सहेजें जिसे आप इसे दुर्घटना से नष्ट करने की संभावना नहीं रखते हैं, लेकिन जहाँ आपको आवश्यकता हो, वहाँ भी इसे आसानी से पा सकते हैं।
स्क्रिप्ट चलाने
PowerShell सिर्फ एक स्क्रिप्ट autorun नहीं कर सकते। एक अंतर्निहित सुरक्षा उपाय है जो इसे ऐसा करने से रोकता है लेकिन इसके चारों ओर एक रास्ता है। हमारे पास एक विस्तृत लेख है कि आप ऐसा कैसे कर सकते हैं। आपके द्वारा अभी-अभी बनाए गए PowerShell स्क्रिप्ट को स्वतः चलाने के लिए निर्देशों का पालन करें, और अपने पीसी को बूट करने के लिए स्क्रिप्ट को शुरू करने के लिए एक निर्धारित कार्य का उपयोग करें।
वैकल्पिक रूप से, आप अपने सिस्टम को बूट करते समय स्क्रिप्ट को मैन्युअल रूप से चला सकते हैं। मैं 30 मिनट से कम समय से इसका उपयोग कर रहा हूं और मुझे नहीं पता कि मैं इसके बिना कैसे जी रहा था।
टिप्पणियाँ