#88610# correctly add as property change listener on our aggregate
This commit is contained in:
@@ -2,9 +2,9 @@
|
||||
*
|
||||
* $RCSfile: CheckBox.cxx,v $
|
||||
*
|
||||
* $Revision: 1.3 $
|
||||
* $Revision: 1.4 $
|
||||
*
|
||||
* last change: $Author: fs $ $Date: 2001-04-02 10:28:06 $
|
||||
* last change: $Author: fs $ $Date: 2001-06-21 18:24:00 $
|
||||
*
|
||||
* The Contents of this file are made available subject to the terms of
|
||||
* either of the following licenses
|
||||
@@ -129,10 +129,11 @@ InterfaceRef SAL_CALL OCheckBoxModel_CreateInstance(const Reference<XMultiServic
|
||||
|
||||
//------------------------------------------------------------------
|
||||
OCheckBoxModel::OCheckBoxModel(const Reference<XMultiServiceFactory>& _rxFactory)
|
||||
:OBoundControlModel(_rxFactory, VCL_CONTROLMODEL_CHECKBOX, FRM_CONTROL_CHECKBOX, sal_False)
|
||||
:OBoundControlModel(_rxFactory, VCL_CONTROLMODEL_CHECKBOX, FRM_CONTROL_CHECKBOX, sal_False, sal_False)
|
||||
// use the old control name for compytibility reasons
|
||||
,OPropertyChangeListener(m_aMutex)
|
||||
,m_bInReset(sal_False)
|
||||
,m_pAggregatePropertyMultiplexer(NULL)
|
||||
{
|
||||
m_nClassId = FormComponentType::CHECKBOX;
|
||||
m_nDefaultChecked = CB_NOCHECK;
|
||||
@@ -141,10 +142,35 @@ OCheckBoxModel::OCheckBoxModel(const Reference<XMultiServiceFactory>& _rxFactory
|
||||
increment(m_refCount);
|
||||
if (m_xAggregateSet.is())
|
||||
{
|
||||
OPropertyChangeMultiplexer* pMultiplexer = new OPropertyChangeMultiplexer(this, m_xAggregateSet);
|
||||
pMultiplexer->addProperty(PROPERTY_STATE);
|
||||
m_pAggregatePropertyMultiplexer = new OPropertyChangeMultiplexer(this, m_xAggregateSet, sal_False);
|
||||
m_pAggregatePropertyMultiplexer->acquire();
|
||||
m_pAggregatePropertyMultiplexer->addProperty(PROPERTY_STATE);
|
||||
}
|
||||
decrement(m_refCount);
|
||||
|
||||
doSetDelegator();
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
OCheckBoxModel::~OCheckBoxModel()
|
||||
{
|
||||
doResetDelegator();
|
||||
|
||||
if (m_pAggregatePropertyMultiplexer)
|
||||
{
|
||||
m_pAggregatePropertyMultiplexer->dispose();
|
||||
m_pAggregatePropertyMultiplexer->release();
|
||||
m_pAggregatePropertyMultiplexer = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
void SAL_CALL OCheckBoxModel::disposing()
|
||||
{
|
||||
if (m_pAggregatePropertyMultiplexer)
|
||||
m_pAggregatePropertyMultiplexer->dispose();
|
||||
|
||||
OBoundControlModel::disposing();
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
@@ -2,9 +2,9 @@
|
||||
*
|
||||
* $RCSfile: CheckBox.hxx,v $
|
||||
*
|
||||
* $Revision: 1.3 $
|
||||
* $Revision: 1.4 $
|
||||
*
|
||||
* last change: $Author: oj $ $Date: 2000-11-23 08:48:15 $
|
||||
* last change: $Author: fs $ $Date: 2001-06-21 18:24:00 $
|
||||
*
|
||||
* The Contents of this file are made available subject to the terms of
|
||||
* either of the following licenses
|
||||
@@ -87,6 +87,8 @@ class OCheckBoxModel :public OBoundControlModel
|
||||
sal_Int16 m_nDefaultChecked; // Soll beim Reset gecheckt werden ?
|
||||
sal_Bool m_bInReset;
|
||||
|
||||
OPropertyChangeMultiplexer* m_pAggregatePropertyMultiplexer;
|
||||
|
||||
protected:
|
||||
sal_Int16 getState(const ::com::sun::star::uno::Any& rValue);
|
||||
|
||||
@@ -96,6 +98,7 @@ protected:
|
||||
|
||||
public:
|
||||
OCheckBoxModel(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory>& _rxFactory);
|
||||
~OCheckBoxModel();
|
||||
|
||||
// XServiceInfo
|
||||
IMPLEMENTATION_NAME(OCheckBoxModel);
|
||||
@@ -133,6 +136,9 @@ public:
|
||||
) const;
|
||||
IMPLEMENT_INFO_SERVICE()
|
||||
|
||||
protected:
|
||||
virtual void SAL_CALL disposing();
|
||||
|
||||
protected:
|
||||
virtual void _reset();
|
||||
virtual sal_Bool _commit();
|
||||
|
@@ -2,9 +2,9 @@
|
||||
*
|
||||
* $RCSfile: ImageControl.cxx,v $
|
||||
*
|
||||
* $Revision: 1.16 $
|
||||
* $Revision: 1.17 $
|
||||
*
|
||||
* last change: $Author: fs $ $Date: 2001-06-18 08:56:12 $
|
||||
* last change: $Author: fs $ $Date: 2001-06-21 18:24:00 $
|
||||
*
|
||||
* The Contents of this file are made available subject to the terms of
|
||||
* either of the following licenses
|
||||
@@ -182,11 +182,12 @@ Sequence<Type> OImageControlModel::_getTypes()
|
||||
DBG_NAME(OImageControlModel)
|
||||
//------------------------------------------------------------------
|
||||
OImageControlModel::OImageControlModel(const Reference<XMultiServiceFactory>& _rxFactory)
|
||||
:OBoundControlModel(_rxFactory, VCL_CONTROLMODEL_IMAGECONTROL, FRM_CONTROL_IMAGECONTROL, sal_False)
|
||||
:OBoundControlModel(_rxFactory, VCL_CONTROLMODEL_IMAGECONTROL, FRM_CONTROL_IMAGECONTROL, sal_False, sal_False)
|
||||
// use the old control name for compytibility reasons
|
||||
,OPropertyChangeListener(m_aMutex)
|
||||
,m_pImageProducer(new ImageProducer)
|
||||
,m_bReadOnly(sal_False)
|
||||
,m_pAggregatePropertyMultiplexer(NULL)
|
||||
{
|
||||
DBG_CTOR(OImageControlModel,NULL);
|
||||
m_nClassId = FormComponentType::IMAGECONTROL;
|
||||
@@ -197,10 +198,13 @@ OImageControlModel::OImageControlModel(const Reference<XMultiServiceFactory>& _r
|
||||
increment(m_refCount);
|
||||
if (m_xAggregateSet.is())
|
||||
{
|
||||
OPropertyChangeMultiplexer* pMultiplexer = new OPropertyChangeMultiplexer(this, m_xAggregateSet);
|
||||
pMultiplexer->addProperty(PROPERTY_IMAGE_URL);
|
||||
m_pAggregatePropertyMultiplexer = new OPropertyChangeMultiplexer(this, m_xAggregateSet, sal_False);
|
||||
m_pAggregatePropertyMultiplexer->acquire();
|
||||
m_pAggregatePropertyMultiplexer->addProperty(PROPERTY_IMAGE_URL);
|
||||
}
|
||||
decrement(m_refCount);
|
||||
|
||||
doSetDelegator();
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------
|
||||
@@ -212,6 +216,15 @@ OImageControlModel::~OImageControlModel()
|
||||
dispose();
|
||||
}
|
||||
|
||||
doResetDelegator();
|
||||
|
||||
if (m_pAggregatePropertyMultiplexer)
|
||||
{
|
||||
m_pAggregatePropertyMultiplexer->dispose();
|
||||
m_pAggregatePropertyMultiplexer->release();
|
||||
m_pAggregatePropertyMultiplexer = NULL;
|
||||
}
|
||||
|
||||
DBG_DTOR(OImageControlModel,NULL);
|
||||
}
|
||||
|
||||
@@ -466,6 +479,9 @@ Any OImageControlModel::_getControlValue() const
|
||||
//------------------------------------------------------------------
|
||||
void OImageControlModel::disposing()
|
||||
{
|
||||
if (m_pAggregatePropertyMultiplexer)
|
||||
m_pAggregatePropertyMultiplexer->dispose();
|
||||
|
||||
OBoundControlModel::disposing();
|
||||
|
||||
Reference<XInputStream> xInStream;
|
||||
|
@@ -2,9 +2,9 @@
|
||||
*
|
||||
* $RCSfile: ImageControl.hxx,v $
|
||||
*
|
||||
* $Revision: 1.3 $
|
||||
* $Revision: 1.4 $
|
||||
*
|
||||
* last change: $Author: oj $ $Date: 2000-11-23 08:48:15 $
|
||||
* last change: $Author: fs $ $Date: 2001-06-21 18:24:00 $
|
||||
*
|
||||
* The Contents of this file are made available subject to the terms of
|
||||
* either of the following licenses
|
||||
@@ -98,6 +98,8 @@ class OImageControlModel
|
||||
ImageProducer* m_pImageProducer;
|
||||
sal_Bool m_bReadOnly;
|
||||
|
||||
OPropertyChangeMultiplexer* m_pAggregatePropertyMultiplexer;
|
||||
|
||||
// Helper functions
|
||||
void UpdateFromField();
|
||||
|
||||
|
Reference in New Issue
Block a user