mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2025-01-12 02:45:27 +00:00
CHANGED: #1471 Moved the contexthelp drawing/controlling code to the GUI library.
This commit is contained in:
parent
e97ec6788e
commit
27953ec7e8
10 changed files with 628 additions and 630 deletions
|
@ -216,6 +216,9 @@ namespace NLGUI
|
||||||
CCtrlBase* getCurContextHelp(){ return curContextHelp; }
|
CCtrlBase* getCurContextHelp(){ return curContextHelp; }
|
||||||
|
|
||||||
float _DeltaTimeStopingContextHelp;
|
float _DeltaTimeStopingContextHelp;
|
||||||
|
float _MaxTimeStopingContextHelp;
|
||||||
|
sint _LastXContextHelp;
|
||||||
|
sint _LastYContextHelp;
|
||||||
|
|
||||||
CViewPointerBase* getPointer(){ return _Pointer; }
|
CViewPointerBase* getPointer(){ return _Pointer; }
|
||||||
void setPointer( CViewPointerBase *pointer ){ _Pointer = pointer; }
|
void setPointer( CViewPointerBase *pointer ){ _Pointer = pointer; }
|
||||||
|
@ -256,6 +259,38 @@ namespace NLGUI
|
||||||
void reset();
|
void reset();
|
||||||
|
|
||||||
void checkCoords();
|
void checkCoords();
|
||||||
|
|
||||||
|
CInterfaceGroup* getWindowForActiveMasterGroup( const std::string &windowName );
|
||||||
|
|
||||||
|
void drawOverExtendViewText();
|
||||||
|
|
||||||
|
// Internal : adjust a tooltip with respect to its parent. Returns the number of coordinate that were clamped
|
||||||
|
// against the screen border
|
||||||
|
uint adjustTooltipPosition( CCtrlBase *newCtrl, CInterfaceGroup *win, THotSpot ttParentRef,
|
||||||
|
THotSpot ttPosRef, sint32 xParent, sint32 yParent,
|
||||||
|
sint32 wParent, sint32 hParent );
|
||||||
|
|
||||||
|
void updateTooltipCoords();
|
||||||
|
|
||||||
|
// Update tooltip coordinate if they need to be (getInvalidCoords() returns a value != 0)
|
||||||
|
void updateTooltipCoords(CCtrlBase *newCtrl);
|
||||||
|
|
||||||
|
/// for ContextHelp action handler only: set the result name
|
||||||
|
void setContextHelpText( const ucstring &text ){ _ContextHelpText = text; }
|
||||||
|
ucstring& getContextHelpText(){ return _ContextHelpText; }
|
||||||
|
|
||||||
|
/// force disable the context help
|
||||||
|
void disableContextHelp();
|
||||||
|
|
||||||
|
/// force disable the context help, if it is issued from the given control
|
||||||
|
void disableContextHelpForControl(CCtrlBase *pCtrl);
|
||||||
|
|
||||||
|
CCtrlBase* getNewContextHelpCtrl();
|
||||||
|
|
||||||
|
void drawContextHelp();
|
||||||
|
|
||||||
|
void setContextHelpActive(bool active);
|
||||||
|
|
||||||
// Relative move of pointer
|
// Relative move of pointer
|
||||||
void movePointer (sint32 dx, sint32 dy);
|
void movePointer (sint32 dx, sint32 dy);
|
||||||
// Set absolute coordinates of pointer
|
// Set absolute coordinates of pointer
|
||||||
|
@ -440,6 +475,9 @@ namespace NLGUI
|
||||||
|
|
||||||
SInterfaceTimes interfaceTimes;
|
SInterfaceTimes interfaceTimes;
|
||||||
|
|
||||||
|
ucstring _ContextHelpText;
|
||||||
|
bool _ContextHelpActive;
|
||||||
|
|
||||||
bool inGame;
|
bool inGame;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,8 @@
|
||||||
#include "nel/gui/group_modal.h"
|
#include "nel/gui/group_modal.h"
|
||||||
#include "nel/gui/group_editbox_base.h"
|
#include "nel/gui/group_editbox_base.h"
|
||||||
#include "nel/gui/interface_options.h"
|
#include "nel/gui/interface_options.h"
|
||||||
|
#include "nel/gui/view_text.h"
|
||||||
|
#include "nel/gui/view_bitmap.h"
|
||||||
|
|
||||||
namespace NLGUI
|
namespace NLGUI
|
||||||
{
|
{
|
||||||
|
@ -1075,6 +1077,559 @@ namespace NLGUI
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
CInterfaceGroup* CWidgetManager::getWindowForActiveMasterGroup( const std::string &window )
|
||||||
|
{
|
||||||
|
// Search for all elements
|
||||||
|
for (uint32 nMasterGroup = 0; nMasterGroup < _MasterGroups.size(); nMasterGroup++)
|
||||||
|
{
|
||||||
|
const SMasterGroup &rMG = _MasterGroups[nMasterGroup];
|
||||||
|
if (rMG.Group->getActive())
|
||||||
|
{
|
||||||
|
CInterfaceElement *pEL= getElementFromId( rMG.Group->getId() + ":" + window);
|
||||||
|
if(pEL && pEL->isGroup())
|
||||||
|
return (CInterfaceGroup*)pEL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ***************************************************************************
|
||||||
|
void CWidgetManager::drawOverExtendViewText()
|
||||||
|
{
|
||||||
|
if( getOverExtendViewText() )
|
||||||
|
{
|
||||||
|
CViewText *vtSrc= dynamic_cast<CViewText*>( getOverExtendViewText() );
|
||||||
|
|
||||||
|
CInterfaceGroup *groupOver = getWindowForActiveMasterGroup("over_extend_view_text");
|
||||||
|
if(groupOver)
|
||||||
|
{
|
||||||
|
CViewText *vtDst = dynamic_cast<CViewText*>(groupOver->getView("text"));
|
||||||
|
if (vtDst != NULL)
|
||||||
|
{
|
||||||
|
// Copy all aspects to the view
|
||||||
|
vtDst->setText (vtSrc->getText());
|
||||||
|
vtDst->setFontSize (vtSrc->getFontSize());
|
||||||
|
vtDst->setColor (vtSrc->getColor());
|
||||||
|
vtDst->setModulateGlobalColor(vtSrc->getModulateGlobalColor());
|
||||||
|
vtDst->setShadow(vtSrc->getShadow());
|
||||||
|
vtDst->setShadowColor(vtSrc->getShadowColor());
|
||||||
|
vtDst->setCaseMode(vtSrc->getCaseMode());
|
||||||
|
vtDst->setUnderlined(vtSrc->getUnderlined());
|
||||||
|
|
||||||
|
// setup background
|
||||||
|
CViewBitmap *pBack= dynamic_cast<CViewBitmap*>(groupOver->getView("midback"));
|
||||||
|
CViewBitmap *pOutline= dynamic_cast<CViewBitmap*>(groupOver->getView("midoutline"));
|
||||||
|
if(pBack)
|
||||||
|
pBack->setColor( getOverExtendViewTextBackColor() );
|
||||||
|
if(pOutline)
|
||||||
|
{
|
||||||
|
pOutline->setColor(vtSrc->getColor());
|
||||||
|
pOutline->setModulateGlobalColor(vtSrc->getModulateGlobalColor());
|
||||||
|
}
|
||||||
|
|
||||||
|
// the group is the position of the overed text, but apply the delta of borders (vtDst X/Y)
|
||||||
|
sint32 x = vtSrc->getXReal() - vtDst->getX();
|
||||||
|
sint32 y = vtSrc->getYReal() - vtDst->getY();
|
||||||
|
|
||||||
|
// update one time only to get correct W/H
|
||||||
|
groupOver->updateCoords ();
|
||||||
|
|
||||||
|
if(!vtSrc->isClampRight())
|
||||||
|
{
|
||||||
|
// clamped from the left part
|
||||||
|
x += vtSrc->getWReal() - vtDst->getWReal();
|
||||||
|
}
|
||||||
|
|
||||||
|
// clamp to screen coords, and set
|
||||||
|
if ((x+groupOver->getW()) > groupOver->getParent()->getWReal())
|
||||||
|
x = groupOver->getParent()->getWReal() - groupOver->getW();
|
||||||
|
if (x < 0)
|
||||||
|
x = 0;
|
||||||
|
if ((y+groupOver->getH()) > groupOver->getParent()->getHReal())
|
||||||
|
y = groupOver->getParent()->getHReal() - groupOver->getH();
|
||||||
|
if (y < 0)
|
||||||
|
y = 0;
|
||||||
|
|
||||||
|
// set pos
|
||||||
|
groupOver->setX (x);
|
||||||
|
groupOver->setY (y);
|
||||||
|
|
||||||
|
// update coords 3 times is required
|
||||||
|
groupOver->updateCoords ();
|
||||||
|
groupOver->updateCoords ();
|
||||||
|
groupOver->updateCoords ();
|
||||||
|
|
||||||
|
// draw
|
||||||
|
groupOver->draw ();
|
||||||
|
// flush layers
|
||||||
|
CViewRenderer::getInstance()->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset the ptr so at next frame, won't be rendered (but if reset)
|
||||||
|
setOverExtendViewText( NULL, getOverExtendViewTextBackColor() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
uint CWidgetManager::adjustTooltipPosition( CCtrlBase *newCtrl, CInterfaceGroup *win, THotSpot ttParentRef,
|
||||||
|
THotSpot ttPosRef, sint32 xParent, sint32 yParent,
|
||||||
|
sint32 wParent, sint32 hParent )
|
||||||
|
{
|
||||||
|
CCtrlBase::TToolTipParentType parentType= newCtrl->getToolTipParent();
|
||||||
|
CInterfaceGroup *groupContextHelp =
|
||||||
|
getWindowForActiveMasterGroup(newCtrl->getContextHelpWindowName());
|
||||||
|
|
||||||
|
uint32 _ScreenH, _ScreenW;
|
||||||
|
CViewRenderer::getInstance()->getScreenSize( _ScreenH, _ScreenW );
|
||||||
|
|
||||||
|
if(ttPosRef==Hotspot_TTAuto || ttParentRef==Hotspot_TTAuto)
|
||||||
|
{
|
||||||
|
// NB: keep the special window if type is specialwindow (defined above)
|
||||||
|
if(!win)
|
||||||
|
win= newCtrl->getRootWindow();
|
||||||
|
sint32 xWin= 0;
|
||||||
|
sint32 yWin= 0;
|
||||||
|
sint32 wWin= 0;
|
||||||
|
sint32 hWin= 0;
|
||||||
|
if(win)
|
||||||
|
{
|
||||||
|
xWin = win->getXReal();
|
||||||
|
yWin = win->getYReal();
|
||||||
|
wWin = win->getWReal();
|
||||||
|
hWin = win->getHReal();
|
||||||
|
}
|
||||||
|
// for Window, display top or bottom according to window pos/size
|
||||||
|
if(parentType==CCtrlBase::TTWindow || parentType==CCtrlBase::TTSpecialWindow)
|
||||||
|
{
|
||||||
|
sint32 top= (sint32)_ScreenH - (yWin+hWin);
|
||||||
|
sint32 bottom= yWin;
|
||||||
|
if(top>bottom)
|
||||||
|
{
|
||||||
|
ttParentRef= Hotspot_TL;
|
||||||
|
ttPosRef= Hotspot_BL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ttParentRef= Hotspot_BL;
|
||||||
|
ttPosRef= Hotspot_TL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// for Ctrl, display top, left or right according to window pos/size
|
||||||
|
else if(parentType==CCtrlBase::TTCtrl)
|
||||||
|
{
|
||||||
|
sint32 right= (sint32)_ScreenW - (xWin+wWin);
|
||||||
|
sint32 left= xWin;
|
||||||
|
if(right>left)
|
||||||
|
{
|
||||||
|
ttParentRef= Hotspot_TR;
|
||||||
|
ttPosRef= Hotspot_BL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ttParentRef= Hotspot_TL;
|
||||||
|
ttPosRef= Hotspot_BR;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// default (mouse)
|
||||||
|
ttParentRef= Hotspot_BL;
|
||||||
|
ttPosRef= Hotspot_BL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// **** compute coordinates of the tooltip
|
||||||
|
sint32 x= xParent;
|
||||||
|
sint32 y= yParent;
|
||||||
|
if (ttParentRef & Hotspot_Mx)
|
||||||
|
y += hParent/2;
|
||||||
|
if (ttParentRef & Hotspot_Tx)
|
||||||
|
y += hParent;
|
||||||
|
if (ttParentRef & Hotspot_xM)
|
||||||
|
x += wParent/2;
|
||||||
|
if (ttParentRef & Hotspot_xR)
|
||||||
|
x += wParent;
|
||||||
|
|
||||||
|
// adjust according to self posref
|
||||||
|
if (ttPosRef & Hotspot_Mx)
|
||||||
|
y -= groupContextHelp->getHReal()/2;
|
||||||
|
if (ttPosRef & Hotspot_Tx)
|
||||||
|
y -= groupContextHelp->getHReal();
|
||||||
|
if (ttPosRef & Hotspot_xM)
|
||||||
|
x -= groupContextHelp->getWReal()/2;
|
||||||
|
if (ttPosRef & Hotspot_xR)
|
||||||
|
x -= groupContextHelp->getWReal();
|
||||||
|
|
||||||
|
|
||||||
|
// **** clamp to screen coords, and set
|
||||||
|
uint clampCount = 0;
|
||||||
|
|
||||||
|
if ((x+groupContextHelp->getW()) > groupContextHelp->getParent()->getWReal())
|
||||||
|
{
|
||||||
|
++ clampCount;
|
||||||
|
x = groupContextHelp->getParent()->getWReal() - groupContextHelp->getW();
|
||||||
|
}
|
||||||
|
if (x < 0)
|
||||||
|
{
|
||||||
|
x = 0;
|
||||||
|
++ clampCount;
|
||||||
|
}
|
||||||
|
if ((y+groupContextHelp->getH()) > groupContextHelp->getParent()->getHReal())
|
||||||
|
{
|
||||||
|
y = groupContextHelp->getParent()->getHReal() - groupContextHelp->getH();
|
||||||
|
++ clampCount;
|
||||||
|
}
|
||||||
|
if (y < 0)
|
||||||
|
{
|
||||||
|
y = 0;
|
||||||
|
++ clampCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
// update coords 3 times is required
|
||||||
|
groupContextHelp->setX (x);
|
||||||
|
groupContextHelp->setY (y);
|
||||||
|
groupContextHelp->updateCoords ();
|
||||||
|
groupContextHelp->updateCoords ();
|
||||||
|
groupContextHelp->updateCoords ();
|
||||||
|
|
||||||
|
return clampCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
void CWidgetManager::updateTooltipCoords()
|
||||||
|
{
|
||||||
|
updateTooltipCoords( getCurContextHelp() );
|
||||||
|
}
|
||||||
|
|
||||||
|
void CWidgetManager::updateTooltipCoords( CCtrlBase *newCtrl )
|
||||||
|
{
|
||||||
|
if (!newCtrl) return;
|
||||||
|
if (!newCtrl->getInvalidCoords()) return;
|
||||||
|
|
||||||
|
CInterfaceGroup *groupContextHelp =
|
||||||
|
getWindowForActiveMasterGroup(newCtrl->getContextHelpWindowName());
|
||||||
|
|
||||||
|
if(groupContextHelp)
|
||||||
|
{
|
||||||
|
CViewText *pTxt = (CViewText*)groupContextHelp->getView("text");
|
||||||
|
if (pTxt != NULL)
|
||||||
|
{
|
||||||
|
pTxt->setTextFormatTaged(_ContextHelpText);
|
||||||
|
// update only to get correct W/H
|
||||||
|
groupContextHelp->updateCoords ();
|
||||||
|
|
||||||
|
|
||||||
|
// **** Compute parent coordinates
|
||||||
|
CCtrlBase::TToolTipParentType parentType= newCtrl->getToolTipParent();
|
||||||
|
CInterfaceGroup *win= NULL;
|
||||||
|
// adjust to the mouse by default
|
||||||
|
sint32 xParent= getPointer()->getX();
|
||||||
|
sint32 yParent= getPointer()->getY();
|
||||||
|
sint32 wParent= 0;
|
||||||
|
sint32 hParent= 0;
|
||||||
|
// adjust to the window
|
||||||
|
if(parentType==CCtrlBase::TTWindow || parentType==CCtrlBase::TTSpecialWindow)
|
||||||
|
{
|
||||||
|
if(parentType==CCtrlBase::TTWindow)
|
||||||
|
win= newCtrl->getRootWindow();
|
||||||
|
else
|
||||||
|
win =
|
||||||
|
dynamic_cast<CInterfaceGroup*>( getElementFromId(newCtrl->getToolTipSpecialParent()));
|
||||||
|
|
||||||
|
if(win)
|
||||||
|
{
|
||||||
|
xParent = win->getXReal();
|
||||||
|
yParent = win->getYReal();
|
||||||
|
wParent = win->getWReal();
|
||||||
|
hParent = win->getHReal();
|
||||||
|
}
|
||||||
|
// Bug...: leave default to pointer
|
||||||
|
}
|
||||||
|
// adjust to the ctrl
|
||||||
|
else if (parentType==CCtrlBase::TTCtrl)
|
||||||
|
{
|
||||||
|
xParent = newCtrl->getXReal();
|
||||||
|
yParent = newCtrl->getYReal();
|
||||||
|
wParent = newCtrl->getWReal();
|
||||||
|
hParent = newCtrl->getHReal();
|
||||||
|
// Additionaly, must clip this ctrl with its parent
|
||||||
|
// (else animals are buggy for instance)
|
||||||
|
CInterfaceGroup *parent= newCtrl->getParent();
|
||||||
|
if(parent)
|
||||||
|
{
|
||||||
|
sint32 xClip,yClip,wClip,hClip;
|
||||||
|
parent->getClip(xClip,yClip,wClip,hClip);
|
||||||
|
// clip bottom left
|
||||||
|
xParent= std::max(xParent, xClip);
|
||||||
|
yParent= std::max(yParent, yClip);
|
||||||
|
// clip top right
|
||||||
|
sint32 xrParent= std::min(xParent+ wParent, xClip+wClip);
|
||||||
|
sint32 ytParent= std::min(yParent+ hParent, yClip+hClip);
|
||||||
|
wParent= std::max((sint32)0, xrParent-xParent);
|
||||||
|
hParent= std::max((sint32)0, ytParent-yParent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// **** resolve auto posref
|
||||||
|
uint clampCount =
|
||||||
|
adjustTooltipPosition( newCtrl, win, newCtrl->getToolTipParentPosRef(),
|
||||||
|
newCtrl->getToolTipPosRef(), xParent, yParent,
|
||||||
|
wParent, hParent);
|
||||||
|
|
||||||
|
if (clampCount != 0)
|
||||||
|
{
|
||||||
|
// try to fallback on alternate tooltip posref
|
||||||
|
uint altClampCount =
|
||||||
|
adjustTooltipPosition( newCtrl, win, newCtrl->getToolTipParentPosRefAlt(),
|
||||||
|
newCtrl->getToolTipPosRefAlt(), xParent, yParent,
|
||||||
|
wParent, hParent);
|
||||||
|
|
||||||
|
if (altClampCount > clampCount)
|
||||||
|
{
|
||||||
|
// worst ? resume to first posref
|
||||||
|
adjustTooltipPosition( newCtrl, win, newCtrl->getToolTipParentPosRef(),
|
||||||
|
newCtrl->getToolTipPosRef(), xParent, yParent,
|
||||||
|
wParent, hParent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
void CWidgetManager::disableContextHelp()
|
||||||
|
{
|
||||||
|
setCurContextHelp( NULL );
|
||||||
|
_DeltaTimeStopingContextHelp = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
void CWidgetManager::disableContextHelpForControl( CCtrlBase *pCtrl )
|
||||||
|
{
|
||||||
|
if( pCtrl == NULL )
|
||||||
|
return;
|
||||||
|
|
||||||
|
if( getCurContextHelp() == pCtrl )
|
||||||
|
disableContextHelp();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
CCtrlBase* CWidgetManager::getNewContextHelpCtrl()
|
||||||
|
{
|
||||||
|
// get the top most ctrl under us
|
||||||
|
CCtrlBase *best = NULL;
|
||||||
|
sint8 bestRenderLayer = -128;
|
||||||
|
|
||||||
|
for (sint i = (sint32)_CtrlsUnderPointer.size()-1; i>=0; i--)
|
||||||
|
{
|
||||||
|
CCtrlBase *pICL = _CtrlsUnderPointer[i];
|
||||||
|
if (pICL->getRenderLayer() > bestRenderLayer)
|
||||||
|
{
|
||||||
|
if ((pICL->getActive()) && (!pICL->emptyContextHelp()))
|
||||||
|
{
|
||||||
|
if (!getPointer()) return pICL;
|
||||||
|
sint32 mx, my;
|
||||||
|
getPointer()->getPointerPos(mx, my);
|
||||||
|
if (pICL->preciseHitTest(mx, my))
|
||||||
|
{
|
||||||
|
best = pICL;
|
||||||
|
bestRenderLayer = pICL->getRenderLayer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!best)
|
||||||
|
{
|
||||||
|
// if a control was not found, try with the groups
|
||||||
|
sint8 bestRenderLayer = -128;
|
||||||
|
|
||||||
|
for (sint i = (sint32)_GroupsUnderPointer.size()-1; i>=0; i--)
|
||||||
|
{
|
||||||
|
CCtrlBase *pICL = _GroupsUnderPointer[i];
|
||||||
|
if (pICL->getRenderLayer() > bestRenderLayer)
|
||||||
|
{
|
||||||
|
if ((pICL->getActive()) && (!pICL->emptyContextHelp()))
|
||||||
|
{
|
||||||
|
if (!getPointer()) return pICL;
|
||||||
|
sint32 mx, my;
|
||||||
|
getPointer()->getPointerPos(mx, my);
|
||||||
|
if (pICL->preciseHitTest(mx, my))
|
||||||
|
{
|
||||||
|
best = pICL;
|
||||||
|
bestRenderLayer = pICL->getRenderLayer();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return best;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
void CWidgetManager::drawContextHelp ()
|
||||||
|
{
|
||||||
|
if (!getPointer() || !_ContextHelpActive)
|
||||||
|
return;
|
||||||
|
|
||||||
|
|
||||||
|
sint32 x = getPointer()->getX();
|
||||||
|
sint32 y = getPointer()->getY();
|
||||||
|
|
||||||
|
|
||||||
|
// ***************
|
||||||
|
// **** try to disable
|
||||||
|
// ***************
|
||||||
|
// test disable first, so can recheck asap if another present. see below
|
||||||
|
CCtrlBase *_CurCtrlContextHelp = getCurContextHelp();
|
||||||
|
if( _CurCtrlContextHelp)
|
||||||
|
{
|
||||||
|
if(x!=_LastXContextHelp || y!=_LastYContextHelp)
|
||||||
|
{
|
||||||
|
// May change of ctrl!! => disable context help
|
||||||
|
CCtrlBase *newCtrl= getNewContextHelpCtrl();
|
||||||
|
if(newCtrl!=_CurCtrlContextHelp)
|
||||||
|
{
|
||||||
|
// disable
|
||||||
|
disableContextHelp();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if _CurCtrlContextHelp is visible
|
||||||
|
if (_CurCtrlContextHelp == NULL)
|
||||||
|
{
|
||||||
|
disableContextHelp();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
bool bVisible = true;
|
||||||
|
if (_CurCtrlContextHelp->getActive() == false)
|
||||||
|
bVisible = false;
|
||||||
|
CInterfaceGroup *pParent = _CurCtrlContextHelp->getParent();
|
||||||
|
while (pParent != NULL)
|
||||||
|
{
|
||||||
|
if (pParent->getActive() == false)
|
||||||
|
bVisible = false;
|
||||||
|
pParent = pParent->getParent();
|
||||||
|
}
|
||||||
|
if (!bVisible)
|
||||||
|
disableContextHelp();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ***************
|
||||||
|
// **** try to acquire
|
||||||
|
// ***************
|
||||||
|
if(!_CurCtrlContextHelp)
|
||||||
|
{
|
||||||
|
// get the ctrl of interset
|
||||||
|
CCtrlBase *newCtrl= getNewContextHelpCtrl();
|
||||||
|
|
||||||
|
if(x==_LastXContextHelp && y==_LastYContextHelp)
|
||||||
|
_DeltaTimeStopingContextHelp += ( interfaceTimes.frameDiffMs / 1000.0f );
|
||||||
|
else
|
||||||
|
_DeltaTimeStopingContextHelp = 0;
|
||||||
|
|
||||||
|
// If reach the time limit
|
||||||
|
if( ( _DeltaTimeStopingContextHelp > _MaxTimeStopingContextHelp )
|
||||||
|
|| (newCtrl && newCtrl->wantInstantContextHelp()))
|
||||||
|
{
|
||||||
|
// if present, get the ctx help text.
|
||||||
|
if(newCtrl)
|
||||||
|
{
|
||||||
|
// get the text
|
||||||
|
//newCtrl->getContextHelpToolTip(_ContextHelpText);
|
||||||
|
newCtrl->getContextHelp( getContextHelpText() );
|
||||||
|
// UserDefined context help
|
||||||
|
if( !newCtrl->getContextHelpActionHandler().empty() )
|
||||||
|
{
|
||||||
|
CAHManager::getInstance()->runActionHandler(newCtrl->getContextHelpActionHandler(), newCtrl, newCtrl->getContextHelpAHParams() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the text is finally empty (Special AH case), abort
|
||||||
|
if( getContextHelpText().empty() )
|
||||||
|
newCtrl= NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// not present? wait furthermore to move the mouse.
|
||||||
|
if(!newCtrl)
|
||||||
|
_DeltaTimeStopingContextHelp= 0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// enable
|
||||||
|
setCurContextHelp( newCtrl );
|
||||||
|
newCtrl->invalidateCoords();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
updateTooltipCoords(_CurCtrlContextHelp);
|
||||||
|
|
||||||
|
|
||||||
|
// ***************
|
||||||
|
// **** display
|
||||||
|
// ***************
|
||||||
|
if(_CurCtrlContextHelp)
|
||||||
|
{
|
||||||
|
CInterfaceGroup *groupContextHelp =
|
||||||
|
getWindowForActiveMasterGroup(_CurCtrlContextHelp->getContextHelpWindowName());
|
||||||
|
|
||||||
|
if(groupContextHelp)
|
||||||
|
{
|
||||||
|
/** If there's a modal box around, should be sure that the context help doesn't intersect it.
|
||||||
|
* If this is the case, we just disable it, unless the tooltip was generated by the current modal window
|
||||||
|
*/
|
||||||
|
if ( hasModal() )
|
||||||
|
{
|
||||||
|
CInterfaceGroup *mw = getModal().ModalWindow;
|
||||||
|
if (mw && mw->isIn(*groupContextHelp))
|
||||||
|
{
|
||||||
|
if (_CurCtrlContextHelp->isSonOf(mw))
|
||||||
|
{
|
||||||
|
groupContextHelp->executeLuaScriptOnDraw();
|
||||||
|
groupContextHelp->draw ();
|
||||||
|
// flush layers
|
||||||
|
CViewRenderer::getInstance()->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
groupContextHelp->executeLuaScriptOnDraw();
|
||||||
|
groupContextHelp->draw ();
|
||||||
|
// flush layers
|
||||||
|
CViewRenderer::getInstance()->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
groupContextHelp->executeLuaScriptOnDraw();
|
||||||
|
groupContextHelp->draw ();
|
||||||
|
// flush layers
|
||||||
|
CViewRenderer::getInstance()->flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bkup movement
|
||||||
|
_LastXContextHelp= x;
|
||||||
|
_LastYContextHelp= y;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CWidgetManager::setContextHelpActive(bool active)
|
||||||
|
{
|
||||||
|
if (!active)
|
||||||
|
{
|
||||||
|
disableContextHelp();
|
||||||
|
}
|
||||||
|
_ContextHelpActive = active;
|
||||||
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CWidgetManager::movePointer (sint32 dx, sint32 dy)
|
void CWidgetManager::movePointer (sint32 dx, sint32 dy)
|
||||||
{
|
{
|
||||||
|
@ -1494,6 +2049,11 @@ namespace NLGUI
|
||||||
{
|
{
|
||||||
_Pointer = NULL;
|
_Pointer = NULL;
|
||||||
curContextHelp = NULL;
|
curContextHelp = NULL;
|
||||||
|
_ContextHelpActive = true;
|
||||||
|
_DeltaTimeStopingContextHelp = 0;
|
||||||
|
_MaxTimeStopingContextHelp= 0.2f;
|
||||||
|
_LastXContextHelp= -10000;
|
||||||
|
_LastYContextHelp= -10000;
|
||||||
|
|
||||||
resetColorProps();
|
resetColorProps();
|
||||||
|
|
||||||
|
|
|
@ -3705,7 +3705,7 @@ public:
|
||||||
ucstring str;
|
ucstring str;
|
||||||
fillPlayerBarText(str, "HP", SCORES::hit_points, "uittPlayerLifeFormat");
|
fillPlayerBarText(str, "HP", SCORES::hit_points, "uittPlayerLifeFormat");
|
||||||
|
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerPlayerTTLife, "player_tt_life");
|
REGISTER_ACTION_HANDLER(CHandlerPlayerTTLife, "player_tt_life");
|
||||||
|
@ -3722,7 +3722,7 @@ public:
|
||||||
ucstring str;
|
ucstring str;
|
||||||
fillPlayerBarText(str, "STA", SCORES::stamina, "uittPlayerStaminaFormat");
|
fillPlayerBarText(str, "STA", SCORES::stamina, "uittPlayerStaminaFormat");
|
||||||
|
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerPlayerTTStamina, "player_tt_stamina");
|
REGISTER_ACTION_HANDLER(CHandlerPlayerTTStamina, "player_tt_stamina");
|
||||||
|
@ -3739,7 +3739,7 @@ public:
|
||||||
ucstring str;
|
ucstring str;
|
||||||
fillPlayerBarText(str, "SAP", SCORES::sap, "uittPlayerSapFormat");
|
fillPlayerBarText(str, "SAP", SCORES::sap, "uittPlayerSapFormat");
|
||||||
|
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerPlayerTTSap, "player_tt_sap");
|
REGISTER_ACTION_HANDLER(CHandlerPlayerTTSap, "player_tt_sap");
|
||||||
|
@ -3756,7 +3756,7 @@ public:
|
||||||
ucstring str;
|
ucstring str;
|
||||||
fillPlayerBarText(str, "FOCUS", SCORES::focus, "uittPlayerFocusFormat");
|
fillPlayerBarText(str, "FOCUS", SCORES::focus, "uittPlayerFocusFormat");
|
||||||
|
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerPlayerTTFocus, "player_tt_focus");
|
REGISTER_ACTION_HANDLER(CHandlerPlayerTTFocus, "player_tt_focus");
|
||||||
|
@ -3786,7 +3786,7 @@ public:
|
||||||
ucstring str= CI18N::get("uittBulkFormat");
|
ucstring str= CI18N::get("uittBulkFormat");
|
||||||
strFindReplace(str, "%v", toString(val) );
|
strFindReplace(str, "%v", toString(val) );
|
||||||
strFindReplace(str, "%m", toString(maxVal) );
|
strFindReplace(str, "%m", toString(maxVal) );
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerGetTTBulk, "get_tt_bulk");
|
REGISTER_ACTION_HANDLER(CHandlerGetTTBulk, "get_tt_bulk");
|
||||||
|
|
|
@ -3546,7 +3546,7 @@ void setConsoModSuccessTooltip( CDBCtrlSheet *cs )
|
||||||
strFindReplace(ustr, "%modifier", "@{0F0F}"+toString(nodeSM->getValue32())+"@{FFFF}");
|
strFindReplace(ustr, "%modifier", "@{0F0F}"+toString(nodeSM->getValue32())+"@{FFFF}");
|
||||||
|
|
||||||
// replace the context help that is required.
|
// replace the context help that is required.
|
||||||
pIM->setContextHelpText(ustr);
|
CWidgetManager::getInstance()->setContextHelpText(ustr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3568,13 +3568,13 @@ public:
|
||||||
// special tooltip? (pvp outpost and xp catalyzer)
|
// special tooltip? (pvp outpost and xp catalyzer)
|
||||||
sint specialTTId= getBonusMalusSpecialTT(cs);
|
sint specialTTId= getBonusMalusSpecialTT(cs);
|
||||||
if(specialTTId==BONUS_MALUS::XpCatalyser)
|
if(specialTTId==BONUS_MALUS::XpCatalyser)
|
||||||
pIM->setContextHelpText(CI18N::get("uittXpBonus"));
|
CWidgetManager::getInstance()->setContextHelpText(CI18N::get("uittXpBonus"));
|
||||||
else if(specialTTId==BONUS_MALUS::OutpostPVPOn)
|
else if(specialTTId==BONUS_MALUS::OutpostPVPOn)
|
||||||
pIM->setContextHelpText(CI18N::get("uittPvpOutpostOn"));
|
CWidgetManager::getInstance()->setContextHelpText(CI18N::get("uittPvpOutpostOn"));
|
||||||
else if(specialTTId==BONUS_MALUS::OutpostPVPOutOfZone)
|
else if(specialTTId==BONUS_MALUS::OutpostPVPOutOfZone)
|
||||||
pIM->setContextHelpText(CI18N::get("uittPvpOutpostOutOfZone"));
|
CWidgetManager::getInstance()->setContextHelpText(CI18N::get("uittPvpOutpostOutOfZone"));
|
||||||
else if(specialTTId==BONUS_MALUS::OutpostPVPInRound)
|
else if(specialTTId==BONUS_MALUS::OutpostPVPInRound)
|
||||||
pIM->setContextHelpText(CI18N::get("uittPvpOutpostInRound"));
|
CWidgetManager::getInstance()->setContextHelpText(CI18N::get("uittPvpOutpostInRound"));
|
||||||
else if(specialTTId==BONUS_MALUS::DeathPenalty)
|
else if(specialTTId==BONUS_MALUS::DeathPenalty)
|
||||||
{
|
{
|
||||||
CCDBNodeLeaf * node = NLGUI::CDBManager::getInstance()->getDbProp("SERVER:USER:DEATH_XP_MALUS", false);
|
CCDBNodeLeaf * node = NLGUI::CDBManager::getInstance()->getDbProp("SERVER:USER:DEATH_XP_MALUS", false);
|
||||||
|
@ -3582,7 +3582,7 @@ public:
|
||||||
{
|
{
|
||||||
ucstring txt = CI18N::get("uittDeathPenalty");
|
ucstring txt = CI18N::get("uittDeathPenalty");
|
||||||
strFindReplace(txt, "%dp", toString((100*node->getValue16())/254));
|
strFindReplace(txt, "%dp", toString((100*node->getValue16())/254));
|
||||||
pIM->setContextHelpText(txt);
|
CWidgetManager::getInstance()->setContextHelpText(txt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// if disabled.
|
// if disabled.
|
||||||
|
@ -3595,7 +3595,7 @@ public:
|
||||||
str+= CI18N::get("uittAuraDisabled");
|
str+= CI18N::get("uittAuraDisabled");
|
||||||
|
|
||||||
// and replace the context help that is required.
|
// and replace the context help that is required.
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
// else keep the default one
|
// else keep the default one
|
||||||
}
|
}
|
||||||
|
@ -3622,7 +3622,7 @@ public:
|
||||||
CCDBNodeLeaf *node = NLGUI::CDBManager::getInstance()->getDbProp(toString("SERVER:PACK_ANIMAL:BEAST%d:NAME", index));
|
CCDBNodeLeaf *node = NLGUI::CDBManager::getInstance()->getDbProp(toString("SERVER:PACK_ANIMAL:BEAST%d:NAME", index));
|
||||||
if (node && CStringManagerClient::instance()->getDynString(node->getValue32(), txt))
|
if (node && CStringManagerClient::instance()->getDynString(node->getValue32(), txt))
|
||||||
{
|
{
|
||||||
pIM->setContextHelpText(CEntityCL::removeTitleFromName(txt));
|
CWidgetManager::getInstance()->setContextHelpText(CEntityCL::removeTitleFromName(txt));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -3668,7 +3668,7 @@ public:
|
||||||
str += toString(minTimeRemaining);
|
str += toString(minTimeRemaining);
|
||||||
|
|
||||||
// replace the context help that is required.
|
// replace the context help that is required.
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER( CHandlerAnimalDeadPopupTooltip, "animal_dead_popup_tooltip");
|
REGISTER_ACTION_HANDLER( CHandlerAnimalDeadPopupTooltip, "animal_dead_popup_tooltip");
|
||||||
|
|
|
@ -1652,7 +1652,7 @@ public:
|
||||||
else
|
else
|
||||||
strFindReplace(str, "%comp", CI18N::get("uittPhraseCombatRestrictOK"));
|
strFindReplace(str, "%comp", CI18N::get("uittPhraseCombatRestrictOK"));
|
||||||
|
|
||||||
pIM->setContextHelpText(str);
|
CWidgetManager::getInstance()->setContextHelpText(str);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER( CHandlerCombatRestrictTooltip, "phrase_combat_restrict_tooltip");
|
REGISTER_ACTION_HANDLER( CHandlerCombatRestrictTooltip, "phrase_combat_restrict_tooltip");
|
||||||
|
|
|
@ -2426,10 +2426,8 @@ class CHandlerBotChatTTItemType : public IActionHandler
|
||||||
public:
|
public:
|
||||||
void execute (CCtrlBase * /* pCaller */, const std::string &/* sParams */)
|
void execute (CCtrlBase * /* pCaller */, const std::string &/* sParams */)
|
||||||
{
|
{
|
||||||
CInterfaceManager *pIM= CInterfaceManager::getInstance();
|
|
||||||
|
|
||||||
// \todo yoyo: for now disable tooltip
|
// \todo yoyo: for now disable tooltip
|
||||||
pIM->setContextHelpText(ucstring());
|
CWidgetManager::getInstance()->setContextHelpText(ucstring());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
REGISTER_ACTION_HANDLER(CHandlerBotChatTTItemType, "botchat_tt_item_type");
|
REGISTER_ACTION_HANDLER(CHandlerBotChatTTItemType, "botchat_tt_item_type");
|
||||||
|
|
|
@ -439,11 +439,6 @@ CInterfaceManager::CInterfaceManager( NL3D::UDriver *driver, NL3D::UTextContext
|
||||||
_ErrorColor = NULL;
|
_ErrorColor = NULL;
|
||||||
_EmotesInitialized = false;
|
_EmotesInitialized = false;
|
||||||
|
|
||||||
// context help
|
|
||||||
CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp = 0;
|
|
||||||
_MaxTimeStopingContextHelp= 0.2f;
|
|
||||||
_LastXContextHelp= -10000;
|
|
||||||
_LastYContextHelp= -10000;
|
|
||||||
|
|
||||||
// Global initialization
|
// Global initialization
|
||||||
// *********************
|
// *********************
|
||||||
|
@ -469,8 +464,6 @@ CInterfaceManager::CInterfaceManager( NL3D::UDriver *driver, NL3D::UTextContext
|
||||||
_CheckForumNode = NULL;
|
_CheckForumNode = NULL;
|
||||||
_UpdateWeatherTime = 0;
|
_UpdateWeatherTime = 0;
|
||||||
|
|
||||||
_ContextHelpActive = true;
|
|
||||||
|
|
||||||
_DBB_UI_DUMMY = NULL;
|
_DBB_UI_DUMMY = NULL;
|
||||||
_DB_UI_DUMMY_QUANTITY = NULL;
|
_DB_UI_DUMMY_QUANTITY = NULL;
|
||||||
_DB_UI_DUMMY_QUALITY = NULL;
|
_DB_UI_DUMMY_QUALITY = NULL;
|
||||||
|
@ -2060,10 +2053,10 @@ void CInterfaceManager::drawViews(NL3D::UCamera camera)
|
||||||
NLGUI::CDBManager::getInstance()->flushObserverCalls();
|
NLGUI::CDBManager::getInstance()->flushObserverCalls();
|
||||||
|
|
||||||
// draw the special over extend text
|
// draw the special over extend text
|
||||||
drawOverExtendViewText();
|
CWidgetManager::getInstance()->drawOverExtendViewText();
|
||||||
|
|
||||||
// draw the context help
|
// draw the context help
|
||||||
drawContextHelp ();
|
CWidgetManager::getInstance()->drawContextHelp ();
|
||||||
|
|
||||||
// Draw the pointer and DND Item
|
// Draw the pointer and DND Item
|
||||||
if ( CWidgetManager::getInstance()->getPointer() != NULL)
|
if ( CWidgetManager::getInstance()->getPointer() != NULL)
|
||||||
|
@ -2111,448 +2104,6 @@ void CInterfaceManager::drawViews(NL3D::UCamera camera)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
CCtrlBase* CInterfaceManager::getNewContextHelpCtrl()
|
|
||||||
{
|
|
||||||
// get the top most ctrl under us
|
|
||||||
CCtrlBase *best = NULL;
|
|
||||||
sint8 bestRenderLayer = -128;
|
|
||||||
const std::vector< CCtrlBase* >& _CtrlsUnderPointer = CWidgetManager::getInstance()->getCtrlsUnderPointer();
|
|
||||||
for (sint i = (sint32)_CtrlsUnderPointer.size()-1; i>=0; i--)
|
|
||||||
{
|
|
||||||
CCtrlBase *pICL = _CtrlsUnderPointer[i];
|
|
||||||
if (pICL->getRenderLayer() > bestRenderLayer)
|
|
||||||
{
|
|
||||||
if ((pICL->getActive()) && (!pICL->emptyContextHelp()))
|
|
||||||
{
|
|
||||||
if (!CWidgetManager::getInstance()->getPointer()) return pICL;
|
|
||||||
sint32 mx, my;
|
|
||||||
CWidgetManager::getInstance()->getPointer()->getPointerPos(mx, my);
|
|
||||||
if (pICL->preciseHitTest(mx, my))
|
|
||||||
{
|
|
||||||
best = pICL;
|
|
||||||
bestRenderLayer = pICL->getRenderLayer();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!best)
|
|
||||||
{
|
|
||||||
// if a control was not found, try with the groups
|
|
||||||
sint8 bestRenderLayer = -128;
|
|
||||||
const std::vector< CInterfaceGroup* >& _GroupsUnderPointer = CWidgetManager::getInstance()->getGroupsUnderPointer();
|
|
||||||
for (sint i = (sint32)_GroupsUnderPointer.size()-1; i>=0; i--)
|
|
||||||
{
|
|
||||||
CCtrlBase *pICL = _GroupsUnderPointer[i];
|
|
||||||
if (pICL->getRenderLayer() > bestRenderLayer)
|
|
||||||
{
|
|
||||||
if ((pICL->getActive()) && (!pICL->emptyContextHelp()))
|
|
||||||
{
|
|
||||||
if (!CWidgetManager::getInstance()->getPointer()) return pICL;
|
|
||||||
sint32 mx, my;
|
|
||||||
CWidgetManager::getInstance()->getPointer()->getPointerPos(mx, my);
|
|
||||||
if (pICL->preciseHitTest(mx, my))
|
|
||||||
{
|
|
||||||
best = pICL;
|
|
||||||
bestRenderLayer = pICL->getRenderLayer();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return best;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
CInterfaceGroup *CInterfaceManager::getWindowForActiveMasterGroup(const std::string &window)
|
|
||||||
{
|
|
||||||
std::vector< CWidgetManager::SMasterGroup > &_MasterGroups = CWidgetManager::getInstance()->getAllMasterGroup();
|
|
||||||
// Search for all elements
|
|
||||||
for (uint32 nMasterGroup = 0; nMasterGroup < _MasterGroups.size(); nMasterGroup++)
|
|
||||||
{
|
|
||||||
const CWidgetManager::SMasterGroup &rMG = _MasterGroups[nMasterGroup];
|
|
||||||
if (rMG.Group->getActive())
|
|
||||||
{
|
|
||||||
CInterfaceElement *pEL= CWidgetManager::getInstance()->getElementFromId( rMG.Group->getId() + ":" + window);
|
|
||||||
if(pEL && pEL->isGroup())
|
|
||||||
return (CInterfaceGroup*)pEL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::updateTooltipCoords()
|
|
||||||
{
|
|
||||||
updateTooltipCoords( CWidgetManager::getInstance()->getCurContextHelp() );
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::updateTooltipCoords(CCtrlBase *newCtrl)
|
|
||||||
{
|
|
||||||
if (!newCtrl) return;
|
|
||||||
if (!newCtrl->getInvalidCoords()) return;
|
|
||||||
CInterfaceGroup *groupContextHelp = getWindowForActiveMasterGroup(newCtrl->getContextHelpWindowName());
|
|
||||||
if(groupContextHelp)
|
|
||||||
{
|
|
||||||
CViewText *pTxt = (CViewText*)groupContextHelp->getView("text");
|
|
||||||
if (pTxt != NULL)
|
|
||||||
{
|
|
||||||
pTxt->setTextFormatTaged(_ContextHelpText);
|
|
||||||
// update only to get correct W/H
|
|
||||||
groupContextHelp->updateCoords ();
|
|
||||||
|
|
||||||
|
|
||||||
// **** Compute parent coordinates
|
|
||||||
CCtrlBase::TToolTipParentType parentType= newCtrl->getToolTipParent();
|
|
||||||
CInterfaceGroup *win= NULL;
|
|
||||||
// adjust to the mouse by default
|
|
||||||
sint32 xParent= CWidgetManager::getInstance()->getPointer()->getX();
|
|
||||||
sint32 yParent= CWidgetManager::getInstance()->getPointer()->getY();
|
|
||||||
sint32 wParent= 0;
|
|
||||||
sint32 hParent= 0;
|
|
||||||
// adjust to the window
|
|
||||||
if(parentType==CCtrlBase::TTWindow || parentType==CCtrlBase::TTSpecialWindow)
|
|
||||||
{
|
|
||||||
if(parentType==CCtrlBase::TTWindow)
|
|
||||||
win= newCtrl->getRootWindow();
|
|
||||||
else
|
|
||||||
win= dynamic_cast<CInterfaceGroup*>(CWidgetManager::getInstance()->getElementFromId(newCtrl->getToolTipSpecialParent()));
|
|
||||||
if(win)
|
|
||||||
{
|
|
||||||
xParent = win->getXReal();
|
|
||||||
yParent = win->getYReal();
|
|
||||||
wParent = win->getWReal();
|
|
||||||
hParent = win->getHReal();
|
|
||||||
}
|
|
||||||
// Bug...: leave default to pointer
|
|
||||||
}
|
|
||||||
// adjust to the ctrl
|
|
||||||
else if (parentType==CCtrlBase::TTCtrl)
|
|
||||||
{
|
|
||||||
xParent = newCtrl->getXReal();
|
|
||||||
yParent = newCtrl->getYReal();
|
|
||||||
wParent = newCtrl->getWReal();
|
|
||||||
hParent = newCtrl->getHReal();
|
|
||||||
// Additionaly, must clip this ctrl with its parent
|
|
||||||
// (else animals are buggy for instance)
|
|
||||||
CInterfaceGroup *parent= newCtrl->getParent();
|
|
||||||
if(parent)
|
|
||||||
{
|
|
||||||
sint32 xClip,yClip,wClip,hClip;
|
|
||||||
parent->getClip(xClip,yClip,wClip,hClip);
|
|
||||||
// clip bottom left
|
|
||||||
xParent= max(xParent, xClip);
|
|
||||||
yParent= max(yParent, yClip);
|
|
||||||
// clip top right
|
|
||||||
sint32 xrParent= min(xParent+ wParent, xClip+wClip);
|
|
||||||
sint32 ytParent= min(yParent+ hParent, yClip+hClip);
|
|
||||||
wParent= max((sint32)0, xrParent-xParent);
|
|
||||||
hParent= max((sint32)0, ytParent-yParent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// **** resolve auto posref
|
|
||||||
uint clampCount = adjustTooltipPosition(newCtrl, win, newCtrl->getToolTipParentPosRef(), newCtrl->getToolTipPosRef(), xParent, yParent, wParent, hParent);
|
|
||||||
if (clampCount != 0)
|
|
||||||
{
|
|
||||||
// try to fallback on alternate tooltip posref
|
|
||||||
uint altClampCount = adjustTooltipPosition(newCtrl, win, newCtrl->getToolTipParentPosRefAlt(), newCtrl->getToolTipPosRefAlt(), xParent, yParent, wParent, hParent);
|
|
||||||
if (altClampCount > clampCount)
|
|
||||||
{
|
|
||||||
// worst ? resume to first posref
|
|
||||||
adjustTooltipPosition(newCtrl, win, newCtrl->getToolTipParentPosRef(), newCtrl->getToolTipPosRef(), xParent, yParent, wParent, hParent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::drawContextHelp ()
|
|
||||||
{
|
|
||||||
if (!CWidgetManager::getInstance()->getPointer() || !_ContextHelpActive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
|
|
||||||
sint32 x = CWidgetManager::getInstance()->getPointer()->getX();
|
|
||||||
sint32 y = CWidgetManager::getInstance()->getPointer()->getY();
|
|
||||||
|
|
||||||
|
|
||||||
// ***************
|
|
||||||
// **** try to disable
|
|
||||||
// ***************
|
|
||||||
// test disable first, so can recheck asap if another present. see below
|
|
||||||
CCtrlBase *_CurCtrlContextHelp = CWidgetManager::getInstance()->getCurContextHelp();
|
|
||||||
if( _CurCtrlContextHelp)
|
|
||||||
{
|
|
||||||
if(x!=_LastXContextHelp || y!=_LastYContextHelp)
|
|
||||||
{
|
|
||||||
// May change of ctrl!! => disable context help
|
|
||||||
CCtrlBase *newCtrl= getNewContextHelpCtrl();
|
|
||||||
if(newCtrl!=_CurCtrlContextHelp)
|
|
||||||
{
|
|
||||||
// disable
|
|
||||||
disableContextHelp();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if _CurCtrlContextHelp is visible
|
|
||||||
if (_CurCtrlContextHelp == NULL)
|
|
||||||
{
|
|
||||||
disableContextHelp();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
bool bVisible = true;
|
|
||||||
if (_CurCtrlContextHelp->getActive() == false)
|
|
||||||
bVisible = false;
|
|
||||||
CInterfaceGroup *pParent = _CurCtrlContextHelp->getParent();
|
|
||||||
while (pParent != NULL)
|
|
||||||
{
|
|
||||||
if (pParent->getActive() == false)
|
|
||||||
bVisible = false;
|
|
||||||
pParent = pParent->getParent();
|
|
||||||
}
|
|
||||||
if (!bVisible)
|
|
||||||
disableContextHelp();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ***************
|
|
||||||
// **** try to acquire
|
|
||||||
// ***************
|
|
||||||
if(!_CurCtrlContextHelp)
|
|
||||||
{
|
|
||||||
// get the ctrl of interset
|
|
||||||
CCtrlBase *newCtrl= getNewContextHelpCtrl();
|
|
||||||
|
|
||||||
if(x==_LastXContextHelp && y==_LastYContextHelp)
|
|
||||||
CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp+= DT;
|
|
||||||
else
|
|
||||||
CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp = 0;
|
|
||||||
|
|
||||||
// If reach the time limit
|
|
||||||
if( CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp > _MaxTimeStopingContextHelp || (newCtrl && newCtrl->wantInstantContextHelp()))
|
|
||||||
{
|
|
||||||
// if present, get the ctx help text.
|
|
||||||
if(newCtrl)
|
|
||||||
{
|
|
||||||
// get the text
|
|
||||||
//newCtrl->getContextHelpToolTip(_ContextHelpText);
|
|
||||||
newCtrl->getContextHelp(_ContextHelpText);
|
|
||||||
// UserDefined context help
|
|
||||||
if( !newCtrl->getContextHelpActionHandler().empty() )
|
|
||||||
{
|
|
||||||
CAHManager::getInstance()->runActionHandler(newCtrl->getContextHelpActionHandler(), newCtrl, newCtrl->getContextHelpAHParams() );
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the text is finally empty (Special AH case), abort
|
|
||||||
if(_ContextHelpText.empty())
|
|
||||||
newCtrl= NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// not present? wait furthermore to move the mouse.
|
|
||||||
if(!newCtrl)
|
|
||||||
CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp= 0;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// enable
|
|
||||||
CWidgetManager::getInstance()->setCurContextHelp( newCtrl );
|
|
||||||
newCtrl->invalidateCoords();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
updateTooltipCoords(_CurCtrlContextHelp);
|
|
||||||
|
|
||||||
|
|
||||||
// ***************
|
|
||||||
// **** display
|
|
||||||
// ***************
|
|
||||||
if(_CurCtrlContextHelp)
|
|
||||||
{
|
|
||||||
CInterfaceGroup *groupContextHelp = getWindowForActiveMasterGroup(_CurCtrlContextHelp->getContextHelpWindowName());
|
|
||||||
if(groupContextHelp)
|
|
||||||
{
|
|
||||||
/** If there's a modal box around, should be sure that the context help doesn't intersect it.
|
|
||||||
* If this is the case, we just disable it, unless the tooltip was generated by the current modal window
|
|
||||||
*/
|
|
||||||
if ( CWidgetManager::getInstance()->hasModal() )
|
|
||||||
{
|
|
||||||
CInterfaceGroup *mw = CWidgetManager::getInstance()->getModal().ModalWindow;
|
|
||||||
if (mw && mw->isIn(*groupContextHelp))
|
|
||||||
{
|
|
||||||
if (_CurCtrlContextHelp->isSonOf(mw))
|
|
||||||
{
|
|
||||||
groupContextHelp->executeLuaScriptOnDraw();
|
|
||||||
groupContextHelp->draw ();
|
|
||||||
// flush layers
|
|
||||||
CViewRenderer::getInstance()->flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
groupContextHelp->executeLuaScriptOnDraw();
|
|
||||||
groupContextHelp->draw ();
|
|
||||||
// flush layers
|
|
||||||
CViewRenderer::getInstance()->flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
groupContextHelp->executeLuaScriptOnDraw();
|
|
||||||
groupContextHelp->draw ();
|
|
||||||
// flush layers
|
|
||||||
CViewRenderer::getInstance()->flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Bkup movement
|
|
||||||
_LastXContextHelp= x;
|
|
||||||
_LastYContextHelp= y;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CInterfaceManager::setContextHelpActive(bool active)
|
|
||||||
{
|
|
||||||
if (!active)
|
|
||||||
{
|
|
||||||
disableContextHelp();
|
|
||||||
}
|
|
||||||
_ContextHelpActive = active;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
uint CInterfaceManager::adjustTooltipPosition(CCtrlBase *newCtrl,
|
|
||||||
CInterfaceGroup *win,
|
|
||||||
THotSpot ttParentRef,
|
|
||||||
THotSpot ttPosRef,
|
|
||||||
sint32 xParent,
|
|
||||||
sint32 yParent,
|
|
||||||
sint32 wParent,
|
|
||||||
sint32 hParent
|
|
||||||
)
|
|
||||||
{
|
|
||||||
CCtrlBase::TToolTipParentType parentType= newCtrl->getToolTipParent();
|
|
||||||
CInterfaceGroup *groupContextHelp = getWindowForActiveMasterGroup(newCtrl->getContextHelpWindowName());
|
|
||||||
if(ttPosRef==Hotspot_TTAuto || ttParentRef==Hotspot_TTAuto)
|
|
||||||
{
|
|
||||||
// NB: keep the special window if type is specialwindow (defined above)
|
|
||||||
if(!win)
|
|
||||||
win= newCtrl->getRootWindow();
|
|
||||||
sint32 xWin= 0;
|
|
||||||
sint32 yWin= 0;
|
|
||||||
sint32 wWin= 0;
|
|
||||||
sint32 hWin= 0;
|
|
||||||
if(win)
|
|
||||||
{
|
|
||||||
xWin = win->getXReal();
|
|
||||||
yWin = win->getYReal();
|
|
||||||
wWin = win->getWReal();
|
|
||||||
hWin = win->getHReal();
|
|
||||||
}
|
|
||||||
// for Window, display top or bottom according to window pos/size
|
|
||||||
if(parentType==CCtrlBase::TTWindow || parentType==CCtrlBase::TTSpecialWindow)
|
|
||||||
{
|
|
||||||
sint32 top= (sint32)_ScreenH - (yWin+hWin);
|
|
||||||
sint32 bottom= yWin;
|
|
||||||
if(top>bottom)
|
|
||||||
{
|
|
||||||
ttParentRef= Hotspot_TL;
|
|
||||||
ttPosRef= Hotspot_BL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ttParentRef= Hotspot_BL;
|
|
||||||
ttPosRef= Hotspot_TL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// for Ctrl, display top, left or right according to window pos/size
|
|
||||||
else if(parentType==CCtrlBase::TTCtrl)
|
|
||||||
{
|
|
||||||
sint32 right= (sint32)_ScreenW - (xWin+wWin);
|
|
||||||
sint32 left= xWin;
|
|
||||||
if(right>left)
|
|
||||||
{
|
|
||||||
ttParentRef= Hotspot_TR;
|
|
||||||
ttPosRef= Hotspot_BL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ttParentRef= Hotspot_TL;
|
|
||||||
ttPosRef= Hotspot_BR;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// default (mouse)
|
|
||||||
ttParentRef= Hotspot_BL;
|
|
||||||
ttPosRef= Hotspot_BL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// **** compute coordinates of the tooltip
|
|
||||||
sint32 x= xParent;
|
|
||||||
sint32 y= yParent;
|
|
||||||
if (ttParentRef & Hotspot_Mx)
|
|
||||||
y += hParent/2;
|
|
||||||
if (ttParentRef & Hotspot_Tx)
|
|
||||||
y += hParent;
|
|
||||||
if (ttParentRef & Hotspot_xM)
|
|
||||||
x += wParent/2;
|
|
||||||
if (ttParentRef & Hotspot_xR)
|
|
||||||
x += wParent;
|
|
||||||
|
|
||||||
// adjust according to self posref
|
|
||||||
if (ttPosRef & Hotspot_Mx)
|
|
||||||
y -= groupContextHelp->getHReal()/2;
|
|
||||||
if (ttPosRef & Hotspot_Tx)
|
|
||||||
y -= groupContextHelp->getHReal();
|
|
||||||
if (ttPosRef & Hotspot_xM)
|
|
||||||
x -= groupContextHelp->getWReal()/2;
|
|
||||||
if (ttPosRef & Hotspot_xR)
|
|
||||||
x -= groupContextHelp->getWReal();
|
|
||||||
|
|
||||||
|
|
||||||
// **** clamp to screen coords, and set
|
|
||||||
uint clampCount = 0;
|
|
||||||
|
|
||||||
if ((x+groupContextHelp->getW()) > groupContextHelp->getParent()->getWReal())
|
|
||||||
{
|
|
||||||
++ clampCount;
|
|
||||||
x = groupContextHelp->getParent()->getWReal() - groupContextHelp->getW();
|
|
||||||
}
|
|
||||||
if (x < 0)
|
|
||||||
{
|
|
||||||
x = 0;
|
|
||||||
++ clampCount;
|
|
||||||
}
|
|
||||||
if ((y+groupContextHelp->getH()) > groupContextHelp->getParent()->getHReal())
|
|
||||||
{
|
|
||||||
y = groupContextHelp->getParent()->getHReal() - groupContextHelp->getH();
|
|
||||||
++ clampCount;
|
|
||||||
}
|
|
||||||
if (y < 0)
|
|
||||||
{
|
|
||||||
y = 0;
|
|
||||||
++ clampCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// update coords 3 times is required
|
|
||||||
groupContextHelp->setX (x);
|
|
||||||
groupContextHelp->setY (y);
|
|
||||||
groupContextHelp->updateCoords ();
|
|
||||||
groupContextHelp->updateCoords ();
|
|
||||||
groupContextHelp->updateCoords ();
|
|
||||||
|
|
||||||
return clampCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
bool CInterfaceManager::isControlInWindow (CCtrlBase *ctrl, CInterfaceGroup *pNewCurrentWnd)
|
bool CInterfaceManager::isControlInWindow (CCtrlBase *ctrl, CInterfaceGroup *pNewCurrentWnd)
|
||||||
{
|
{
|
||||||
|
@ -2623,7 +2174,7 @@ bool CInterfaceManager::handleEvent (const NLGUI::CEventDescriptor& event)
|
||||||
_LastEventKeyDesc = eventDesc;
|
_LastEventKeyDesc = eventDesc;
|
||||||
|
|
||||||
// Any Key event disable the ContextHelp
|
// Any Key event disable the ContextHelp
|
||||||
disableContextHelp();
|
CWidgetManager::getInstance()->disableContextHelp();
|
||||||
|
|
||||||
// Hide menu if the key is pushed
|
// Hide menu if the key is pushed
|
||||||
// if ((eventDesc.getKeyEventType() == NLGUI::CEventDescriptorKey::keydown) && !_ModalStack.empty() && !eventDesc.getKeyAlt() && !eventDesc.getKeyCtrl() && !eventDesc.getKeyShift())
|
// if ((eventDesc.getKeyEventType() == NLGUI::CEventDescriptorKey::keydown) && !_ModalStack.empty() && !eventDesc.getKeyAlt() && !eventDesc.getKeyCtrl() && !eventDesc.getKeyShift())
|
||||||
|
@ -2776,7 +2327,7 @@ bool CInterfaceManager::handleEvent (const NLGUI::CEventDescriptor& event)
|
||||||
// Any Mouse event but move disable the ContextHelp
|
// Any Mouse event but move disable the ContextHelp
|
||||||
if(eventDesc.getEventTypeExtended() != NLGUI::CEventDescriptorMouse::mousemove)
|
if(eventDesc.getEventTypeExtended() != NLGUI::CEventDescriptorMouse::mousemove)
|
||||||
{
|
{
|
||||||
disableContextHelp();
|
CWidgetManager::getInstance()->disableContextHelp();
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the group under the mouse
|
// get the group under the mouse
|
||||||
|
@ -3584,30 +3135,6 @@ bool CInterfaceManager::getCurrentValidMessageBoxOnOk(string &ahOnOk, const std:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::setContextHelpText(const ucstring &text)
|
|
||||||
{
|
|
||||||
_ContextHelpText = text;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::disableContextHelp()
|
|
||||||
{
|
|
||||||
CWidgetManager::getInstance()->setCurContextHelp( NULL );
|
|
||||||
CWidgetManager::getInstance()->_DeltaTimeStopingContextHelp = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
|
||||||
void CInterfaceManager::disableContextHelpForControl(CCtrlBase *pCtrl)
|
|
||||||
{
|
|
||||||
if(!pCtrl)
|
|
||||||
return;
|
|
||||||
if( CWidgetManager::getInstance()->getCurContextHelp() == pCtrl )
|
|
||||||
disableContextHelp();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
void CInterfaceManager::displayDebugInfo(const ucstring &str, TSystemInfoMode mode /*=InfoMsg*/)
|
void CInterfaceManager::displayDebugInfo(const ucstring &str, TSystemInfoMode mode /*=InfoMsg*/)
|
||||||
{
|
{
|
||||||
|
@ -3690,7 +3217,7 @@ CRGBA CInterfaceManager::getSystemInfoColor(const std::string &cat)
|
||||||
void CInterfaceManager::launchContextMenuInGame (const std::string &nameOfCM)
|
void CInterfaceManager::launchContextMenuInGame (const std::string &nameOfCM)
|
||||||
{
|
{
|
||||||
// Launch the context menu in-game: can't appear while dragging an item
|
// Launch the context menu in-game: can't appear while dragging an item
|
||||||
if (CDBCtrlSheet::getDraggedSheet() == NULL)
|
if (CCtrlDraggable::getDraggedSheet() == NULL)
|
||||||
{
|
{
|
||||||
if ( !CWidgetManager::getInstance()->hasModal() )
|
if ( !CWidgetManager::getInstance()->hasModal() )
|
||||||
{
|
{
|
||||||
|
@ -4138,86 +3665,6 @@ void CInterfaceManager::incLocalSyncActionCounter()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ***************************************************************************
|
|
||||||
void CInterfaceManager::drawOverExtendViewText()
|
|
||||||
{
|
|
||||||
// CViewRenderer &rVR= getViewRenderer();
|
|
||||||
|
|
||||||
if( CWidgetManager::getInstance()->getOverExtendViewText() )
|
|
||||||
{
|
|
||||||
CViewText *vtSrc= safe_cast<CViewText*>( CWidgetManager::getInstance()->getOverExtendViewText() );
|
|
||||||
|
|
||||||
CInterfaceGroup *groupOver = getWindowForActiveMasterGroup("over_extend_view_text");
|
|
||||||
if(groupOver)
|
|
||||||
{
|
|
||||||
CViewText *vtDst = dynamic_cast<CViewText*>(groupOver->getView("text"));
|
|
||||||
if (vtDst != NULL)
|
|
||||||
{
|
|
||||||
// Copy all aspects to the view
|
|
||||||
vtDst->setText (vtSrc->getText());
|
|
||||||
vtDst->setFontSize (vtSrc->getFontSize());
|
|
||||||
vtDst->setColor (vtSrc->getColor());
|
|
||||||
vtDst->setModulateGlobalColor(vtSrc->getModulateGlobalColor());
|
|
||||||
vtDst->setShadow(vtSrc->getShadow());
|
|
||||||
vtDst->setShadowColor(vtSrc->getShadowColor());
|
|
||||||
vtDst->setCaseMode(vtSrc->getCaseMode());
|
|
||||||
vtDst->setUnderlined(vtSrc->getUnderlined());
|
|
||||||
|
|
||||||
// setup background
|
|
||||||
CViewBitmap *pBack= dynamic_cast<CViewBitmap*>(groupOver->getView("midback"));
|
|
||||||
CViewBitmap *pOutline= dynamic_cast<CViewBitmap*>(groupOver->getView("midoutline"));
|
|
||||||
if(pBack)
|
|
||||||
pBack->setColor( CWidgetManager::getInstance()->getOverExtendViewTextBackColor() );
|
|
||||||
if(pOutline)
|
|
||||||
{
|
|
||||||
pOutline->setColor(vtSrc->getColor());
|
|
||||||
pOutline->setModulateGlobalColor(vtSrc->getModulateGlobalColor());
|
|
||||||
}
|
|
||||||
|
|
||||||
// the group is the position of the overed text, but apply the delta of borders (vtDst X/Y)
|
|
||||||
sint32 x = vtSrc->getXReal() - vtDst->getX();
|
|
||||||
sint32 y = vtSrc->getYReal() - vtDst->getY();
|
|
||||||
|
|
||||||
// update one time only to get correct W/H
|
|
||||||
groupOver->updateCoords ();
|
|
||||||
|
|
||||||
if(!vtSrc->isClampRight())
|
|
||||||
{
|
|
||||||
// clamped from the left part
|
|
||||||
x += vtSrc->getWReal() - vtDst->getWReal();
|
|
||||||
}
|
|
||||||
|
|
||||||
// clamp to screen coords, and set
|
|
||||||
if ((x+groupOver->getW()) > groupOver->getParent()->getWReal())
|
|
||||||
x = groupOver->getParent()->getWReal() - groupOver->getW();
|
|
||||||
if (x < 0)
|
|
||||||
x = 0;
|
|
||||||
if ((y+groupOver->getH()) > groupOver->getParent()->getHReal())
|
|
||||||
y = groupOver->getParent()->getHReal() - groupOver->getH();
|
|
||||||
if (y < 0)
|
|
||||||
y = 0;
|
|
||||||
|
|
||||||
// set pos
|
|
||||||
groupOver->setX (x);
|
|
||||||
groupOver->setY (y);
|
|
||||||
|
|
||||||
// update coords 3 times is required
|
|
||||||
groupOver->updateCoords ();
|
|
||||||
groupOver->updateCoords ();
|
|
||||||
groupOver->updateCoords ();
|
|
||||||
|
|
||||||
// draw
|
|
||||||
groupOver->draw ();
|
|
||||||
// flush layers
|
|
||||||
CViewRenderer::getInstance()->flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reset the ptr so at next frame, won't be rendered (but if reset)
|
|
||||||
CWidgetManager::getInstance()->setOverExtendViewText( NULL, CWidgetManager::getInstance()->getOverExtendViewTextBackColor() );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#if !FINAL_VERSION
|
#if !FINAL_VERSION
|
||||||
|
|
||||||
|
|
|
@ -287,7 +287,6 @@ public:
|
||||||
*/
|
*/
|
||||||
void drawViews (NL3D::UCamera camera);
|
void drawViews (NL3D::UCamera camera);
|
||||||
void drawAutoAdd ();
|
void drawAutoAdd ();
|
||||||
void drawContextHelp ();
|
|
||||||
//void drawContextMenu ();
|
//void drawContextMenu ();
|
||||||
|
|
||||||
/// Update all the elements
|
/// Update all the elements
|
||||||
|
@ -331,15 +330,6 @@ public:
|
||||||
*/
|
*/
|
||||||
bool getCurrentValidMessageBoxOnOk(std::string &ahOnOk, const std::string &masterGroup="ui:interface");
|
bool getCurrentValidMessageBoxOnOk(std::string &ahOnOk, const std::string &masterGroup="ui:interface");
|
||||||
|
|
||||||
/// force disable the context help
|
|
||||||
void disableContextHelp();
|
|
||||||
/// force disable the context help, if it is issued from the given control
|
|
||||||
void disableContextHelpForControl(CCtrlBase *pCtrl);
|
|
||||||
/// for ContextHelp action handler only: set the result name
|
|
||||||
void setContextHelpText(const ucstring &text);
|
|
||||||
|
|
||||||
void setContextHelpActive(bool active);
|
|
||||||
|
|
||||||
bool isMouseOverWindow() const {return _MouseOverWindow;}
|
bool isMouseOverWindow() const {return _MouseOverWindow;}
|
||||||
|
|
||||||
// Modes
|
// Modes
|
||||||
|
@ -465,8 +455,6 @@ public:
|
||||||
void notifyMailAvailable();
|
void notifyMailAvailable();
|
||||||
void notifyForumUpdated();
|
void notifyForumUpdated();
|
||||||
|
|
||||||
void updateTooltipCoords();
|
|
||||||
|
|
||||||
/** Returns a human readable timestamp with the given format.
|
/** Returns a human readable timestamp with the given format.
|
||||||
*/
|
*/
|
||||||
static char* getTimestampHuman(const char* format = "[%H:%M:%S] ");
|
static char* getTimestampHuman(const char* format = "[%H:%M:%S] ");
|
||||||
|
@ -636,16 +624,6 @@ private:
|
||||||
|
|
||||||
bool _MouseOverWindow;
|
bool _MouseOverWindow;
|
||||||
|
|
||||||
// Context Help
|
|
||||||
bool _ContextHelpActive;
|
|
||||||
//CCtrlBasePtr _CurCtrlContextHelp;
|
|
||||||
//Delay before displaying ContextHelp on a ctrl having wantInstantContextHelp set to false (in seconds)
|
|
||||||
float _MaxTimeStopingContextHelp;
|
|
||||||
sint _LastXContextHelp;
|
|
||||||
sint _LastYContextHelp;
|
|
||||||
ucstring _ContextHelpText;
|
|
||||||
CCtrlBase *getNewContextHelpCtrl();
|
|
||||||
|
|
||||||
/// Current waiting id and string from server
|
/// Current waiting id and string from server
|
||||||
struct SIDStringWaiter
|
struct SIDStringWaiter
|
||||||
{
|
{
|
||||||
|
@ -690,10 +668,6 @@ private:
|
||||||
NLMISC::CCDBNodeLeaf *_WarningColor;
|
NLMISC::CCDBNodeLeaf *_WarningColor;
|
||||||
NLMISC::CCDBNodeLeaf *_ErrorColor;
|
NLMISC::CCDBNodeLeaf *_ErrorColor;
|
||||||
|
|
||||||
void drawOverExtendViewText();
|
|
||||||
|
|
||||||
CInterfaceGroup *getWindowForActiveMasterGroup(const std::string &windowName);
|
|
||||||
|
|
||||||
CDBLandmarkObs _LandmarkObs;
|
CDBLandmarkObs _LandmarkObs;
|
||||||
|
|
||||||
/// \name LUA
|
/// \name LUA
|
||||||
|
@ -729,21 +703,6 @@ private:
|
||||||
// Pop a new message box. If the message box was found, returns a pointer on it
|
// Pop a new message box. If the message box was found, returns a pointer on it
|
||||||
void messageBoxInternal(const std::string &msgBoxGroup, const ucstring &text, const std::string &masterGroup, TCaseMode caseMode);
|
void messageBoxInternal(const std::string &msgBoxGroup, const ucstring &text, const std::string &masterGroup, TCaseMode caseMode);
|
||||||
|
|
||||||
// Internal : adjust a tooltip with respect to its parent. Returns the number of coordinate that were clamped
|
|
||||||
// against the screen border
|
|
||||||
uint adjustTooltipPosition(CCtrlBase *newCtrl,
|
|
||||||
CInterfaceGroup *win,
|
|
||||||
THotSpot ttParentRef,
|
|
||||||
THotSpot ttPosRef,
|
|
||||||
sint32 xParent,
|
|
||||||
sint32 yParent,
|
|
||||||
sint32 wParent,
|
|
||||||
sint32 hParent
|
|
||||||
);
|
|
||||||
|
|
||||||
// Update tooltip coordinate if they need to be (getInvalidCoords() returns a value != 0)
|
|
||||||
void updateTooltipCoords(CCtrlBase *newCtrl);
|
|
||||||
|
|
||||||
NL3D::UDriver *driver;
|
NL3D::UDriver *driver;
|
||||||
NL3D::UTextContext *textcontext;
|
NL3D::UTextContext *textcontext;
|
||||||
CInterfaceLink::CInterfaceLinkUpdater *interfaceLinkUpdater;
|
CInterfaceLink::CInterfaceLinkUpdater *interfaceLinkUpdater;
|
||||||
|
|
|
@ -1255,8 +1255,7 @@ int CLuaIHMRyzom::disableContextHelp(CLuaState &ls)
|
||||||
//H_AUTO(Lua_CLuaIHM_disableContextHelp)
|
//H_AUTO(Lua_CLuaIHM_disableContextHelp)
|
||||||
CLuaStackChecker lsc(&ls, 0);
|
CLuaStackChecker lsc(&ls, 0);
|
||||||
CLuaIHM::checkArgCount(ls, "disableContextHelp", 0);
|
CLuaIHM::checkArgCount(ls, "disableContextHelp", 0);
|
||||||
CInterfaceManager *pIM= CInterfaceManager::getInstance();
|
CWidgetManager::getInstance()->disableContextHelp();
|
||||||
pIM->disableContextHelp();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1275,8 +1274,7 @@ int CLuaIHMRyzom::disableContextHelpForControl(CLuaState &ls)
|
||||||
CInterfaceElement *pIE= CLuaIHM::getUIOnStack(ls, 1);
|
CInterfaceElement *pIE= CLuaIHM::getUIOnStack(ls, 1);
|
||||||
|
|
||||||
// go
|
// go
|
||||||
CInterfaceManager *pIM= CInterfaceManager::getInstance();
|
CWidgetManager::getInstance()->disableContextHelpForControl(dynamic_cast<CCtrlBase*>(pIE));
|
||||||
pIM->disableContextHelpForControl(dynamic_cast<CCtrlBase*>(pIE));
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1971,9 +1969,7 @@ std::string CLuaIHMRyzom::getDefine(const std::string &def)
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
void CLuaIHMRyzom::setContextHelpText(const ucstring &text)
|
void CLuaIHMRyzom::setContextHelpText(const ucstring &text)
|
||||||
{
|
{
|
||||||
//H_AUTO(Lua_CLuaIHM_setContextHelpText)
|
CWidgetManager::getInstance()->setContextHelpText(text);
|
||||||
CInterfaceManager *pIM= CInterfaceManager::getInstance();
|
|
||||||
pIM->setContextHelpText(text);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
|
@ -2645,7 +2641,7 @@ bool CLuaIHMRyzom::isRingAccessPointInReach()
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
void CLuaIHMRyzom::updateTooltipCoords()
|
void CLuaIHMRyzom::updateTooltipCoords()
|
||||||
{
|
{
|
||||||
CInterfaceManager::getInstance()->updateTooltipCoords();
|
CWidgetManager::getInstance()->updateTooltipCoords();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ***************************************************************************
|
// ***************************************************************************
|
||||||
|
|
|
@ -727,7 +727,7 @@ void CTool::captureMouse()
|
||||||
UserControls.captureMouse();
|
UserControls.captureMouse();
|
||||||
CWidgetManager::getInstance()->enableMouseHandling(false);
|
CWidgetManager::getInstance()->enableMouseHandling(false);
|
||||||
}
|
}
|
||||||
getUI().setContextHelpActive(false);
|
CWidgetManager::getInstance()->setContextHelpActive(false);
|
||||||
_MouseCaptured = true;
|
_MouseCaptured = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -738,7 +738,7 @@ void CTool::releaseMouse()
|
||||||
CWidgetManager::getInstance()->setCapturePointerLeft(NULL);
|
CWidgetManager::getInstance()->setCapturePointerLeft(NULL);
|
||||||
UserControls.releaseMouse();
|
UserControls.releaseMouse();
|
||||||
CWidgetManager::getInstance()->enableMouseHandling(true);
|
CWidgetManager::getInstance()->enableMouseHandling(true);
|
||||||
getUI().setContextHelpActive(true);
|
CWidgetManager::getInstance()->setContextHelpActive(true);
|
||||||
_MouseCaptured = false;
|
_MouseCaptured = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue