2019-09-04 18:26:26 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
2020-03-09 19:22:53 +01:00
|
|
|
/**
|
|
|
|
|
* Class representing one zone inside applied zone layout, which is basically wrapper around rectangle structure.
|
|
|
|
|
*/
|
2019-09-04 18:26:26 +02:00
|
|
|
interface __declspec(uuid("{8228E934-B6EF-402A-9892-15A1441BF8B0}")) IZone : public IUnknown
|
|
|
|
|
{
|
2020-03-09 19:22:53 +01:00
|
|
|
/**
|
|
|
|
|
* @returns Zone coordinates (top-left and bottom-right corner) represented as RECT structure.
|
|
|
|
|
*/
|
2019-09-04 18:26:26 +02:00
|
|
|
IFACEMETHOD_(RECT, GetZoneRect)() = 0;
|
2020-03-09 19:22:53 +01:00
|
|
|
/**
|
|
|
|
|
* @param id Zone identifier.
|
|
|
|
|
*/
|
2019-09-04 18:26:26 +02:00
|
|
|
IFACEMETHOD_(void, SetId)(size_t id) = 0;
|
2020-03-09 19:22:53 +01:00
|
|
|
/**
|
2020-04-10 16:09:08 +02:00
|
|
|
* @returns Zone identifier.
|
2020-03-09 19:22:53 +01:00
|
|
|
*/
|
2019-09-04 18:26:26 +02:00
|
|
|
IFACEMETHOD_(size_t, Id)() = 0;
|
2020-04-10 16:09:08 +02:00
|
|
|
/**
|
|
|
|
|
* Compute the coordinates of the rectangle to which a window should be resized.
|
|
|
|
|
*
|
|
|
|
|
* @param window Handle of window which should be assigned to zone.
|
|
|
|
|
* @param zoneWindow The m_window of a ZoneWindow, it's a hidden window representing the
|
|
|
|
|
* current monitor desktop work area.
|
|
|
|
|
* @returns a RECT structure, describing global coordinates to which a window should be resized
|
|
|
|
|
*/
|
|
|
|
|
IFACEMETHOD_(RECT, ComputeActualZoneRect)(HWND window, HWND zoneWindow) = 0;
|
|
|
|
|
|
2019-09-04 18:26:26 +02:00
|
|
|
};
|
|
|
|
|
|
2020-02-10 14:59:51 +01:00
|
|
|
winrt::com_ptr<IZone> MakeZone(const RECT& zoneRect) noexcept;
|