2020-03-25 22:38:44 +08:00
|
|
|
#pragma once
|
|
|
|
|
2020-07-31 19:06:13 +08:00
|
|
|
#include <common/WinHookEvent.h>
|
|
|
|
|
2020-09-18 21:18:01 +08:00
|
|
|
#include <functional>
|
|
|
|
|
2020-03-25 22:38:44 +08:00
|
|
|
interface IZoneWindow;
|
|
|
|
interface IFancyZonesSettings;
|
|
|
|
interface IZoneSet;
|
|
|
|
|
2020-05-04 22:29:48 +08:00
|
|
|
struct WinHookEvent;
|
|
|
|
|
2020-03-25 22:38:44 +08:00
|
|
|
interface __declspec(uuid("{50D3F0F5-736E-4186-BDF4-3D6BEE150C3A}")) IFancyZones : public IUnknown
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Start and initialize FancyZones.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, Run)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
|
|
|
* Stop FancyZones and do the clean up.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, Destroy)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Core FancyZones functionality.
|
|
|
|
*/
|
|
|
|
interface __declspec(uuid("{2CB37E8F-87E6-4AEC-B4B2-E0FDC873343F}")) IFancyZonesCallback : public IUnknown
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Inform FancyZones that user has switched between virtual desktops.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, VirtualDesktopChanged)
|
|
|
|
() = 0;
|
2020-05-04 22:29:48 +08:00
|
|
|
/**
|
|
|
|
* Callback from WinEventHook to FancyZones
|
|
|
|
*
|
|
|
|
* @param data Handle of window being moved or resized.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, HandleWinHookEvent)
|
|
|
|
(const WinHookEvent* data) = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
|
|
|
* Process keyboard event.
|
|
|
|
*
|
|
|
|
* @param info Information about low level keyboard event.
|
|
|
|
* @returns Boolean indicating if this event should be passed on further to other applications
|
|
|
|
* in event chain, or should it be suppressed.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(bool, OnKeyDown)
|
|
|
|
(PKBDLLHOOKSTRUCT info) = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
|
|
|
* Toggle FancyZones editor application.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, ToggleEditor)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
|
|
|
* Callback triggered when user changes FancyZones settings.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, SettingsChanged)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper functions used by each ZoneWindow (representing work area).
|
|
|
|
*/
|
|
|
|
interface __declspec(uuid("{5C8D99D6-34B2-4F4A-A8E5-7483F6869775}")) IZoneWindowHost : public IUnknown
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Assign window to appropriate zone inside new zone layout.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(void, MoveWindowsOnActiveZoneSetChange)
|
|
|
|
() = 0;
|
|
|
|
/**
|
2020-03-25 22:38:44 +08:00
|
|
|
* @returns Basic zone color.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(COLORREF, GetZoneColor)
|
|
|
|
() = 0;
|
|
|
|
/**
|
2020-03-25 22:38:44 +08:00
|
|
|
* @returns Zone border color.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(COLORREF, GetZoneBorderColor)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
|
|
|
* @returns Color used to highlight zone while giving zone layout hints.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(COLORREF, GetZoneHighlightColor)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
2020-05-26 22:56:25 +08:00
|
|
|
* @returns Integer in range [0, 100] indicating opacity of highlighted zone (while giving zone layout hints).
|
2020-03-25 22:38:44 +08:00
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(int, GetZoneHighlightOpacity)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
/**
|
2020-05-26 22:56:25 +08:00
|
|
|
* @returns Boolean indicating if dragged window should be transparent.
|
2020-03-25 22:38:44 +08:00
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(bool, isMakeDraggedWindowTransparentActive)
|
|
|
|
() = 0;
|
2020-05-22 22:42:29 +08:00
|
|
|
/**
|
|
|
|
* @returns Boolean indicating if move/size operation is currently active.
|
|
|
|
*/
|
2020-07-31 19:06:13 +08:00
|
|
|
IFACEMETHOD_(bool, InMoveSize)
|
|
|
|
() = 0;
|
2020-03-25 22:38:44 +08:00
|
|
|
};
|
|
|
|
|
2020-09-18 21:18:01 +08:00
|
|
|
winrt::com_ptr<IFancyZones> MakeFancyZones(HINSTANCE hinstance, const winrt::com_ptr<IFancyZonesSettings>& settings, std::function<void()> disableCallback) noexcept;
|