mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-23 01:41:59 -05:00
6f9e0e3876
Only repaint windows that intersect either the old or the new rect. Also only repaint those rects in the root widget.
122 lines
2.5 KiB
C++
122 lines
2.5 KiB
C++
#include "Widget.h"
|
|
#include "Event.h"
|
|
#include "EventLoop.h"
|
|
#include "WindowManager.h"
|
|
#include "Window.h"
|
|
#include <AK/Assertions.h>
|
|
|
|
Widget::Widget(Widget* parent)
|
|
: Object(parent)
|
|
{
|
|
m_backgroundColor = Color(255, 255, 255);
|
|
m_foregroundColor = Color(0, 0, 0);
|
|
}
|
|
|
|
Widget::~Widget()
|
|
{
|
|
}
|
|
|
|
void Widget::setWindowRelativeRect(const Rect& rect)
|
|
{
|
|
// FIXME: Make some kind of event loop driven ResizeEvent?
|
|
m_relativeRect = rect;
|
|
update();
|
|
}
|
|
|
|
void Widget::repaint(const Rect& rect)
|
|
{
|
|
event(*make<PaintEvent>(rect));
|
|
}
|
|
|
|
void Widget::event(Event& event)
|
|
{
|
|
switch (event.type()) {
|
|
case Event::Paint:
|
|
if (auto* win = window()) {
|
|
if (win->isBeingDragged())
|
|
return;
|
|
}
|
|
m_hasPendingPaintEvent = false;
|
|
return onPaint(static_cast<PaintEvent&>(event));
|
|
case Event::Show:
|
|
return onShow(static_cast<ShowEvent&>(event));
|
|
case Event::Hide:
|
|
return onHide(static_cast<HideEvent&>(event));
|
|
case Event::KeyDown:
|
|
return onKeyDown(static_cast<KeyEvent&>(event));
|
|
case Event::KeyUp:
|
|
return onKeyUp(static_cast<KeyEvent&>(event));
|
|
case Event::MouseMove:
|
|
return onMouseMove(static_cast<MouseEvent&>(event));
|
|
case Event::MouseDown:
|
|
return onMouseDown(static_cast<MouseEvent&>(event));
|
|
case Event::MouseUp:
|
|
return onMouseUp(static_cast<MouseEvent&>(event));
|
|
default:
|
|
return Object::event(event);
|
|
}
|
|
}
|
|
|
|
void Widget::onPaint(PaintEvent& event)
|
|
{
|
|
//printf("Widget::onPaint :)\n");
|
|
for (auto* ch : children()) {
|
|
auto* child = (Widget*)ch;
|
|
child->onPaint(event);
|
|
}
|
|
}
|
|
|
|
void Widget::onShow(ShowEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onHide(HideEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onKeyDown(KeyEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onKeyUp(KeyEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onMouseDown(MouseEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onMouseUp(MouseEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::onMouseMove(MouseEvent&)
|
|
{
|
|
}
|
|
|
|
void Widget::update()
|
|
{
|
|
if (m_hasPendingPaintEvent)
|
|
return;
|
|
m_hasPendingPaintEvent = true;
|
|
EventLoop::main().postEvent(this, make<PaintEvent>(rect()));
|
|
}
|
|
|
|
Widget::HitTestResult Widget::hitTest(int x, int y)
|
|
{
|
|
// FIXME: Care about z-order.
|
|
for (auto* ch : children()) {
|
|
auto* child = (Widget*)ch;
|
|
if (child->relativeRect().contains(x, y)) {
|
|
return child->hitTest(x - child->relativeRect().x(), y - child->relativeRect().y());
|
|
}
|
|
}
|
|
return { this, x, y };
|
|
}
|
|
|
|
void Widget::setWindow(Window* window)
|
|
{
|
|
if (m_window == window)
|
|
return;
|
|
m_window = window;
|
|
}
|