Add RimFieldReference

This commit is contained in:
Magne Sjaastad
2024-10-10 10:26:08 +02:00
parent 5526ed1a82
commit c56cd59080
5 changed files with 161 additions and 29 deletions

View File

@@ -18,19 +18,21 @@
#include "RimFieldQuickAccess.h"
#include "RimFieldReference.h"
#include "Riu3DMainWindowTools.h"
#include "cafPdmUiToolButtonEditor.h"
CAF_PDM_SOURCE_INIT( RimFieldQuickAccess, "RimFieldReference" );
CAF_PDM_SOURCE_INIT( RimFieldQuickAccess, "RimFieldQuickAccess" );
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFieldQuickAccess::RimFieldQuickAccess()
{
CAF_PDM_InitFieldNoDefault( &m_object, "Object", "Object" );
CAF_PDM_InitFieldNoDefault( &m_fieldName, "FieldName", "FieldName" );
CAF_PDM_InitFieldNoDefault( &m_fieldReference, "FieldReference", "FieldReference" );
m_fieldReference = new RimFieldReference();
CAF_PDM_InitField( &m_selectObjectButton, "SelectObject", false, "...", ":/Bullet.png", "Select Object in Property Editor" );
m_selectObjectButton.uiCapability()->setUiEditorTypeName( caf::PdmUiToolButtonEditor::uiEditorTypeName() );
@@ -42,12 +44,9 @@ RimFieldQuickAccess::RimFieldQuickAccess()
//--------------------------------------------------------------------------------------------------
void RimFieldQuickAccess::setField( caf::PdmFieldHandle* field )
{
if ( !field ) return;
if ( !m_fieldReference() ) return;
auto ownerObject = field->ownerObject();
if ( !ownerObject ) return;
setField( field->ownerObject(), field->keyword() );
m_fieldReference->setField( field );
}
//--------------------------------------------------------------------------------------------------
@@ -55,9 +54,9 @@ void RimFieldQuickAccess::setField( caf::PdmFieldHandle* field )
//--------------------------------------------------------------------------------------------------
void RimFieldQuickAccess::defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering )
{
if ( field() )
if ( m_fieldReference() && m_fieldReference()->field() )
{
uiOrdering.add( field() );
uiOrdering.add( m_fieldReference()->field() );
}
uiOrdering.add( &m_selectObjectButton );
@@ -70,9 +69,9 @@ void RimFieldQuickAccess::defineUiOrdering( QString uiConfigName, caf::PdmUiOrde
//--------------------------------------------------------------------------------------------------
caf::PdmFieldHandle* RimFieldQuickAccess::field() const
{
if ( !m_object() ) return nullptr;
if ( !m_fieldReference() ) return nullptr;
return m_object->findField( m_fieldName() );
return m_fieldReference->field();
}
//--------------------------------------------------------------------------------------------------
@@ -92,18 +91,12 @@ void RimFieldQuickAccess::fieldChangedByUi( const caf::PdmFieldHandle* changedFi
{
m_selectObjectButton = false;
if ( auto pdmObj = dynamic_cast<caf::PdmObject*>( m_object() ) )
if ( m_fieldReference() )
{
Riu3DMainWindowTools::selectAsCurrentItem( pdmObj );
if ( auto pdmObj = dynamic_cast<caf::PdmObject*>( m_fieldReference->object() ) )
{
Riu3DMainWindowTools::selectAsCurrentItem( pdmObj );
}
}
}
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFieldQuickAccess::setField( caf::PdmObjectHandle* object, const QString& fieldName )
{
m_object = object;
m_fieldName = fieldName;
}