blob: 697755a9639a96dfed2b9a46eea1cbfe743874d8 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#ifndef _SVDOUNO_HXX
#define _SVDOUNO_HXX
#include <com/sun/star/awt/XControlModel.hpp>
#include <com/sun/star/awt/XControl.hpp>
#ifndef _COM_SUN_STAR_AWT_XMULTISERVICEFACTORY_HPP_
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#endif
#include <com/sun/star/awt/XControlContainer.hpp>
#include "svx/svxdllapi.h"
#include <svx/svdorect.hxx>
//************************************************************
// Vorausdeklarationen
//************************************************************
class SdrView;
class SdrPageWindow;
class SdrControlEventListenerImpl;
namespace sdr { namespace contact {
class ViewContactOfUnoControl;
}}
//************************************************************
// SdrUnoObj
//************************************************************
struct SdrUnoObjDataHolder;
class SVX_DLLPUBLIC SdrUnoObj : public SdrRectObj
{
friend class SdrPageView;
friend class SdrControlEventListenerImpl;
SdrUnoObjDataHolder* m_pImpl;
String aUnoControlModelTypeName;
String aUnoControlTypeName;
sal_Bool bOwnUnoControlModel;
protected:
::com::sun::star::uno::Reference< com::sun::star::awt::XControlModel > xUnoControlModel; // kann auch von aussen gesetzt werden
private:
SVX_DLLPRIVATE void CreateUnoControlModel(const String& rModelName);
SVX_DLLPRIVATE void CreateUnoControlModel(const String& rModelName,
const ::com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxSFac );
public:
TYPEINFO();
SdrUnoObj(const String& rModelName, sal_Bool bOwnsModel = sal_True);
SdrUnoObj(const String& rModelName,
const ::com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxSFac,
sal_Bool bOwnsModel = sal_True);
virtual ~SdrUnoObj();
virtual void SetPage(SdrPage* pNewPage);
virtual void SetModel(SdrModel* pModel);
virtual void TakeObjInfo(SdrObjTransformInfoRec& rInfo) const;
virtual sal_uInt16 GetObjIdentifier() const;
virtual void operator = (const SdrObject& rObj);
virtual void NbcResize(const Point& rRef, const Fraction& xFact, const Fraction& yFact);
virtual void NbcSetLayer(SdrLayerID nLayer);
// SpecialDrag support
virtual bool hasSpecialDrag() const;
// FullDrag support
virtual bool supportsFullDrag() const;
virtual SdrObject* getFullDragClone() const;
virtual void TakeObjNameSingul(XubString& rName) const;
virtual void TakeObjNamePlural(XubString& rName) const;
virtual void SetContextWritingMode( const sal_Int16 _nContextWritingMode );
::com::sun::star::uno::Reference< com::sun::star::awt::XControlModel > GetUnoControlModel() const {return xUnoControlModel;}
::com::sun::star::uno::Reference< com::sun::star::awt::XControl > GetUnoControl(const SdrView& _rView, const OutputDevice& _rOut) const;
/** retrieves a temporary XControl instance for a given output device
The method GetUnoControl, used to retrieve the XControl whose parent is a given device, only works
if the SdrUnoObj has already been painted at least once onto this device. However, there are valid
scenarios where you need certain information on how a control is painted onto a window, without
actually painting it. For example, you might be interested in the DeviceInfo of an UNO control.
For those cases, you can ontain an XControl which behaves as the control which *would* be used to
paint onto a window.
@param _rWindow
the window for which should act as parent for the temporary control
@param _inout_ControlContainer
the control container belonging to the window, necessary as context
for the newly created control. A control container is usually created by calling
VCLUnoHelper::CreateControlContainer.
If _inout_ControlContainer is <NULL/>, it will be created internally, and passed to the caller.
In this case, the caller also takes ownership of the control container, and is responsible for
disposing it when not needed anymore.
@return
The requested control. This control is temporary only, and the caller is responsible for it.
In particular, the caller is required to dispose it when it's not needed anymore.
*/
::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >
GetTemporaryControlForWindow(
const Window& _rWindow,
::com::sun::star::uno::Reference< ::com::sun::star::awt::XControlContainer >& _inout_ControlContainer
) const;
const String& GetUnoControlModelTypeName() const { return aUnoControlTypeName; }
const String& GetUnoControlTypeName() const { return aUnoControlTypeName; }
virtual void SetUnoControlModel( const ::com::sun::star::uno::Reference< com::sun::star::awt::XControlModel >& xModel );
protected:
// SdrObject overridables
virtual ::sdr::contact::ViewContact* CreateObjectSpecificViewContact();
private:
/** retrieves the typed ViewContact for the object
@param _out_rpContact
Upon successfull return, ->_out_rpContact contains the ViewContact.
@return
<TRUE/> if and only if the contact was successfully retrieved. In this case,
->_out_rpContact contains a pointer to this contact.
A failure to retrieve the contact object fires an assertion in non-product builds.
*/
SVX_DLLPRIVATE bool impl_getViewContact( ::sdr::contact::ViewContactOfUnoControl*& _out_rpContact ) const;
};
#endif // _SVDOUNO_HXX