anchoring errors

This commit is contained in:
Eduardo Bart 2011-05-09 18:08:17 -03:00
parent 51fe97644d
commit 42c1ae090c
2 changed files with 22 additions and 2 deletions

View File

@ -55,19 +55,27 @@ int Anchor::getAnchorLinePoint() const
} }
return -9999; return -9999;
} }
bool UIAnchorLayout::addAnchor(const UIElementPtr& anchoredElement, UI::AnchorPoint anchoredEdge, const AnchorLine& anchorLine) bool UIAnchorLayout::addAnchor(const UIElementPtr& anchoredElement, UI::AnchorPoint anchoredEdge, const AnchorLine& anchorLine)
{ {
Anchor anchor(anchoredElement, anchoredEdge, anchorLine); Anchor anchor(anchoredElement, anchoredEdge, anchorLine);
UIElementPtr anchorLineElement = anchor.getAnchorLineElement(); UIElementPtr anchorLineElement = anchor.getAnchorLineElement();
if(!anchorLineElement) {
logError("ERROR: could not find the element to anchor on, wrong id?");
return false;
}
// we can never anchor with itself // we can never anchor with itself
if(anchoredElement == anchorLineElement) { if(anchoredElement == anchorLineElement) {
logError("ERROR: anchoring with itself is not possible"); logError("ERROR: anchoring with itself is not possible");
return false; return false;
} }
// TODO: check if itself is already anchored on the anchor element // we must never anchor to an anchor child
if(hasElementInAnchorTree(anchorLineElement, anchoredElement)) {
logError("ERROR: anchors is miss configurated, you must never make anchor chains in loops");
return false;
}
// setup the anchor // setup the anchor
m_anchors.push_back(anchor); m_anchors.push_back(anchor);
@ -144,6 +152,17 @@ void UIAnchorLayout::recalculateChildrenLayout(const UIElementPtr& parent)
} }
} }
bool UIAnchorLayout::hasElementInAnchorTree(const UIElementPtr& element, const UIElementPtr& treeAnchor)
{
foreach(const Anchor& anchor, m_anchors) {
if(anchor.getAnchorLineElement() == treeAnchor) {
if(anchor.getAnchoredElement() == element || hasElementInAnchorTree(element, anchor.getAnchoredElement()))
return true;
}
}
return false;
}
UI::AnchorPoint UIAnchorLayout::parseAnchorPoint(const std::string& anchorPointStr) UI::AnchorPoint UIAnchorLayout::parseAnchorPoint(const std::string& anchorPointStr)
{ {
if(anchorPointStr == "left") if(anchorPointStr == "left")

View File

@ -66,6 +66,7 @@ public:
void recalculateElementLayout(const UIElementPtr& element); void recalculateElementLayout(const UIElementPtr& element);
void recalculateChildrenLayout(const UIElementPtr& parent); void recalculateChildrenLayout(const UIElementPtr& parent);
bool hasElementInAnchorTree(const UIElementPtr& element, const UIElementPtr& treeAnchor);
static UI::AnchorPoint parseAnchorPoint(const std::string& anchorPointStr); static UI::AnchorPoint parseAnchorPoint(const std::string& anchorPointStr);
private: private: