दिलचस्प पोस्ट
एक अमेज़ॅन Ec2 उदाहरण – अनुमति त्रुटि में SSH की कोशिश कर रहा है सी ++ में एक वेक्टर को कैसे प्रारंभ करें Excel फ़ाइल (.xls / .xlsx) को पढ़ने का सर्वोत्तम तरीका क्या सत्र की हत्या किए बिना ओरेकल में एक ही क्वेरी को मारना संभव है? facebook: स्थायी पृष्ठ एक्सेस टोकन? twitter4j => AndroidRuntime (446): java.lang.NoClassDefFound त्रुटि: twitter4j.http.AccessToken क्या जावा रेगएक्स केस-असंवेदनशील है? बिटमैप आकार बदलने के बिना कैसे बिटमैप को सेकेंड करना है? jboss 7 ऑरेकल डाटासॉर कॉन्फ़िगरेशन MySQL: # 126 – तालिका के लिए गलत कुंजी फ़ाइल यह क्रिया पूरी नहीं की जा सकती पुनः प्रयास करें (-22421) जावा: अनंत लूप स्कैनर का उपयोग करके hasNextInt () कैसे एमएलसी में नियंत्रक में DropDownList चयनित मूल्य प्राप्त करने के लिए एजेक्स अद्यतन / रेंडर के लिए घटक का क्लाइंट आईडी कैसे पता चलेगा? "बार" से संदर्भित "foo" अभिव्यक्ति वाले घटक नहीं मिल सकते पंडों में 'पार्श्व दृश्य विस्फोट ()' कैसे करें

मैं टास्कबार की स्थिति और आकार कैसे प्राप्त करूं?

मैं जानना चाहता हूँ कि आयत (नीचे, ऊपर, बायीं और दाएं) कैसे प्राप्त करें, जो कि टास्कबार में रहती है मैं इसे सी # में कैसे करूँ?

Solutions Collecting From Web of "मैं टास्कबार की स्थिति और आकार कैसे प्राप्त करूं?"

आपको कुछ विंडोज़ एपीआई कॉल करना है:

http://winsharp93.wordpress.com/2009/06/29/find-out-size-and-position-of-the-taskbar/

  private enum TaskBarLocation { TOP, BOTTOM, LEFT, RIGHT} private TaskBarLocation GetTaskBarLocation() { TaskBarLocation taskBarLocation = TaskBarLocation.BOTTOM; bool taskBarOnTopOrBottom = (Screen.PrimaryScreen.WorkingArea.Width == Screen.PrimaryScreen.Bounds.Width); if (taskBarOnTopOrBottom) { if (Screen.PrimaryScreen.WorkingArea.Top > 0) taskBarLocation = TaskBarLocation.TOP; } else { if (Screen.PrimaryScreen.WorkingArea.Left > 0) { taskBarLocation = TaskBarLocation.LEFT; } else { taskBarLocation = TaskBarLocation.RIGHT; } } return taskBarLocation; } 

यह वास्तव में अधिक जटिल है जैसा कि ऊपर दिखाया गया है एक बात के लिए, कार्य पट्टी प्राथमिक स्क्रीन पर नहीं होती है, इसे किसी भी स्क्रीन पर खींचा जा सकता है। दूसरे के लिए, सिद्धांत में कुछ दिए गए स्क्रीन के प्रत्येक किनारे पर डॉक किया जा सकता है। उपरोक्त कोड गलत तरीके से मानता है कि कुछ किनारों को डॉक करने के लिए कुछ अन्य किनारों को शामिल नहीं किया जा रहा है।

टास्क बार के स्थान का एकमात्र तरीका निश्चित रूप से बनाम वर्किंग से व्युत्पन्न किया जा सकता है, अगर सभी स्क्रीनों में से केवल एक ही बढ़त उसको डॉक किया होता।

