diff options
Diffstat (limited to 'opentrack')
| -rw-r--r-- | opentrack/is-window-visible.cpp | 33 | ||||
| -rw-r--r-- | opentrack/is-window-visible.hpp | 38 | 
2 files changed, 36 insertions, 35 deletions
| diff --git a/opentrack/is-window-visible.cpp b/opentrack/is-window-visible.cpp new file mode 100644 index 00000000..fc25bb7d --- /dev/null +++ b/opentrack/is-window-visible.cpp @@ -0,0 +1,33 @@ +#include "is-window-visible.hpp" +#include <QPoint> + +#ifdef _WIN32 + +#include <windows.h> + +OPENTRACK_API_EXPORT bool is_window_visible(const QWidget* widget) +{ +    const QPoint p = widget->mapToGlobal(QPoint(0, 0)); +    const QSize s = widget->size(); + +    const POINT points[] = +    { +        { p.x(), p.y() }, +        { p.x() + s.width(), p.y() }, +        { p.x() + s.width(), p.y() + s.height() }, +        { p.x(), p.y() + s.height() }, +        { p.x() + s.width()/2, p.y() + s.height()/2 }, +    }; + +    for (const POINT& pt : points) +        if (WindowFromPoint(pt) == (HWND) widget->winId()) +            return true; +    return false; +} + +#else +OPENTRACK_API_EXPORT bool is_window_visible(const QWidget* widget) +{ +    return true; +} +#endif diff --git a/opentrack/is-window-visible.hpp b/opentrack/is-window-visible.hpp index fa6aeb53..18c9251a 100644 --- a/opentrack/is-window-visible.hpp +++ b/opentrack/is-window-visible.hpp @@ -1,39 +1,7 @@ -#ifdef _WIN32 +#pragma once -#include <windows.h>  #include <QWidget> -#include <QRect> -#include <QDebug> -#include <QPoint> -#include <initializer_list> +#include "export.hpp" -template<typename=void> -bool is_window_visible(const QWidget* widget) -{ -    const QWidget* window = widget->window(); +OPENTRACK_API_EXPORT bool is_window_visible(const QWidget* widget); -    if (!window) -        return true; - -    const QPoint p = widget->mapToGlobal(QPoint(0, 0)); -    const QSize s = widget->size(); - -    const std::initializer_list<POINT> points = -    { -        { p.x(), p.y() }, -        { p.x() + s.width(), p.y() }, -        { p.x() + s.width(), p.y() + s.height() }, -        { p.x(), p.y() + s.height() }, -        { p.x() + s.width()/2, p.y() + s.height()/2 }, -    }; - -    for (const POINT& pt : points) -        if (WindowFromPoint(pt) == (HWND) widget->winId()) -            return true; -    return false; -} - -#else -template<typename=void> -bool is_window_visible(const QWidget* widget) { return true; } -#endif | 
