mirror of
https://github.com/edubart/otclient.git
synced 2025-12-15 05:09:46 +01:00
improve miniwindow moving
This commit is contained in:
@@ -1065,7 +1065,7 @@ UIWidgetPtr UIWidget::getChildById(const std::string& childId)
|
||||
|
||||
UIWidgetPtr UIWidget::getChildByPos(const Point& childPos)
|
||||
{
|
||||
if(!containsChildPoint(childPos))
|
||||
if(!containsPaddingPoint(childPos))
|
||||
return nullptr;
|
||||
|
||||
for(auto it = m_children.rbegin(); it != m_children.rend(); ++it) {
|
||||
@@ -1100,7 +1100,7 @@ UIWidgetPtr UIWidget::recursiveGetChildById(const std::string& id)
|
||||
|
||||
UIWidgetPtr UIWidget::recursiveGetChildByPos(const Point& childPos, bool wantsPhantom)
|
||||
{
|
||||
if(!containsChildPoint(childPos))
|
||||
if(!containsPaddingPoint(childPos))
|
||||
return nullptr;
|
||||
|
||||
for(auto it = m_children.rbegin(); it != m_children.rend(); ++it) {
|
||||
@@ -1119,7 +1119,7 @@ UIWidgetPtr UIWidget::recursiveGetChildByPos(const Point& childPos, bool wantsPh
|
||||
UIWidgetList UIWidget::recursiveGetChildrenByPos(const Point& childPos)
|
||||
{
|
||||
UIWidgetList children;
|
||||
if(!containsChildPoint(childPos))
|
||||
if(!containsPaddingPoint(childPos))
|
||||
return children;
|
||||
|
||||
for(auto it = m_children.rbegin(); it != m_children.rend(); ++it) {
|
||||
@@ -1134,6 +1134,24 @@ UIWidgetList UIWidget::recursiveGetChildrenByPos(const Point& childPos)
|
||||
return children;
|
||||
}
|
||||
|
||||
UIWidgetList UIWidget::recursiveGetChildrenByMarginPos(const Point& childPos)
|
||||
{
|
||||
UIWidgetList children;
|
||||
if(!containsPaddingPoint(childPos))
|
||||
return children;
|
||||
|
||||
for(auto it = m_children.rbegin(); it != m_children.rend(); ++it) {
|
||||
const UIWidgetPtr& child = (*it);
|
||||
if(child->isExplicitlyVisible() && child->containsMarginPoint(childPos)) {
|
||||
UIWidgetList subChildren = child->recursiveGetChildrenByMarginPos(childPos);
|
||||
if(!subChildren.empty())
|
||||
children.insert(children.end(), subChildren.begin(), subChildren.end());
|
||||
children.push_back(child);
|
||||
}
|
||||
}
|
||||
return children;
|
||||
}
|
||||
|
||||
UIWidgetPtr UIWidget::backwardsGetWidgetById(const std::string& id)
|
||||
{
|
||||
UIWidgetPtr widget = getChildById(id);
|
||||
@@ -1580,7 +1598,7 @@ bool UIWidget::propagateOnKeyUp(uchar keyCode, int keyboardModifiers)
|
||||
bool UIWidget::propagateOnMouseEvent(const Point& mousePos, UIWidgetList& widgetList)
|
||||
{
|
||||
bool ret = false;
|
||||
if(containsChildPoint(mousePos)) {
|
||||
if(containsPaddingPoint(mousePos)) {
|
||||
for(auto it = m_children.rbegin(); it != m_children.rend(); ++it) {
|
||||
const UIWidgetPtr& child = *it;
|
||||
if(child->isExplicitlyEnabled() && child->isExplicitlyVisible() && child->containsPoint(mousePos)) {
|
||||
|
||||
Reference in New Issue
Block a user