निम्नलिखित फ़ंक्शंस आयत की एक सरणी देता है, प्रत्येक एक डॉक कार्य पट्टी का प्रतिनिधित्व करता है, और इसके byref पैरामीटर को गिनती लिखता है। अगर वह गणना 1 है, तो लौटे हुए सरणी का तत्व 0 कार्य पट्टी से आयताकार है। यदि 1 से अधिक, अनुमान लगाने का समय है?

 Public Function FindDockedTaskBars(ByRef DockedRectCounter As Integer) As Rectangle() Dim TmpScrn As Screen = Nothing Dim LeftDockedWidth As Integer = 0 Dim TopDockedHeight As Integer = 0 Dim RightDockedWidth As Integer = 0 Dim BottomDockedHeight As Integer = 0 Dim DockedRects(Screen.AllScreens.Count * 4) As Rectangle DockedRectCounter = 0 For Each TmpScrn In Screen.AllScreens If Not TmpScrn.Bounds.Equals(TmpScrn.WorkingArea) Then LeftDockedWidth = Math.Abs(Math.Abs(TmpScrn.Bounds.Left) - Math.Abs(TmpScrn.WorkingArea.Left)) TopDockedHeight = Math.Abs(Math.Abs(TmpScrn.Bounds.Top) - Math.Abs(TmpScrn.WorkingArea.Top)) RightDockedWidth = (TmpScrn.Bounds.Width - LeftDockedWidth) - TmpScrn.WorkingArea.Width BottomDockedHeight = (TmpScrn.Bounds.Height - TopDockedHeight) - TmpScrn.WorkingArea.Height If LeftDockedWidth > 0 Then DockedRects(DockedRectCounter).X = TmpScrn.Bounds.Left DockedRects(DockedRectCounter).Y = TmpScrn.Bounds.Top DockedRects(DockedRectCounter).Width = LeftDockedWidth DockedRects(DockedRectCounter).Height = TmpScrn.Bounds.Height DockedRectCounter += 1 End If If RightDockedWidth > 0 Then DockedRects(DockedRectCounter).X = TmpScrn.WorkingArea.Right DockedRects(DockedRectCounter).Y = TmpScrn.Bounds.Top DockedRects(DockedRectCounter).Width = RightDockedWidth DockedRects(DockedRectCounter).Height = TmpScrn.Bounds.Height DockedRectCounter += 1 End If If TopDockedHeight > 0 Then DockedRects(DockedRectCounter).X = TmpScrn.WorkingArea.Left DockedRects(DockedRectCounter).Y = TmpScrn.Bounds.Top DockedRects(DockedRectCounter).Width = TmpScrn.WorkingArea.Width DockedRects(DockedRectCounter).Height = TopDockedHeight DockedRectCounter += 1 End If If BottomDockedHeight > 0 Then DockedRects(DockedRectCounter).X = TmpScrn.WorkingArea.Left DockedRects(DockedRectCounter).Y = TmpScrn.WorkingArea.Bottom DockedRects(DockedRectCounter).Width = TmpScrn.WorkingArea.Width DockedRects(DockedRectCounter).Height = BottomDockedHeight DockedRectCounter += 1 End If End If Next Return DockedRects End Function 

या आप में से उन लोगों के लिए जो सी # पसंद करते हैं … (ध्यान दें: यह पोर्टेड कोड अप्रयुक्त है)

 using System.Drawing; using System.Windows.Forms; public Rectangle[] FindDockedTaskBars(ref int DockedRectCounter) { int LeftDockedWidth = 0; int TopDockedHeight = 0; int RightDockedWidth = 0; int BottomDockedHeight = 0; Rectangle[] DockedRects = new Rectangle[Screen.AllScreens.Count() * 4]; DockedRectCounter = 0; foreach (Screen TmpScrn in Screen.AllScreens) { if (!TmpScrn.Bounds.Equals(TmpScrn.WorkingArea)) { LeftDockedWidth = Math.Abs(Math.Abs(TmpScrn.Bounds.Left) - Math.Abs(TmpScrn.WorkingArea.Left)); TopDockedHeight = Math.Abs(Math.Abs(TmpScrn.Bounds.Top) - Math.Abs(TmpScrn.WorkingArea.Top)); RightDockedWidth = (TmpScrn.Bounds.Width - LeftDockedWidth) - TmpScrn.WorkingArea.Width; BottomDockedHeight = (TmpScrn.Bounds.Height - TopDockedHeight) - TmpScrn.WorkingArea.Height; if (LeftDockedWidth > 0) { DockedRects[DockedRectCounter].X = TmpScrn.Bounds.Left; DockedRects[DockedRectCounter].Y = TmpScrn.Bounds.Top; DockedRects[DockedRectCounter].Width = LeftDockedWidth; DockedRects[DockedRectCounter].Height = TmpScrn.Bounds.Height; DockedRectCounter += 1; } if (RightDockedWidth > 0) { DockedRects[DockedRectCounter].X = TmpScrn.WorkingArea.Right; DockedRects[DockedRectCounter].Y = TmpScrn.Bounds.Top; DockedRects[DockedRectCounter].Width = RightDockedWidth; DockedRects[DockedRectCounter].Height = TmpScrn.Bounds.Height; DockedRectCounter += 1; } if (TopDockedHeight > 0) { DockedRects[DockedRectCounter].X = TmpScrn.WorkingArea.Left; DockedRects[DockedRectCounter].Y = TmpScrn.Bounds.Top; DockedRects[DockedRectCounter].Width = TmpScrn.WorkingArea.Width; DockedRects[DockedRectCounter].Height = TopDockedHeight; DockedRectCounter += 1; } if (BottomDockedHeight > 0) { DockedRects[DockedRectCounter].X = TmpScrn.WorkingArea.Left; DockedRects[DockedRectCounter].Y = TmpScrn.WorkingArea.Bottom; DockedRects[DockedRectCounter].Width = TmpScrn.WorkingArea.Width; DockedRects[DockedRectCounter].Height = BottomDockedHeight; DockedRectCounter += 1; } } } return DockedRects; } 
 private enum TaskBarLocation { TOP, BOTTOM, LEFT, RIGHT } private TaskBarLocation GetTaskBarLocation() { //System.Windows.SystemParameters.... if (SystemParameters.WorkArea.Left > 0) return TaskBarLocation.LEFT; if (SystemParameters.WorkArea.Top > 0) return TaskBarLocation.TOP; if (SystemParameters.WorkArea.Left == 0 && SystemParameters.WorkArea.Width < SystemParameters.PrimaryScreenWidth) return TaskBarLocation.RIGHT; return TaskBarLocation.BOTTOM; } 

यह सी # में Mark McGinty से उत्तर है

यह कोड आयत की सूची के रूप में सभी कार्य सलाखों को वापस लाता है:

  • 0 आयत का मतलब है कि टास्कबार छिपा हुआ है;
  • 1 आयत टास्कबार की स्थिति है;
  • 2+ बहुत दुर्लभ है, इसका मतलब है कि हमारे पास कई मॉनिटर हैं, और हम एक एकल वर्चुअल डेस्कटॉप बनाने के लिए Extend these displays का Extend these displays नहीं कर रहे हैं।

हर स्थिति में काम करता है

यह अच्छी तरह से काम करता है:

  • विंडोज 7 (लगभग निश्चित रूप से विंडोज 8.1 और विंडोज 10 पर काम करेगा)।
  • सेटिंग्स के सभी संयोजन

यहां छवि विवरण दर्ज करें

सी # कोड

 public static List<Rectangle> FindDockedTaskBars() { List<Rectangle> dockedRects = new List<Rectangle>(); foreach (var tmpScrn in Screen.AllScreens) { if (!tmpScrn.Bounds.Equals(tmpScrn.WorkingArea)) { Rectangle rect = new Rectangle(); var leftDockedWidth = Math.Abs((Math.Abs(tmpScrn.Bounds.Left) - Math.Abs(tmpScrn.WorkingArea.Left))); var topDockedHeight = Math.Abs((Math.Abs(tmpScrn.Bounds.Top) - Math.Abs(tmpScrn.WorkingArea.Top))); var rightDockedWidth = ((tmpScrn.Bounds.Width - leftDockedWidth) - tmpScrn.WorkingArea.Width); var bottomDockedHeight = ((tmpScrn.Bounds.Height - topDockedHeight) - tmpScrn.WorkingArea.Height); if ((leftDockedWidth > 0)) { rect.X = tmpScrn.Bounds.Left; rect.Y = tmpScrn.Bounds.Top; rect.Width = leftDockedWidth; rect.Height = tmpScrn.Bounds.Height; } else if ((rightDockedWidth > 0)) { rect.X = tmpScrn.WorkingArea.Right; rect.Y = tmpScrn.Bounds.Top; rect.Width = rightDockedWidth; rect.Height = tmpScrn.Bounds.Height; } else if ((topDockedHeight > 0)) { rect.X = tmpScrn.WorkingArea.Left; rect.Y = tmpScrn.Bounds.Top; rect.Width = tmpScrn.WorkingArea.Width; rect.Height = topDockedHeight; } else if ((bottomDockedHeight > 0)) { rect.X = tmpScrn.WorkingArea.Left; rect.Y = tmpScrn.WorkingArea.Bottom; rect.Width = tmpScrn.WorkingArea.Width; rect.Height = bottomDockedHeight; } else { // Nothing found! } dockedRects.Add(rect); } } if (dockedRects.Count == 0) { // Taskbar is set to "Auto-Hide". } return dockedRects; } 

यह wpf और बहु ​​स्क्रीन समर्थन के साथ winforms का उपयोग कर एक सरल उदाहरण है:

 Screen sc = Screen.FromHandle(new WindowInteropHelper(this).Handle); if (sc.WorkingArea.Top > 0) { // TASKBAR TOP } else if (sc.WorkingArea.Left != sc.Bounds.X) { // TASKBAR LEFT } else if ((sc.Bounds.Height - sc.WorkingArea.Height) > 0) { // TASKBAR BOTTOM } else if (sc.WorkingArea.Right != 0) { // TASKBAR RIGHT } else { // TASKBAR NOT FOUND } 

दाऊद के जवाब के आधार पर, यह एक बेहतर कार्यान्वयन है जो पी / आवेज़ का उपयोग करता है जो कार्यस्थल के प्लेसमेंट और आकार को ठीक से निर्धारित करता है। मैं अभी तक केवल एकमात्र सीमा जानता हूं कि जब यह विस्तारित मोड में कई मॉनिटरों को प्रदर्शित करने के लिए सेट किया गया है, तो वह सही सीमा वापस नहीं लौटती है।

बाद के सभी अद्यतनों के साथ कोड https://git.io/v9bCx पर एक सार के रूप में उपलब्ध है।

 /****************************************************************************** * Name: Taskbar.cs * Description: Class to get the taskbar's position, size and other properties. * Author: Franz Alex Gaisie-Essilfie * based on code from https://winsharp93.wordpress.com/2009/06/29/find-out-size-and-position-of-the-taskbar/ * * Change Log: * Date | Description * -------------|-------------------------------------------------------------- * 2017-05-16 | Initial design */ using System; using System.Drawing; using System.Runtime.InteropServices; namespace System.Windows.Forms { public enum TaskbarPosition { Unknown = -1, Left, Top, Right, Bottom, } public static class Taskbar { private enum ABS { AutoHide = 0x01, AlwaysOnTop = 0x02, } ////private enum ABE : uint private enum AppBarEdge : uint { Left = 0, Top = 1, Right = 2, Bottom = 3 } ////private enum ABM : uint private enum AppBarMessage : uint { New = 0x00000000, Remove = 0x00000001, QueryPos = 0x00000002, SetPos = 0x00000003, GetState = 0x00000004, GetTaskbarPos = 0x00000005, Activate = 0x00000006, GetAutoHideBar = 0x00000007, SetAutoHideBar = 0x00000008, WindowPosChanged = 0x00000009, SetState = 0x0000000A, } private const string ClassName = "Shell_TrayWnd"; private static APPBARDATA _appBarData; /// <summary>Static initializer of the <see cref="Taskbar" /> class.</summary> static Taskbar() { _appBarData = new APPBARDATA { cbSize = (uint)Marshal.SizeOf(typeof(APPBARDATA)), hWnd = FindWindow(Taskbar.ClassName, null) }; } /// <summary> /// Gets a value indicating whether the taskbar is always on top of other windows. /// </summary> /// <value><c>true</c> if the taskbar is always on top of other windows; otherwise, <c>false</c>.</value> /// <remarks>This property always returns <c>false</c> on Windows 7 and newer.</remarks> public static bool AlwaysOnTop { get { int state = SHAppBarMessage(AppBarMessage.GetState, ref _appBarData).ToInt32(); return ((ABS)state).HasFlag(ABS.AlwaysOnTop); } } /// <summary> /// Gets a value indicating whether the taskbar is automatically hidden when inactive. /// </summary> /// <value><c>true</c> if the taskbar is set to auto-hide is enabled; otherwise, <c>false</c>.</value> public static bool AutoHide { get { int state = SHAppBarMessage(AppBarMessage.GetState, ref _appBarData).ToInt32(); return ((ABS)state).HasFlag(ABS.AutoHide); } } /// <summary>Gets the current display bounds of the taskbar.</summary> public static Rectangle CurrentBounds { get { var rect = new RECT(); if (GetWindowRect(Handle, ref rect)) return Rectangle.FromLTRB(rect.Left, rect.Top, rect.Right, rect.Bottom); return Rectangle.Empty; } } /// <summary>Gets the display bounds when the taskbar is fully visible.</summary> public static Rectangle DisplayBounds { get { if (RefreshBoundsAndPosition()) return Rectangle.FromLTRB(_appBarData.rect.Left, _appBarData.rect.Top, _appBarData.rect.Right, _appBarData.rect.Bottom); return CurrentBounds; } } /// <summary>Gets the taskbar's window handle.</summary> public static IntPtr Handle { get { return _appBarData.hWnd; } } /// <summary>Gets the taskbar's position on the screen.</summary> public static TaskbarPosition Position { get { if (RefreshBoundsAndPosition()) return (TaskbarPosition)_appBarData.uEdge; return TaskbarPosition.Unknown; } } /// <summary>Hides the taskbar.</summary> public static void Hide() { const int SW_HIDE = 0; ShowWindow(Handle, SW_HIDE); } /// <summary>Shows the taskbar.</summary> public static void Show() { const int SW_SHOW = 1; ShowWindow(Handle, SW_SHOW); } private static bool RefreshBoundsAndPosition() { //! SHAppBarMessage returns IntPtr.Zero **if it fails** return SHAppBarMessage(AppBarMessage.GetTaskbarPos, ref _appBarData) != IntPtr.Zero; } #region DllImports [DllImport("user32.dll", SetLastError = true)] private static extern IntPtr FindWindow(string lpClassName, string lpWindowName); [DllImport("user32.dll")] [return: MarshalAs(UnmanagedType.Bool)] private static extern bool GetWindowRect(IntPtr hWnd, ref RECT lpRect); [DllImport("shell32.dll", SetLastError = true)] private static extern IntPtr SHAppBarMessage(AppBarMessage dwMessage, [In] ref APPBARDATA pData); [DllImport("user32.dll")] private static extern int ShowWindow(IntPtr hwnd, int command); #endregion DllImports [StructLayout(LayoutKind.Sequential)] private struct APPBARDATA { public uint cbSize; public IntPtr hWnd; public uint uCallbackMessage; public AppBarEdge uEdge; public RECT rect; public int lParam; } [StructLayout(LayoutKind.Sequential)] private struct RECT { public int Left; public int Top; public int Right; public int Bottom; } } }