Changed: #1246 Build on PPC machines (patch provided by Jeru)
This commit is contained in:
parent
5fb7617fec
commit
3100f477d3
1 changed files with 89 additions and 88 deletions
|
@ -50,6 +50,95 @@ extern ULandscape *Landscape;
|
||||||
namespace R2
|
namespace R2
|
||||||
{
|
{
|
||||||
|
|
||||||
|
// create a special selectable polygon
|
||||||
|
class CCtrlPolygonSelectable : public CCtrlPolygon, public IDisplayerUIHandle
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CCtrlPolygonSelectable(CInstance &instance) : Instance(instance) {}
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual CInstance &getDisplayedInstance() { return Instance; }
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual bool contains(sint32 mouseXInWindow, sint32 mouseYInWindow) const
|
||||||
|
{
|
||||||
|
if (!_Parent) return false;
|
||||||
|
|
||||||
|
// relies on parent class CViewPolygon::contains
|
||||||
|
return CCtrlPolygon::contains(CVector2f(mouseXInWindow + 0.5f, mouseYInWindow + 0.5f));
|
||||||
|
}
|
||||||
|
// tooltip
|
||||||
|
virtual void getContextHelp(::ucstring &help) const
|
||||||
|
{
|
||||||
|
help = Instance.getDisplayName();
|
||||||
|
if (std::operator==(help, NLMISC::CI18N::get("uiR2EDNoName") ))
|
||||||
|
help.clear();
|
||||||
|
}
|
||||||
|
bool emptyContextHelp() const { return true; }
|
||||||
|
bool wantInstantContextHelp() const { return true; }
|
||||||
|
// from CCtrlBase
|
||||||
|
virtual bool preciseHitTest(sint32 x, sint32 y) const
|
||||||
|
{
|
||||||
|
if (!_Parent) return false;
|
||||||
|
sint32 winX, winY;
|
||||||
|
_Parent->getCorner(winX, winY, _ParentPosRef);
|
||||||
|
return contains(x - winX, y - winY);
|
||||||
|
}
|
||||||
|
public:
|
||||||
|
CInstance &Instance;
|
||||||
|
protected:
|
||||||
|
// TMP TMP until matrix precision is solved
|
||||||
|
// from CCtrlPolygon
|
||||||
|
void computeScaledVertex(NLMISC::CVector2f &dest, const NLMISC::CVector2f &src)
|
||||||
|
{
|
||||||
|
CGroupMap *gm = CTool::getWorldMap();
|
||||||
|
if (!gm) dest = CVector::Null;
|
||||||
|
gm->worldToWindow(dest, src);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// create a special selectable polygon
|
||||||
|
class CCtrlQuadSelectable : public CCtrlQuad, public IDisplayerUIHandle
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CCtrlQuadSelectable(CInstance &instance, uint edgeIndex) : Instance(instance), EdgeIndex(edgeIndex) {}
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual CInstance &getDisplayedInstance() { return Instance; }
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual bool isEdge() const { return true; }
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual uint getEdgeIndex() const { return EdgeIndex; }
|
||||||
|
// from IDisplayerUIHandle
|
||||||
|
virtual bool contains(sint32 mouseXInWindow, sint32 mouseYInWindow) const
|
||||||
|
{
|
||||||
|
if (!_Parent) return false;
|
||||||
|
|
||||||
|
// relies on parent class CViewPolygon::contains
|
||||||
|
return CCtrlQuad::contains(CVector2f(mouseXInWindow + 0.5f, mouseYInWindow + 0.5f));
|
||||||
|
}
|
||||||
|
// tooltip
|
||||||
|
virtual void getContextHelp(ucstring &help) const
|
||||||
|
{
|
||||||
|
help = Instance.getDisplayName();
|
||||||
|
if (std::operator==(help, NLMISC::CI18N::get("uiR2EDNoName")))
|
||||||
|
help.clear();
|
||||||
|
}
|
||||||
|
bool emptyContextHelp() const { return true; }
|
||||||
|
bool wantInstantContextHelp() const { return true; }
|
||||||
|
// from CCtrlBase
|
||||||
|
virtual bool preciseHitTest(sint32 x, sint32 y) const
|
||||||
|
{
|
||||||
|
if (!_Parent) return false;
|
||||||
|
sint32 winX, winY;
|
||||||
|
_Parent->getCorner(winX, winY, _ParentPosRef);
|
||||||
|
return contains(x - winX, y - winY);
|
||||||
|
}
|
||||||
|
virtual bool handleEvent (const CEventDescriptor &/* event */)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
public:
|
||||||
|
CInstance &Instance;
|
||||||
|
uint EdgeIndex;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -90,50 +179,6 @@ CCtrlPolygon *CDisplayerVisualGroup::CSelectablePrimRender::newCtrlPolygon() con
|
||||||
{
|
{
|
||||||
//H_AUTO(R2_CDisplayerVisualGroup_CSelectablePrimRender)
|
//H_AUTO(R2_CDisplayerVisualGroup_CSelectablePrimRender)
|
||||||
nlassert(DisplayedInstance);
|
nlassert(DisplayedInstance);
|
||||||
// create a special selectable polygon
|
|
||||||
class CCtrlPolygonSelectable : public CCtrlPolygon, public IDisplayerUIHandle
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CCtrlPolygonSelectable(CInstance &instance) : Instance(instance) {}
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual CInstance &getDisplayedInstance() { return Instance; }
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual bool contains(sint32 mouseXInWindow, sint32 mouseYInWindow) const
|
|
||||||
{
|
|
||||||
if (!_Parent) return false;
|
|
||||||
|
|
||||||
// relies on parent class CViewPolygon::contains
|
|
||||||
return CCtrlPolygon::contains(CVector2f(mouseXInWindow + 0.5f, mouseYInWindow + 0.5f));
|
|
||||||
}
|
|
||||||
// tooltip
|
|
||||||
virtual void getContextHelp(::ucstring &help) const
|
|
||||||
{
|
|
||||||
help = Instance.getDisplayName();
|
|
||||||
if (std::operator==(help, NLMISC::CI18N::get("uiR2EDNoName") ))
|
|
||||||
help.clear();
|
|
||||||
}
|
|
||||||
bool emptyContextHelp() const { return true; }
|
|
||||||
bool wantInstantContextHelp() const { return true; }
|
|
||||||
// from CCtrlBase
|
|
||||||
virtual bool preciseHitTest(sint32 x, sint32 y) const
|
|
||||||
{
|
|
||||||
if (!_Parent) return false;
|
|
||||||
sint32 winX, winY;
|
|
||||||
_Parent->getCorner(winX, winY, _ParentPosRef);
|
|
||||||
return contains(x - winX, y - winY);
|
|
||||||
}
|
|
||||||
public:
|
|
||||||
CInstance &Instance;
|
|
||||||
protected:
|
|
||||||
// TMP TMP until matrix precision is solved
|
|
||||||
// from CCtrlPolygon
|
|
||||||
void computeScaledVertex(NLMISC::CVector2f &dest, const NLMISC::CVector2f &src)
|
|
||||||
{
|
|
||||||
CGroupMap *gm = CTool::getWorldMap();
|
|
||||||
if (!gm) dest = CVector::Null;
|
|
||||||
gm->worldToWindow(dest, src);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
CCtrlPolygonSelectable *result = new CCtrlPolygonSelectable(*DisplayedInstance);
|
CCtrlPolygonSelectable *result = new CCtrlPolygonSelectable(*DisplayedInstance);
|
||||||
result->setId(DisplayedInstance->getId());
|
result->setId(DisplayedInstance->getId());
|
||||||
result->setToolTipParent(CCtrlBase::TTMouse);
|
result->setToolTipParent(CCtrlBase::TTMouse);
|
||||||
|
@ -147,50 +192,6 @@ CCtrlQuad *CDisplayerVisualGroup::CSelectablePrimRender::newCtrlQuad(uint edgeIn
|
||||||
{
|
{
|
||||||
//H_AUTO(R2_CDisplayerVisualGroup_CSelectablePrimRender)
|
//H_AUTO(R2_CDisplayerVisualGroup_CSelectablePrimRender)
|
||||||
nlassert(DisplayedInstance);
|
nlassert(DisplayedInstance);
|
||||||
// create a special selectable polygon
|
|
||||||
class CCtrlQuadSelectable : public CCtrlQuad, public IDisplayerUIHandle
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CCtrlQuadSelectable(CInstance &instance, uint edgeIndex) : Instance(instance), EdgeIndex(edgeIndex) {}
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual CInstance &getDisplayedInstance() { return Instance; }
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual bool isEdge() const { return true; }
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual uint getEdgeIndex() const { return EdgeIndex; }
|
|
||||||
// from IDisplayerUIHandle
|
|
||||||
virtual bool contains(sint32 mouseXInWindow, sint32 mouseYInWindow) const
|
|
||||||
{
|
|
||||||
if (!_Parent) return false;
|
|
||||||
|
|
||||||
// relies on parent class CViewPolygon::contains
|
|
||||||
return CCtrlQuad::contains(CVector2f(mouseXInWindow + 0.5f, mouseYInWindow + 0.5f));
|
|
||||||
}
|
|
||||||
// tooltip
|
|
||||||
virtual void getContextHelp(ucstring &help) const
|
|
||||||
{
|
|
||||||
help = Instance.getDisplayName();
|
|
||||||
if (std::operator==(help, NLMISC::CI18N::get("uiR2EDNoName")))
|
|
||||||
help.clear();
|
|
||||||
}
|
|
||||||
bool emptyContextHelp() const { return true; }
|
|
||||||
bool wantInstantContextHelp() const { return true; }
|
|
||||||
// from CCtrlBase
|
|
||||||
virtual bool preciseHitTest(sint32 x, sint32 y) const
|
|
||||||
{
|
|
||||||
if (!_Parent) return false;
|
|
||||||
sint32 winX, winY;
|
|
||||||
_Parent->getCorner(winX, winY, _ParentPosRef);
|
|
||||||
return contains(x - winX, y - winY);
|
|
||||||
}
|
|
||||||
virtual bool handleEvent (const CEventDescriptor &/* event */)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
public:
|
|
||||||
CInstance &Instance;
|
|
||||||
uint EdgeIndex;
|
|
||||||
};
|
|
||||||
CCtrlQuadSelectable *result = new CCtrlQuadSelectable(*DisplayedInstance, edgeIndex);
|
CCtrlQuadSelectable *result = new CCtrlQuadSelectable(*DisplayedInstance, edgeIndex);
|
||||||
result->setToolTipParent(CCtrlBase::TTMouse);
|
result->setToolTipParent(CCtrlBase::TTMouse);
|
||||||
result->setToolTipParentPosRef(Hotspot_BR);
|
result->setToolTipParentPosRef(Hotspot_BR);
|
||||||
|
|
Loading…
Reference in a new issue