|
|
@ -34,7 +34,6 @@
|
|
|
|
#include "nel/gui/interface_expr.h"
|
|
|
|
#include "nel/gui/interface_expr.h"
|
|
|
|
#include "nel/gui/reflect_register.h"
|
|
|
|
#include "nel/gui/reflect_register.h"
|
|
|
|
#include "nel/gui/editor_selection_watcher.h"
|
|
|
|
#include "nel/gui/editor_selection_watcher.h"
|
|
|
|
#include "nel/gui/widget_addition_watcher.h"
|
|
|
|
|
|
|
|
#include "nel/misc/events.h"
|
|
|
|
#include "nel/misc/events.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace NLGUI
|
|
|
|
namespace NLGUI
|
|
|
@ -2079,9 +2078,9 @@ namespace NLGUI
|
|
|
|
|
|
|
|
|
|
|
|
if( CInterfaceElement::getEditorMode() )
|
|
|
|
if( CInterfaceElement::getEditorMode() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( !currentEditorSelection.empty() )
|
|
|
|
for( int i = 0; i < editorSelection.size(); i++ )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CInterfaceElement *e = getElementFromId( currentEditorSelection );
|
|
|
|
CInterfaceElement *e = getElementFromId( editorSelection[ i ] );
|
|
|
|
if( e != NULL )
|
|
|
|
if( e != NULL )
|
|
|
|
e->drawHighlight();
|
|
|
|
e->drawHighlight();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -2304,6 +2303,14 @@ namespace NLGUI
|
|
|
|
eventDesc.setX( _Pointer->getX() );
|
|
|
|
eventDesc.setX( _Pointer->getX() );
|
|
|
|
eventDesc.setY( _Pointer->getY() );
|
|
|
|
eventDesc.setY( _Pointer->getY() );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( CInterfaceElement::getEditorMode() )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Let's pretend we've handled the event... or actually we have!
|
|
|
|
|
|
|
|
if( ( eventDesc.getEventTypeExtended() == CEventDescriptorMouse::mouserightdown ) ||
|
|
|
|
|
|
|
|
( eventDesc.getEventTypeExtended() == CEventDescriptorMouse::mouserightup ) )
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if( isMouseHandlingEnabled() )
|
|
|
|
if( isMouseHandlingEnabled() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// First thing to do : Capture handling
|
|
|
|
// First thing to do : Capture handling
|
|
|
@ -2402,20 +2409,37 @@ namespace NLGUI
|
|
|
|
// This may happen when alt-tab has been used => the sheet is dragged but the left button is up
|
|
|
|
// This may happen when alt-tab has been used => the sheet is dragged but the left button is up
|
|
|
|
if (!CCtrlDraggable::getDraggedSheet())
|
|
|
|
if (!CCtrlDraggable::getDraggedSheet())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// Take the top most control.
|
|
|
|
if( CInterfaceElement::getEditorMode() && _GroupSelection )
|
|
|
|
uint nMaxDepth = 0;
|
|
|
|
|
|
|
|
const std::vector< CCtrlBase* >& _CtrlsUnderPointer = getCtrlsUnderPointer();
|
|
|
|
|
|
|
|
for (sint32 i = (sint32)_CtrlsUnderPointer.size()-1; i >= 0; i--)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CCtrlBase *ctrl= _CtrlsUnderPointer[i];
|
|
|
|
for( sint32 i = _GroupsUnderPointer.size() - 1; i >= 0; i-- )
|
|
|
|
if (ctrl && ctrl->isCapturable() && ctrl->isInGroup( pNewCurrentWnd ) )
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
uint d = ctrl->getDepth( pNewCurrentWnd );
|
|
|
|
CInterfaceGroup *g = _GroupsUnderPointer[ i ];
|
|
|
|
if (d > nMaxDepth)
|
|
|
|
if( ( g != NULL ) && ( g->isInGroup( pNewCurrentWnd ) ) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
nMaxDepth = d;
|
|
|
|
_CapturedView = g;
|
|
|
|
setCapturePointerLeft( ctrl );
|
|
|
|
|
|
|
|
captured = true;
|
|
|
|
captured = true;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( !captured )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Take the top most control.
|
|
|
|
|
|
|
|
uint nMaxDepth = 0;
|
|
|
|
|
|
|
|
const std::vector< CCtrlBase* >& _CtrlsUnderPointer = getCtrlsUnderPointer();
|
|
|
|
|
|
|
|
for (sint32 i = (sint32)_CtrlsUnderPointer.size()-1; i >= 0; i--)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CCtrlBase *ctrl= _CtrlsUnderPointer[i];
|
|
|
|
|
|
|
|
if (ctrl && ctrl->isCapturable() && ctrl->isInGroup( pNewCurrentWnd ) )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
uint d = ctrl->getDepth( pNewCurrentWnd );
|
|
|
|
|
|
|
|
if (d > nMaxDepth)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
nMaxDepth = d;
|
|
|
|
|
|
|
|
setCapturePointerLeft( ctrl );
|
|
|
|
|
|
|
|
captured = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -2452,6 +2476,11 @@ namespace NLGUI
|
|
|
|
// handle the capture
|
|
|
|
// handle the capture
|
|
|
|
_CapturedView->handleEvent( evnt );
|
|
|
|
_CapturedView->handleEvent( evnt );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if( CInterfaceElement::getEditorMode() )
|
|
|
|
|
|
|
|
clearEditorSelection();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Manage RightClick
|
|
|
|
// Manage RightClick
|
|
|
@ -2631,9 +2660,10 @@ namespace NLGUI
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if( draggedElement != NULL )
|
|
|
|
if( draggedElement != NULL )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
draggedElement->setXReal( newX );
|
|
|
|
sint32 dx = newX - oldX;
|
|
|
|
draggedElement->setYReal( newY );
|
|
|
|
sint32 dy = newY - oldY;
|
|
|
|
draggedElement->invalidateCoords();
|
|
|
|
|
|
|
|
|
|
|
|
draggedElement->moveBy( dx, dy );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -2666,7 +2696,30 @@ namespace NLGUI
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::stopDragging()
|
|
|
|
void CWidgetManager::stopDragging()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
draggedElement = NULL;
|
|
|
|
if( draggedElement != NULL )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CInterfaceGroup *g = getGroupUnder( draggedElement->getXReal(), draggedElement->getYReal() );
|
|
|
|
|
|
|
|
CInterfaceElement *e = draggedElement;
|
|
|
|
|
|
|
|
CInterfaceGroup *tw = getTopWindow();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( g == NULL )
|
|
|
|
|
|
|
|
g = tw;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::string oldid = e->getId();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
e->setParent( g );
|
|
|
|
|
|
|
|
e->setIdRecurse( e->getShortId() );
|
|
|
|
|
|
|
|
e->setParentPos( g );
|
|
|
|
|
|
|
|
e->setParentSize( g );
|
|
|
|
|
|
|
|
g->addElement( e );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
e->alignTo( g );
|
|
|
|
|
|
|
|
//e->setName( "==MARKED==" );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
draggedElement = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onWidgetMoved( oldid, e->getId() );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
@ -3297,25 +3350,53 @@ namespace NLGUI
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::getEditorSelection( std::vector< std::string > &selection )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
selection.clear();
|
|
|
|
|
|
|
|
for( int i = 0; i < editorSelection.size(); i++ )
|
|
|
|
|
|
|
|
selection.push_back( editorSelection[ i ] );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::setCurrentEditorSelection( const std::string &name )
|
|
|
|
void CWidgetManager::selectWidget( const std::string &name )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
std::vector< std::string >::iterator itr
|
|
|
|
|
|
|
|
= std::find( editorSelection.begin(), editorSelection.end(), name );
|
|
|
|
|
|
|
|
|
|
|
|
CInterfaceElement *e = getElementFromId( name );
|
|
|
|
CInterfaceElement *e = getElementFromId( name );
|
|
|
|
if( e != NULL )
|
|
|
|
|
|
|
|
|
|
|
|
if( itr != editorSelection.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( !currentEditorSelection.empty() )
|
|
|
|
// If multiselection is on unselect if already selected
|
|
|
|
|
|
|
|
if( multiSelection )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CInterfaceElement *prev = getElementFromId( currentEditorSelection );
|
|
|
|
editorSelection.erase( itr );
|
|
|
|
if( prev != NULL )
|
|
|
|
if( e != NULL )
|
|
|
|
prev->setEditorSelected( false );
|
|
|
|
e->setEditorSelected( false );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
e->setEditorSelected( true );
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if( !name.empty() )
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
// Select if not yet selected
|
|
|
|
|
|
|
|
if( e != NULL )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// If multiselection is off, we can only have 1 widget selected
|
|
|
|
|
|
|
|
if( !multiSelection )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
editorSelection.clear();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
e->setEditorSelected( true );
|
|
|
|
|
|
|
|
editorSelection.push_back( name );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
notifySelectionWatchers();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
currentEditorSelection = name;
|
|
|
|
void CWidgetManager::clearEditorSelection()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
editorSelection.clear();
|
|
|
|
notifySelectionWatchers();
|
|
|
|
notifySelectionWatchers();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -3324,7 +3405,7 @@ namespace NLGUI
|
|
|
|
std::vector< IEditorSelectionWatcher* >::iterator itr = selectionWatchers.begin();
|
|
|
|
std::vector< IEditorSelectionWatcher* >::iterator itr = selectionWatchers.begin();
|
|
|
|
while( itr != selectionWatchers.end() )
|
|
|
|
while( itr != selectionWatchers.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
(*itr)->selectionChanged( currentEditorSelection );
|
|
|
|
(*itr)->selectionChanged();
|
|
|
|
++itr;
|
|
|
|
++itr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -3353,36 +3434,46 @@ namespace NLGUI
|
|
|
|
selectionWatchers.erase( itr );
|
|
|
|
selectionWatchers.erase( itr );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::notifyAdditionWatchers( const std::string &widgetName )
|
|
|
|
void CWidgetManager::onWidgetAdded( const std::string &id )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::vector< IWidgetAdditionWatcher* >::const_iterator itr = additionWatchers.begin();
|
|
|
|
std::vector< IWidgetWatcher* >::const_iterator itr = widgetWatchers.begin();
|
|
|
|
while( itr != additionWatchers.end() )
|
|
|
|
while( itr != widgetWatchers.end() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
(*itr)->widgetAdded( widgetName );
|
|
|
|
(*itr)->onWidgetAdded( id );
|
|
|
|
++itr;
|
|
|
|
++itr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::registerAdditionWatcher( IWidgetAdditionWatcher *watcher )
|
|
|
|
void CWidgetManager::onWidgetMoved( const std::string &oldid, const std::string &newid )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::vector< IWidgetAdditionWatcher* >::const_iterator itr
|
|
|
|
std::vector< IWidgetWatcher* >::const_iterator itr = widgetWatchers.begin();
|
|
|
|
= std::find( additionWatchers.begin(), additionWatchers.end(), watcher );
|
|
|
|
while( itr != widgetWatchers.end() )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
(*itr)->onWidgetMoved( oldid, newid );
|
|
|
|
|
|
|
|
++itr;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::registerWidgetWatcher( IWidgetWatcher *watcher )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::vector< IWidgetWatcher* >::const_iterator itr
|
|
|
|
|
|
|
|
= std::find( widgetWatchers.begin(), widgetWatchers.end(), watcher );
|
|
|
|
// already exists
|
|
|
|
// already exists
|
|
|
|
if( itr != additionWatchers.end() )
|
|
|
|
if( itr != widgetWatchers.end() )
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
additionWatchers.push_back( watcher );
|
|
|
|
widgetWatchers.push_back( watcher );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CWidgetManager::unregisterAdditionWatcher( IWidgetAdditionWatcher *watcher )
|
|
|
|
void CWidgetManager::unregisterWidgetWatcher( IWidgetWatcher *watcher )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::vector< IWidgetAdditionWatcher* >::iterator itr
|
|
|
|
std::vector< IWidgetWatcher* >::iterator itr
|
|
|
|
= std::find( additionWatchers.begin(), additionWatchers.end(), watcher );
|
|
|
|
= std::find( widgetWatchers.begin(), widgetWatchers.end(), watcher );
|
|
|
|
// doesn't exist
|
|
|
|
// doesn't exist
|
|
|
|
if( itr == additionWatchers.end() )
|
|
|
|
if( itr == widgetWatchers.end() )
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
additionWatchers.erase( itr );
|
|
|
|
widgetWatchers.erase( itr );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CInterfaceElement* CWidgetManager::addWidgetToGroup( std::string &group, std::string &widgetClass, std::string &widgetName )
|
|
|
|
CInterfaceElement* CWidgetManager::addWidgetToGroup( std::string &group, std::string &widgetClass, std::string &widgetName )
|
|
|
@ -3415,11 +3506,103 @@ namespace NLGUI
|
|
|
|
else
|
|
|
|
else
|
|
|
|
g->addView( v );
|
|
|
|
g->addView( v );
|
|
|
|
|
|
|
|
|
|
|
|
notifyAdditionWatchers( v->getId() );
|
|
|
|
onWidgetAdded( v->getId() );
|
|
|
|
|
|
|
|
|
|
|
|
return v;
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool CWidgetManager::groupSelection()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::vector< CInterfaceElement* > elms;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Resolve the widget names
|
|
|
|
|
|
|
|
for( int i = 0; i < editorSelection.size(); i++ )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CInterfaceElement *e = getElementFromId( editorSelection[ i ] );
|
|
|
|
|
|
|
|
if( e != NULL )
|
|
|
|
|
|
|
|
elms.push_back( e );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
editorSelection.clear();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( elms.empty() )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Create the group as the subgroup of the top window
|
|
|
|
|
|
|
|
CInterfaceGroup *g = static_cast< CInterfaceGroup* >( getParser()->createClass( "interface_group" ) );
|
|
|
|
|
|
|
|
getTopWindow()->addGroup( g );
|
|
|
|
|
|
|
|
g->setParent( getTopWindow() );
|
|
|
|
|
|
|
|
g->setIdRecurse( std::string( "group" ) + NLMISC::toString( _WidgetCount ) );
|
|
|
|
|
|
|
|
_WidgetCount++;
|
|
|
|
|
|
|
|
onWidgetAdded( g->getId() );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
std::string oldId;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Reparent the widgets to the new group
|
|
|
|
|
|
|
|
for( int i = 0; i < elms.size(); i++ )
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
CInterfaceElement *e = elms[ i ];
|
|
|
|
|
|
|
|
oldId = e->getId();
|
|
|
|
|
|
|
|
CInterfaceGroup *p = e->getParent();
|
|
|
|
|
|
|
|
if( p != NULL )
|
|
|
|
|
|
|
|
p->takeElement( e );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
g->addElement( e );
|
|
|
|
|
|
|
|
e->setParent( g );
|
|
|
|
|
|
|
|
e->setParentPos( g );
|
|
|
|
|
|
|
|
e->setParentSize( g );
|
|
|
|
|
|
|
|
e->setIdRecurse( e->getShortId() );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onWidgetMoved( oldId, e->getId() );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
elms.clear();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Make sure widgets aren't clipped because the group isn't big enough
|
|
|
|
|
|
|
|
g->spanElements();
|
|
|
|
|
|
|
|
// Make sure widgets are aligned
|
|
|
|
|
|
|
|
g->alignElements();
|
|
|
|
|
|
|
|
// Align the new group to the top window
|
|
|
|
|
|
|
|
g->alignTo( getTopWindow() );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
g->setActive( true );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool CWidgetManager::unGroupSelection()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if( editorSelection.size() != 1 )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Does the element exist?
|
|
|
|
|
|
|
|
CInterfaceElement *e = getElementFromId( editorSelection[ 0 ] );
|
|
|
|
|
|
|
|
if( e == NULL )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Is the element a group?
|
|
|
|
|
|
|
|
CInterfaceGroup *g = dynamic_cast< CInterfaceGroup* >( e );
|
|
|
|
|
|
|
|
if( g == NULL )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Can't blow up a root group :(
|
|
|
|
|
|
|
|
CInterfaceGroup *p = g->getParent();
|
|
|
|
|
|
|
|
if( p == NULL )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// KABOOM!
|
|
|
|
|
|
|
|
bool ok = g->explode();
|
|
|
|
|
|
|
|
if( !ok )
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
p->delElement( g );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
clearEditorSelection();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
p->updateCoords();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CWidgetManager::CWidgetManager()
|
|
|
|
CWidgetManager::CWidgetManager()
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -3458,7 +3641,9 @@ namespace NLGUI
|
|
|
|
|
|
|
|
|
|
|
|
setScreenWH( 0, 0 );
|
|
|
|
setScreenWH( 0, 0 );
|
|
|
|
|
|
|
|
|
|
|
|
currentEditorSelection = "";
|
|
|
|
_GroupSelection = false;
|
|
|
|
|
|
|
|
multiSelection = false;
|
|
|
|
|
|
|
|
_WidgetCount = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CWidgetManager::~CWidgetManager()
|
|
|
|
CWidgetManager::~CWidgetManager()
|
|
|
@ -3472,6 +3657,8 @@ namespace NLGUI
|
|
|
|
curContextHelp = NULL;
|
|
|
|
curContextHelp = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
CStringShared::deleteStringMapper();
|
|
|
|
CStringShared::deleteStringMapper();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
editorSelection.clear();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|