/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ #ifndef INCLUDED_REPORTDESIGN_SOURCE_UI_INC_SCROLLHELPER_HXX #define INCLUDED_REPORTDESIGN_SOURCE_UI_INC_SCROLLHELPER_HXX #include #include #include #include "ReportDefines.hxx" #include #include #include #include #include #include "MarkedSection.hxx" #include "ReportWindow.hxx" namespace rptui { class ODesignView; class OReportWindow; class OSectionView; /** This class defines the scrollable area of the report design. It includes the h-ruler and the sections, and end marker. Not the start marker. */ typedef vcl::Window OScrollWindowHelper_BASE; class OScrollWindowHelper : public ::cppu::BaseMutex , public OScrollWindowHelper_BASE/*TabPage*/ , public ::comphelper::OPropertyChangeListener , public IMarkedSection { private: VclPtr m_aHScroll; VclPtr m_aVScroll; VclPtr m_aCornerWin; // window in the bottom right corner Size m_aTotalPixelSize; VclPtr m_pParent; VclPtr m_aReportWindow; ::rtl::Reference m_pReportDefinitionMultiPlexer; // listener for property changes DECL_LINK_TYPED( ScrollHdl, ScrollBar*, void); Size ResizeScrollBars(); void ImplInitSettings(); void impl_initScrollBar( ScrollBar& _rScrollBar ) const; OScrollWindowHelper(OScrollWindowHelper&) = delete; void operator =(OScrollWindowHelper&) = delete; protected: virtual void DataChanged( const DataChangedEvent& rDCEvt ) SAL_OVERRIDE; // window virtual void Resize() SAL_OVERRIDE; virtual bool Notify( NotifyEvent& rNEvt ) SAL_OVERRIDE; // OPropertyChangeListener virtual void _propertyChanged(const ::com::sun::star::beans::PropertyChangeEvent& _rEvent) throw( ::com::sun::star::uno::RuntimeException, std::exception) SAL_OVERRIDE; public: OScrollWindowHelper( ODesignView* _pReportDesignView); virtual ~OScrollWindowHelper(); virtual void dispose() SAL_OVERRIDE; /** late ctor */ void initialize(); inline Point getThumbPos() const { return Point(m_aHScroll->GetThumbPos(),m_aVScroll->GetThumbPos())/*m_aScrollOffset*/; } void setTotalSize(sal_Int32 _nWidth, sal_Int32 _nHeight); inline Size getTotalSize() const { return m_aTotalPixelSize; } inline ScrollBar& GetHScroll() { return *m_aHScroll.get(); } inline ScrollBar& GetVScroll() { return *m_aVScroll.get(); } // forwards void SetMode( DlgEdMode _eMode ); void SetInsertObj( sal_uInt16 eObj,const OUString& _sShapeType = OUString()); OUString GetInsertObjString() const; void setGridSnap(bool bOn); void setDragStripes(bool bOn); /** copies the current selection in this section */ void Copy(); /** returns if paste is allowed * * \return if paste is allowed */ bool IsPasteAllowed() const; /** paste a new control in this section */ void Paste(); /** Deletes the current selection in this section * */ void Delete(); /** All objects will be marked. */ void SelectAll(const sal_uInt16 _nObjectType); /** returns when a object is marked */ bool HasSelection() const; /** removes the section at the given position. * * \param _nPosition Zero based. */ void removeSection(sal_uInt16 _nPosition); /** adds a new section at position _nPosition. If the section is nothing happens. If the position is grater than the current elements, the section will be appended. */ void addSection(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection >& _xSection ,const OUString& _sColorEntry ,sal_uInt16 _nPosition = USHRT_MAX); sal_uInt16 getSectionCount() const; /** turns the grid on or off * * \param _bVisible */ void toggleGrid(bool _bVisible); /** unmark all objects on the views without the given one. * * @param _pSectionView The view where the objects should not be unmarked. */ void unmarkAllObjects(OSectionView* _pSectionView); /** shows or hides the ruler. */ void showRuler(bool _bShow); /** calculate the max width of the markers * * @param _bWithEnd if the end marker will be used for calculation as well otherwise not. * \return the max width */ sal_Int32 getMaxMarkerWidth(bool _bWithEnd) const; /** checks if the keycode is known by the child windows @param _rCode the keycode @return if the keycode is handled otherwise */ bool handleKeyEvent(const KeyEvent& _rEvent); /** the section as marked or not marked @param _pSectionView the section where to set the marked flag @param _bMark the marked flag */ void setMarked(OSectionView* _pSectionView, bool _bMark); void setMarked(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection>& _xSection, bool _bMark); void setMarked(const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Reference< ::com::sun::star::report::XReportComponent> >& _xShape, bool _bMark); // IMarkedSection OSectionWindow* getMarkedSection(NearSectionAccess nsa = CURRENT) const SAL_OVERRIDE; OSectionWindow* getSectionWindow(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection>& _xSection) const; virtual void markSection(const sal_uInt16 _nPos) SAL_OVERRIDE; /** fills the positions of all collapsed sections. * * \param _rCollapsedPositions Out parameter which holds afterwards all positions of the collapsed sections. */ void fillCollapsedSections(::std::vector& _rCollapsedPositions) const; /** collpase all sections given by their position * * \param _aCollpasedSections The position of the sections which should be collapsed. */ void collapseSections(const com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& _aCollpasedSections); /** align all marked objects in all sections * * \param eHor * \param eVert * \param bBoundRects */ void alignMarkedObjects(sal_Int32 _nControlModification, bool _bAlignAtSection, bool bBoundRects = false); sal_uInt32 getMarkedObjectCount() const; /** zoom the ruler and view windows */ void zoom(const Fraction& _aZoom); /** fills the vector with all selected control models /param _rSelection The vector will be filled and will not be cleared before. */ void fillControlModelSelection(::std::vector< ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > >& _rSelection) const; /** calculates the zoom factor. @param _eType which kind of zoom is needed */ sal_uInt16 getZoomFactor(SvxZoomType _eType) const; }; } #endif // INCLUDED_REPORTDESIGN_SOURCE_UI_INC_SCROLLHELPER_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */