mirror of
https://github.com/greenshot/greenshot
synced 2025-08-20 21:43:24 -07:00
Code cleanup, already made some changes (which are not active) for the next release so I can work on them without having multiple changed files which might cause check in conflicts.
git-svn-id: http://svn.code.sf.net/p/greenshot/code/trunk@2359 7dccd23d-a4a3-4e1f-8c07-b4c1b4018ab4
This commit is contained in:
parent
70d6b0356b
commit
82eddefe4e
5 changed files with 435 additions and 318 deletions
|
@ -26,239 +26,25 @@ using System.Runtime.InteropServices;
|
|||
using System.Text;
|
||||
|
||||
namespace GreenshotPlugin.UnmanagedHelpers {
|
||||
/// <summary>
|
||||
/// Used with EnumWindows or EnumChildWindows
|
||||
/// </summary>
|
||||
/// <param name="hwnd"></param>
|
||||
/// <param name="lParam"></param>
|
||||
/// <returns></returns>
|
||||
public delegate int EnumWindowsProc(IntPtr hwnd, int lParam);
|
||||
|
||||
[StructLayout(LayoutKind.Sequential), Serializable()]
|
||||
public struct POINT {
|
||||
public int X;
|
||||
public int Y;
|
||||
|
||||
public POINT(int x, int y) {
|
||||
this.X = x;
|
||||
this.Y = y;
|
||||
}
|
||||
public POINT(Point point) {
|
||||
this.X = point.X;
|
||||
this.Y = point.Y;
|
||||
}
|
||||
|
||||
public static implicit operator System.Drawing.Point(POINT p) {
|
||||
return new System.Drawing.Point(p.X, p.Y);
|
||||
}
|
||||
|
||||
public static implicit operator POINT(System.Drawing.Point p) {
|
||||
return new POINT(p.X, p.Y);
|
||||
}
|
||||
|
||||
public Point ToPoint() {
|
||||
return new Point(X, Y);
|
||||
}
|
||||
|
||||
override public string ToString() {
|
||||
return X +","+Y;
|
||||
}
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential), Serializable()]
|
||||
public struct RECT {
|
||||
private int _Left;
|
||||
private int _Top;
|
||||
private int _Right;
|
||||
private int _Bottom;
|
||||
|
||||
public RECT(RECT rectangle) : this(rectangle.Left, rectangle.Top, rectangle.Right, rectangle.Bottom) {
|
||||
}
|
||||
public RECT(Rectangle rectangle) : this(rectangle.Left, rectangle.Top, rectangle.Right, rectangle.Bottom) {
|
||||
}
|
||||
public RECT(int Left, int Top, int Right, int Bottom) {
|
||||
_Left = Left;
|
||||
_Top = Top;
|
||||
_Right = Right;
|
||||
_Bottom = Bottom;
|
||||
}
|
||||
|
||||
public int X {
|
||||
get { return _Left; }
|
||||
set { _Left = value; }
|
||||
}
|
||||
public int Y {
|
||||
get { return _Top; }
|
||||
set { _Top = value; }
|
||||
}
|
||||
public int Left {
|
||||
get { return _Left; }
|
||||
set { _Left = value; }
|
||||
}
|
||||
public int Top {
|
||||
get { return _Top; }
|
||||
set { _Top = value; }
|
||||
}
|
||||
public int Right {
|
||||
get { return _Right; }
|
||||
set { _Right = value; }
|
||||
}
|
||||
public int Bottom {
|
||||
get { return _Bottom; }
|
||||
set { _Bottom = value; }
|
||||
}
|
||||
public int Height {
|
||||
get { return _Bottom - _Top; }
|
||||
set { _Bottom = value - _Top; }
|
||||
}
|
||||
public int Width {
|
||||
get { return _Right - _Left; }
|
||||
set { _Right = value + _Left; }
|
||||
}
|
||||
public Point Location {
|
||||
get { return new Point(Left, Top); }
|
||||
set {
|
||||
_Left = value.X;
|
||||
_Top = value.Y;
|
||||
}
|
||||
}
|
||||
public Size Size {
|
||||
get { return new Size(Width, Height); }
|
||||
set {
|
||||
_Right = value.Width + _Left;
|
||||
_Bottom = value.Height + _Top;
|
||||
}
|
||||
}
|
||||
|
||||
public static implicit operator Rectangle(RECT Rectangle) {
|
||||
return new Rectangle(Rectangle.Left, Rectangle.Top, Rectangle.Width, Rectangle.Height);
|
||||
}
|
||||
public static implicit operator RECT(Rectangle Rectangle) {
|
||||
return new RECT(Rectangle.Left, Rectangle.Top, Rectangle.Right, Rectangle.Bottom);
|
||||
}
|
||||
public static bool operator ==(RECT Rectangle1, RECT Rectangle2)
|
||||
{
|
||||
return Rectangle1.Equals(Rectangle2);
|
||||
}
|
||||
public static bool operator !=(RECT Rectangle1, RECT Rectangle2) {
|
||||
return !Rectangle1.Equals(Rectangle2);
|
||||
}
|
||||
|
||||
public override string ToString() {
|
||||
return "{Left: " + _Left + "; " + "Top: " + _Top + "; Right: " + _Right + "; Bottom: " + _Bottom + "}";
|
||||
}
|
||||
|
||||
public override int GetHashCode() {
|
||||
return ToString().GetHashCode();
|
||||
}
|
||||
|
||||
public bool Equals(RECT Rectangle) {
|
||||
return Rectangle.Left == _Left && Rectangle.Top == _Top && Rectangle.Right == _Right && Rectangle.Bottom == _Bottom;
|
||||
}
|
||||
|
||||
public Rectangle ToRectangle() {
|
||||
return new Rectangle(Left, Top, Width, Height);
|
||||
}
|
||||
public override bool Equals(object Object) {
|
||||
if (Object is RECT) {
|
||||
return Equals((RECT)Object);
|
||||
} else if (Object is Rectangle) {
|
||||
return Equals(new RECT((Rectangle)Object));
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential), Serializable()]
|
||||
public struct WindowInfo {
|
||||
public uint cbSize;
|
||||
public RECT rcWindow;
|
||||
public RECT rcClient;
|
||||
public uint dwStyle;
|
||||
public uint dwExStyle;
|
||||
public uint dwWindowStatus;
|
||||
public uint cxWindowBorders;
|
||||
public uint cyWindowBorders;
|
||||
public ushort atomWindowType;
|
||||
public ushort wCreatorVersion;
|
||||
// Allows automatic initialization of "cbSize" with "new WINDOWINFO(null/true/false)".
|
||||
public WindowInfo(Boolean ? filler) : this() {
|
||||
cbSize = (UInt32)(Marshal.SizeOf(typeof( WindowInfo )));
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Contains information about the placement of a window on the screen.
|
||||
/// Used with SetWinEventHook
|
||||
/// </summary>
|
||||
[StructLayout(LayoutKind.Sequential), Serializable()]
|
||||
public struct WindowPlacement {
|
||||
/// <summary>
|
||||
/// The length of the structure, in bytes. Before calling the GetWindowPlacement or SetWindowPlacement functions, set this member to sizeof(WINDOWPLACEMENT).
|
||||
/// <para>
|
||||
/// GetWindowPlacement and SetWindowPlacement fail if this member is not set correctly.
|
||||
/// </para>
|
||||
/// </summary>
|
||||
public int Length;
|
||||
|
||||
/// <summary>
|
||||
/// Specifies flags that control the position of the minimized window and the method by which the window is restored.
|
||||
/// </summary>
|
||||
public WindowPlacementFlags Flags;
|
||||
|
||||
/// <summary>
|
||||
/// The current show state of the window.
|
||||
/// </summary>
|
||||
public ShowWindowCommand ShowCmd;
|
||||
|
||||
/// <summary>
|
||||
/// The coordinates of the window's upper-left corner when the window is minimized.
|
||||
/// </summary>
|
||||
public POINT MinPosition;
|
||||
|
||||
/// <summary>
|
||||
/// The coordinates of the window's upper-left corner when the window is maximized.
|
||||
/// </summary>
|
||||
public POINT MaxPosition;
|
||||
|
||||
/// <summary>
|
||||
/// The window's coordinates when the window is in the restored position.
|
||||
/// </summary>
|
||||
public RECT NormalPosition;
|
||||
|
||||
/// <summary>
|
||||
/// Gets the default (empty) value.
|
||||
/// </summary>
|
||||
public static WindowPlacement Default {
|
||||
get {
|
||||
WindowPlacement result = new WindowPlacement();
|
||||
result.Length = Marshal.SizeOf( result );
|
||||
return result;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct CursorInfo {
|
||||
public Int32 cbSize;
|
||||
public Int32 flags;
|
||||
public IntPtr hCursor;
|
||||
public POINT ptScreenPos;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct IconInfo {
|
||||
public bool fIcon;
|
||||
public Int32 xHotspot;
|
||||
public Int32 yHotspot;
|
||||
public IntPtr hbmMask;
|
||||
public IntPtr hbmColor;
|
||||
}
|
||||
|
||||
[Serializable, StructLayout(LayoutKind.Sequential)]
|
||||
public struct SCROLLINFO {
|
||||
public int cbSize;
|
||||
public int fMask;
|
||||
public int nMin;
|
||||
public int nMax;
|
||||
public int nPage;
|
||||
public int nPos;
|
||||
public int nTrackPos;
|
||||
}
|
||||
/// <param name="hWinEventHook"></param>
|
||||
/// <param name="eventType"></param>
|
||||
/// <param name="hwnd"></param>
|
||||
/// <param name="idObject"></param>
|
||||
/// <param name="idChild"></param>
|
||||
/// <param name="dwEventThread"></param>
|
||||
/// <param name="dwmsEventTime"></param>
|
||||
public delegate void WinEventDelegate(IntPtr hWinEventHook, WinEvent eventType, IntPtr hwnd, EventObjects idObject, int idChild, uint dwEventThread, uint dwmsEventTime);
|
||||
|
||||
/// <summary>
|
||||
/// User32 Wrappers
|
||||
|
@ -276,32 +62,6 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
public const int MONITOR_DEFAULTTONULL = 0;
|
||||
public const int MONITOR_DEFAULTTOPRIMARY = 1;
|
||||
public const int MONITOR_DEFAULTTONEAREST = 2;
|
||||
|
||||
/// <summary>
|
||||
/// Stop flashing. The system restores the window to its original state.
|
||||
/// </summary>
|
||||
public const int FLASHW_STOP = 0;
|
||||
/// <summary>
|
||||
/// Flash the window caption.
|
||||
/// </summary>
|
||||
public const int FLASHW_CAPTION = 0x00000001;
|
||||
/// <summary>
|
||||
/// Flash the taskbar button.
|
||||
/// </summary>
|
||||
public const int FLASHW_TRAY = 0x00000002;
|
||||
/// <summary>
|
||||
/// Flash both the window caption and taskbar button.
|
||||
/// </summary>
|
||||
public const int FLASHW_ALL = (FLASHW_CAPTION | FLASHW_TRAY);
|
||||
/// <summary>
|
||||
/// Flash continuously, until the FLASHW_STOP flag is set.
|
||||
/// </summary>
|
||||
public const int FLASHW_TIMER = 0x00000004;
|
||||
/// <summary>
|
||||
/// Flash continuously until the window comes to the foreground.
|
||||
/// </summary>
|
||||
public const int FLASHW_TIMERNOFG = 0x0000000C;
|
||||
|
||||
public const Int32 CURSOR_SHOWING = 0x00000001;
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
|
@ -364,20 +124,6 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
public static extern IntPtr MonitorFromWindow(IntPtr hwnd, uint dwFlags);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr MonitorFromRect([In] ref RECT lprc, uint dwFlags);
|
||||
|
||||
/// <summary>
|
||||
/// Wrapper for the GetWindowLong which decides if the system is 64-bit or not and calls the right one.
|
||||
/// </summary>
|
||||
/// <param name="hwnd"></param>
|
||||
/// <param name="nIndex"></param>
|
||||
/// <returns></returns>
|
||||
public static uint GetWindowLongWrapper(IntPtr hwnd, int nIndex) {
|
||||
if (IntPtr.Size == 8) {
|
||||
return GetWindowLongPtr(hwnd, nIndex);
|
||||
} else {
|
||||
return GetWindowLong(hwnd, nIndex);
|
||||
}
|
||||
}
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
[return: MarshalAs(UnmanagedType.Bool)]
|
||||
public static extern bool GetWindowInfo(IntPtr hwnd, ref WindowInfo pwi);
|
||||
|
@ -420,7 +166,13 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
[DllImport("user32", SetLastError = true, CharSet = CharSet.Auto)]
|
||||
public static extern bool ChangeClipboardChain(IntPtr hWndRemove, IntPtr hWndNewNext);
|
||||
|
||||
// Added for finding Metro apps
|
||||
// Added for WinEventHook logic, Greenshot 1.2
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool UnhookWinEvent(IntPtr hWinEventHook);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr SetWinEventHook(WinEvent eventMin, WinEvent eventMax, IntPtr hmodWinEventProc, WinEventDelegate lpfnWinEventProc, int idProcess, int idThread, WinEventHookFlags dwFlags);
|
||||
|
||||
// Added for finding Metro apps, Greenshot 1.1
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr FindWindow(string lpClassName, string lpWindowName);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
|
@ -435,6 +187,53 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
///
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern uint GetGuiResources(IntPtr hProcess, uint uiFlags);
|
||||
[DllImport("user32", EntryPoint = "RegisterWindowMessageA", SetLastError = true)]
|
||||
public static extern uint RegisterWindowMessage(string lpString);
|
||||
[DllImport("user32", SetLastError=true, CharSet=CharSet.Auto)]
|
||||
public static extern IntPtr SendMessageTimeout(IntPtr hWnd, uint Msg, IntPtr wParam, IntPtr lParam, SendMessageTimeoutFlags fuFlags, uint uTimeout, out UIntPtr lpdwResult);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetPhysicalCursorPos(out POINT cursorLocation);
|
||||
[DllImport("user32", SetLastError=true)]
|
||||
public static extern int MapWindowPoints(IntPtr hwndFrom, IntPtr hwndTo, ref POINT lpPoints, [MarshalAs(UnmanagedType.U4)] int cPoints);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern int GetSystemMetrics(SystemMetric index);
|
||||
|
||||
/// <summary>
|
||||
/// The following is used for Icon handling
|
||||
/// </summary>
|
||||
/// <param name="hIcon"></param>
|
||||
/// <returns></returns>
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr CopyIcon(IntPtr hIcon);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool DestroyIcon(IntPtr hIcon);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetCursorInfo(out CursorInfo cursorInfo);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetIconInfo(IntPtr hIcon, out IconInfo iconInfo);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool DrawIcon(IntPtr hDC, int X, int Y, IntPtr hIcon);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr SetCapture(IntPtr hWnd);
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
[return: MarshalAs(UnmanagedType.Bool)]
|
||||
public static extern bool ReleaseCapture();
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr CreateIconIndirect(ref IconInfo icon);
|
||||
|
||||
/// <summary>
|
||||
/// Wrapper for the GetWindowLong which decides if the system is 64-bit or not and calls the right one.
|
||||
/// </summary>
|
||||
/// <param name="hwnd"></param>
|
||||
/// <param name="nIndex"></param>
|
||||
/// <returns></returns>
|
||||
public static uint GetWindowLongWrapper(IntPtr hwnd, int nIndex) {
|
||||
if (IntPtr.Size == 8) {
|
||||
return GetWindowLongPtr(hwnd, nIndex);
|
||||
} else {
|
||||
return GetWindowLong(hwnd, nIndex);
|
||||
}
|
||||
}
|
||||
|
||||
public static uint GetGuiResourcesGDICount() {
|
||||
return GetGuiResources(Process.GetCurrentProcess().Handle, 0);
|
||||
|
@ -444,11 +243,6 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
return GetGuiResources(Process.GetCurrentProcess().Handle, 1);
|
||||
}
|
||||
|
||||
[DllImport("user32", EntryPoint = "RegisterWindowMessageA", SetLastError = true)]
|
||||
public static extern uint RegisterWindowMessage(string lpString);
|
||||
[DllImport("user32", SetLastError=true, CharSet=CharSet.Auto)]
|
||||
public static extern IntPtr SendMessageTimeout(IntPtr hWnd, uint Msg, IntPtr wParam, IntPtr lParam, SendMessageTimeoutFlags fuFlags, uint uTimeout, out UIntPtr lpdwResult);
|
||||
|
||||
/// <summary>
|
||||
/// Helper method to create a Win32 exception with the windows message in it
|
||||
/// </summary>
|
||||
|
@ -456,45 +250,8 @@ namespace GreenshotPlugin.UnmanagedHelpers {
|
|||
/// <returns>Exception</returns>
|
||||
public static Exception CreateWin32Exception(string method) {
|
||||
Win32Exception exceptionToThrow = new Win32Exception();
|
||||
exceptionToThrow.Data.Add("Method", method);
|
||||
exceptionToThrow.Data.Add("Method", method);
|
||||
return exceptionToThrow;
|
||||
}
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetPhysicalCursorPos(out POINT cursorLocation);
|
||||
|
||||
[DllImport("user32", SetLastError=true)]
|
||||
public static extern int MapWindowPoints(IntPtr hwndFrom, IntPtr hwndTo, ref POINT lpPoints, [MarshalAs(UnmanagedType.U4)] int cPoints);
|
||||
|
||||
#region icon
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr CopyIcon(IntPtr hIcon);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool DestroyIcon(IntPtr hIcon);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetCursorInfo(out CursorInfo cursorInfo);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool GetIconInfo(IntPtr hIcon, out IconInfo iconInfo);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern bool DrawIcon(IntPtr hDC, int X, int Y, IntPtr hIcon);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr SetCapture(IntPtr hWnd);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
[return: MarshalAs(UnmanagedType.Bool)]
|
||||
public static extern bool ReleaseCapture();
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern int GetSystemMetrics(SystemMetric index);
|
||||
|
||||
[DllImport("user32", SetLastError = true)]
|
||||
public static extern IntPtr CreateIconIndirect(ref IconInfo icon);
|
||||
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue