2019-01-16 16:03:50 +01:00
|
|
|
#pragma once
|
|
|
|
|
2019-01-19 23:22:46 +01:00
|
|
|
#include <SharedGraphics/Rect.h>
|
|
|
|
#include <SharedGraphics/GraphicsBitmap.h>
|
2019-01-16 16:03:50 +01:00
|
|
|
#include <AK/AKString.h>
|
|
|
|
#include <AK/InlineLinkedList.h>
|
2019-01-24 23:40:12 +01:00
|
|
|
#include <AK/Lock.h>
|
2019-01-26 05:28:02 +01:00
|
|
|
#include "WSMessageReceiver.h"
|
2019-01-16 16:03:50 +01:00
|
|
|
|
|
|
|
class Process;
|
|
|
|
|
2019-01-26 05:28:02 +01:00
|
|
|
class WSWindow final : public WSMessageReceiver, public InlineLinkedListNode<WSWindow> {
|
2019-01-24 23:40:12 +01:00
|
|
|
friend class WSWindowLocker;
|
2019-01-16 16:03:50 +01:00
|
|
|
public:
|
|
|
|
WSWindow(Process&, int window_id);
|
|
|
|
virtual ~WSWindow() override;
|
|
|
|
|
|
|
|
int window_id() const { return m_window_id; }
|
|
|
|
|
|
|
|
String title() const { return m_title; }
|
|
|
|
void set_title(String&&);
|
|
|
|
|
|
|
|
int x() const { return m_rect.x(); }
|
|
|
|
int y() const { return m_rect.y(); }
|
|
|
|
int width() const { return m_rect.width(); }
|
|
|
|
int height() const { return m_rect.height(); }
|
|
|
|
|
|
|
|
const Rect& rect() const { return m_rect; }
|
|
|
|
void set_rect(const Rect&);
|
|
|
|
void set_rect_without_repaint(const Rect& rect) { m_rect = rect; }
|
|
|
|
|
|
|
|
Point position() const { return m_rect.location(); }
|
|
|
|
void set_position(const Point& position) { set_rect({ position.x(), position.y(), width(), height() }); }
|
|
|
|
void set_position_without_repaint(const Point& position) { set_rect_without_repaint({ position.x(), position.y(), width(), height() }); }
|
|
|
|
|
2019-01-26 05:35:45 +01:00
|
|
|
virtual void on_message(WSMessage&) override;
|
2019-01-16 16:03:50 +01:00
|
|
|
|
|
|
|
bool is_being_dragged() const { return m_is_being_dragged; }
|
|
|
|
void set_is_being_dragged(bool b) { m_is_being_dragged = b; }
|
|
|
|
|
|
|
|
GraphicsBitmap* backing() { return m_backing.ptr(); }
|
|
|
|
|
2019-01-21 02:42:29 +01:00
|
|
|
pid_t pid() const { return m_pid; }
|
|
|
|
|
2019-01-27 08:48:34 +01:00
|
|
|
void set_global_cursor_tracking_enabled(bool);
|
|
|
|
bool global_cursor_tracking() const { return m_global_cursor_tracking_enabled; }
|
|
|
|
|
2019-01-16 16:03:50 +01:00
|
|
|
// For InlineLinkedList.
|
|
|
|
// FIXME: Maybe make a ListHashSet and then WSWindowManager can just use that.
|
|
|
|
WSWindow* m_next { nullptr };
|
|
|
|
WSWindow* m_prev { nullptr };
|
|
|
|
|
|
|
|
private:
|
2019-01-24 23:40:12 +01:00
|
|
|
Lock m_lock;
|
2019-01-16 16:03:50 +01:00
|
|
|
String m_title;
|
|
|
|
Rect m_rect;
|
|
|
|
bool m_is_being_dragged { false };
|
2019-01-27 08:48:34 +01:00
|
|
|
bool m_global_cursor_tracking_enabled { false };
|
2019-01-16 16:03:50 +01:00
|
|
|
|
|
|
|
RetainPtr<GraphicsBitmap> m_backing;
|
|
|
|
Process& m_process;
|
|
|
|
int m_window_id { -1 };
|
2019-01-21 02:42:29 +01:00
|
|
|
pid_t m_pid { -1 };
|
2019-01-16 16:03:50 +01:00
|
|
|
};
|
|
|
|
|
2019-01-24 23:40:12 +01:00
|
|
|
class WSWindowLocker {
|
|
|
|
public:
|
|
|
|
WSWindowLocker(WSWindow& window) : m_locker(window.m_lock) { }
|
|
|
|
~WSWindowLocker() { }
|
|
|
|
private:
|
|
|
|
Locker m_locker;
|
|
|
|
};
|
|
|
|
|