LCOV - code coverage report
Current view: top level - svx/source/inc - fmcontrolbordermanager.hxx (source / functions) Hit Total Coverage
Test: libreoffice_filtered.info Lines: 11 16 68.8 %
Date: 2012-08-25 Functions: 5 9 55.6 %
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: 0 0 -

           Branch data     Line data    Source code
       1                 :            : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
       2                 :            : /*
       3                 :            :  * This file is part of the LibreOffice project.
       4                 :            :  *
       5                 :            :  * This Source Code Form is subject to the terms of the Mozilla Public
       6                 :            :  * License, v. 2.0. If a copy of the MPL was not distributed with this
       7                 :            :  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
       8                 :            :  *
       9                 :            :  * This file incorporates work covered by the following license notice:
      10                 :            :  *
      11                 :            :  *   Licensed to the Apache Software Foundation (ASF) under one or more
      12                 :            :  *   contributor license agreements. See the NOTICE file distributed
      13                 :            :  *   with this work for additional information regarding copyright
      14                 :            :  *   ownership. The ASF licenses this file to you under the Apache
      15                 :            :  *   License, Version 2.0 (the "License"); you may not use this file
      16                 :            :  *   except in compliance with the License. You may obtain a copy of
      17                 :            :  *   the License at http://www.apache.org/licenses/LICENSE-2.0 .
      18                 :            :  */
      19                 :            : 
      20                 :            : #ifndef SVX_SOURCE_INC_FMCONTROLBORDERMANAGER_HXX
      21                 :            : #define SVX_SOURCE_INC_FMCONTROLBORDERMANAGER_HXX
      22                 :            : 
      23                 :            : #include <com/sun/star/awt/VisualEffect.hpp>
      24                 :            : #include <com/sun/star/awt/FontUnderline.hpp>
      25                 :            : #include <com/sun/star/awt/XControl.hpp>
      26                 :            : #include <com/sun/star/awt/XVclWindowPeer.hpp>
      27                 :            : #include <comphelper/stl_types.hxx>
      28                 :            : 
      29                 :            : #include <set>
      30                 :            : 
      31                 :            : namespace com { namespace sun { namespace star { namespace form { namespace validation {
      32                 :            :     class XValidatableFormComponent;
      33                 :            : } } } } }
      34                 :            : 
      35                 :            : //........................................................................
      36                 :            : namespace svxform
      37                 :            : {
      38                 :            : //........................................................................
      39                 :            : 
      40                 :            :     typedef sal_Int16 ControlStatus;
      41                 :            : 
      42                 :            :     #define CONTROL_STATUS_NONE         0x00
      43                 :            :     #define CONTROL_STATUS_FOCUSED      0x01
      44                 :            :     #define CONTROL_STATUS_MOUSE_HOVER  0x02
      45                 :            :     #define CONTROL_STATUS_INVALID      0x04
      46                 :            : 
      47                 :            :     //====================================================================
      48                 :            :     //= BorderDescriptor
      49                 :            :     //====================================================================
      50                 :            :     struct BorderDescriptor
      51                 :            :     {
      52                 :            :         sal_Int16   nBorderType;
      53                 :            :         sal_Int32   nBorderColor;
      54                 :            : 
      55                 :         57 :         BorderDescriptor()
      56                 :            :             :nBorderType( ::com::sun::star::awt::VisualEffect::FLAT )
      57                 :         57 :             ,nBorderColor( 0x00000000 )
      58                 :            :         {
      59                 :         57 :         }
      60                 :            :         inline void clear()
      61                 :            :         {
      62                 :            :             nBorderType = ::com::sun::star::awt::VisualEffect::FLAT;
      63                 :            :             nBorderColor = 0x00000000;
      64                 :            :         }
      65                 :            :     };
      66                 :            : 
      67                 :            :     //====================================================================
      68                 :            :     //= UnderlineDescriptor
      69                 :            :     //====================================================================
      70                 :            :     struct UnderlineDescriptor
      71                 :            :     {
      72                 :            :         sal_Int16 nUnderlineType;
      73                 :            :         sal_Int32 nUnderlineColor;
      74                 :            : 
      75                 :         57 :         UnderlineDescriptor()
      76                 :            :             :nUnderlineType( ::com::sun::star::awt::FontUnderline::NONE )
      77                 :         57 :             ,nUnderlineColor( 0x00000000 )
      78                 :            :         {
      79                 :         57 :         }
      80                 :            : 
      81                 :          0 :         UnderlineDescriptor( sal_Int16 _nUnderlineType, sal_Int32 _nUnderlineColor )
      82                 :            :             :nUnderlineType( _nUnderlineType )
      83                 :          0 :             ,nUnderlineColor( _nUnderlineColor )
      84                 :            :         {
      85                 :          0 :         }
      86                 :            : 
      87                 :            :         inline void clear()
      88                 :            :         {
      89                 :            :             nUnderlineType = ::com::sun::star::awt::FontUnderline::NONE;
      90                 :            :             nUnderlineColor = 0x00000000;
      91                 :            :         }
      92                 :            :     };
      93                 :            : 
      94                 :            :     //====================================================================
      95                 :            :     //= ControlData
      96                 :            :     //====================================================================
      97                 :         51 :     struct ControlData : public BorderDescriptor, UnderlineDescriptor
      98                 :            :     {
      99                 :            :         ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl > xControl;
     100                 :            :         ::rtl::OUString                                                     sOriginalHelpText;
     101                 :            : 
     102                 :         40 :         ControlData() : BorderDescriptor() { }
     103                 :         17 :         ControlData( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >& _rxControl )
     104                 :         17 :             :xControl( _rxControl )
     105                 :            :         {
     106                 :         17 :         }
     107                 :            :         void clear()
     108                 :            :         {
     109                 :            :             BorderDescriptor::clear();
     110                 :            :             UnderlineDescriptor::clear();
     111                 :            :             xControl.clear();
     112                 :            :             sOriginalHelpText = ::rtl::OUString();
     113                 :            :         }
     114                 :            :     };
     115                 :            : 
     116                 :            :     //====================================================================
     117                 :            :     //= ControlBorderManager
     118                 :            :     //====================================================================
     119                 :            :     /** manages the dynamic border color for form controls
     120                 :            : 
     121                 :            :         Used by the <type>FormController</type>, this class manages the dynamic changes in the
     122                 :            :         border color of form controls. For this a set of events have to be forwarded to the manager
     123                 :            :         instance, which then will switch the border color depending on the mouse and focus status
     124                 :            :         of the controls.
     125                 :            :     */
     126                 :            :     class ControlBorderManager
     127                 :            :     {
     128                 :            :     private:
     129                 :            :         struct ControlDataCompare : public ::std::binary_function< ControlData, ControlData, bool >
     130                 :            :         {
     131                 :          0 :            bool operator()( const ControlData& _rLHS, const ControlData& _rRHS ) const
     132                 :            :            {
     133                 :          0 :                return _rLHS.xControl.get() < _rRHS.xControl.get();
     134                 :            :            }
     135                 :            :         };
     136                 :            : 
     137                 :            :         typedef ::std::set< ControlData, ControlDataCompare > ControlBag;
     138                 :            :         typedef ::com::sun::star::awt::XVclWindowPeer                                       WindowPeer;
     139                 :            :         typedef ::com::sun::star::uno::Reference< ::com::sun::star::awt::XVclWindowPeer >   WindowPeerRef;
     140                 :            :         typedef ::std::set< WindowPeerRef, ::comphelper::OInterfaceCompare< WindowPeer > >  PeerBag;
     141                 :            : 
     142                 :            :         PeerBag     m_aColorableControls;
     143                 :            :         PeerBag     m_aNonColorableControls;
     144                 :            : 
     145                 :            :         ControlData m_aFocusControl;
     146                 :            :         ControlData m_aMouseHoverControl;
     147                 :            :         ControlBag  m_aInvalidControls;
     148                 :            : 
     149                 :            :         // ----------------
     150                 :            :         // attributes
     151                 :            :         sal_Int32   m_nFocusColor;
     152                 :            :         sal_Int32   m_nMouseHoveColor;
     153                 :            :         sal_Int32   m_nInvalidColor;
     154                 :            :         bool        m_bDynamicBorderColors;
     155                 :            : 
     156                 :            :     public:
     157                 :            :         ControlBorderManager();
     158                 :            :         ~ControlBorderManager();
     159                 :            : 
     160                 :            :     public:
     161                 :            :         void    focusGained( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl ) SAL_THROW(());
     162                 :            :         void    focusLost( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl ) SAL_THROW(());
     163                 :            :         void    mouseEntered( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl ) SAL_THROW(());
     164                 :            :         void    mouseExited( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl ) SAL_THROW(());
     165                 :            : 
     166                 :            :         void    validityChanged(
     167                 :            :                     const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >& _rxControl,
     168                 :            :                     const ::com::sun::star::uno::Reference< ::com::sun::star::form::validation::XValidatableFormComponent >& _rxValidatable
     169                 :            :                 ) SAL_THROW(());
     170                 :            : 
     171                 :            :         /// enables dynamic border color for the controls
     172                 :            :         void    enableDynamicBorderColor( );
     173                 :            :         /// disables dynamic border color for the controls
     174                 :            :         void    disableDynamicBorderColor( );
     175                 :            : 
     176                 :            :         /** sets a color to be used for a given status
     177                 :            :             @param _nStatus
     178                 :            :                 the status which the color should be applied for. Must not be CONTROL_STATUS_NONE
     179                 :            :             @param _nColor
     180                 :            :                 the color to apply for the given status
     181                 :            :         */
     182                 :            :         void    setStatusColor( ControlStatus _nStatus, sal_Int32 _nColor );
     183                 :            : 
     184                 :            :         /** restores all colors of all controls where we possibly changed them
     185                 :            :         */
     186                 :            :         void    restoreAll();
     187                 :            : 
     188                 :            :     private:
     189                 :            :         /** called when a control got one of the two possible stati (focused, and hovered with the mouse)
     190                 :            :             @param _rxControl
     191                 :            :                 the control which gained the status
     192                 :            :             @param _rControlData
     193                 :            :                 the control's status data, as a reference to our respective member
     194                 :            :         */
     195                 :            :         void    controlStatusGained(
     196                 :            :                     const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl,
     197                 :            :                     ControlData& _rControlData
     198                 :            :                 ) SAL_THROW(());
     199                 :            : 
     200                 :            :         /** called when a control lost one of the two possible stati (focused, and hovered with the mouse)
     201                 :            :             @param _rxControl
     202                 :            :                 the control which lost the status
     203                 :            :             @param _rControlData
     204                 :            :                 the control's status data, as a reference to our respective member
     205                 :            :         */
     206                 :            :         void    controlStatusLost( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxControl, ControlData& _rControlData ) SAL_THROW(());
     207                 :            : 
     208                 :            :         /** determines whether the border of a given peer can be colored
     209                 :            :             @param _rxPeer
     210                 :            :                 the peer to examine. Must not be <NULL/>
     211                 :            :         */
     212                 :            :         bool    canColorBorder( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XVclWindowPeer >& _rxPeer );
     213                 :            : 
     214                 :            :         /** determines the status of the given control
     215                 :            :         */
     216                 :            :         ControlStatus   getControlStatus( const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >& _rxControl ) SAL_THROW(());
     217                 :            : 
     218                 :            :         /** retrieves the color associated with a given ControlStatus
     219                 :            :             @param _eStatus
     220                 :            :                 the status of the control. Must not be <member>ControlStatus::none</member>
     221                 :            :         */
     222                 :            :         sal_Int32       getControlColorByStatus( ControlStatus _eStatus );
     223                 :            : 
     224                 :            :         /** sets the border color for a given control, depending on its status
     225                 :            :             @param _rxControl
     226                 :            :                 the control to set the border color for. Must not be <NULL/>
     227                 :            :             @param _rxPeer
     228                 :            :                 the peer of the control, to be passed herein for optimization the caller usually needs it, anyway).
     229                 :            :                 Must not be <NULL/>
     230                 :            :             @param _rFallback
     231                 :            :                 the color/type to use when the control has the status CONTROL_STATUS_NONE
     232                 :            :         */
     233                 :            :         void            updateBorderStyle(
     234                 :            :                             const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >& _rxControl,
     235                 :            :                             const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XVclWindowPeer >& _rxPeer,
     236                 :            :                             const BorderDescriptor& _rFallback
     237                 :            :                         ) SAL_THROW(());
     238                 :            : 
     239                 :            :         /** determines the to-be-remembered original border color and type for a control
     240                 :            : 
     241                 :            :             The method also takes into account that the control may currently have an overwritten
     242                 :            :             border style
     243                 :            : 
     244                 :            :             @param _rxControl
     245                 :            :                 the control to examine. Must not be <NULL/>, and have a non-<NULL/> peer
     246                 :            :         */
     247                 :            :         void determineOriginalBorderStyle(
     248                 :            :                     const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XControl >& _rxControl,
     249                 :            :                     BorderDescriptor& _rData
     250                 :            :                 ) const;
     251                 :            :     };
     252                 :            : 
     253                 :            : //........................................................................
     254                 :            : } // namespace svxform
     255                 :            : //........................................................................
     256                 :            : 
     257                 :            : #endif // SVX_SOURCE_INC_FMCONTROLBORDERMANAGER_HXX
     258                 :            : 
     259                 :            : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */

Generated by: LCOV version 1.10