diff options
author | Steve Yin <steve_y@apache.org> | 2013-11-25 16:15:58 +0000 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2013-11-25 16:52:36 +0000 |
commit | b755fb8c0f6b1282f62c12f378c0a5ecac64d490 (patch) | |
tree | 4e6df42c862fe4eafef3f52267797e811bac59e0 /include/svtools/accessibleruler.hxx | |
parent | 74bf915fb48c660bd1e3a04bec6c3a20c754b6af (diff) |
Integrate branch of IAccessible2
Change-Id: I3b5936bb92bb258f9e9e76402dd2b55f29aa686a
Diffstat (limited to 'include/svtools/accessibleruler.hxx')
-rw-r--r-- | include/svtools/accessibleruler.hxx | 247 |
1 files changed, 247 insertions, 0 deletions
diff --git a/include/svtools/accessibleruler.hxx b/include/svtools/accessibleruler.hxx new file mode 100644 index 000000000000..0f989819a22c --- /dev/null +++ b/include/svtools/accessibleruler.hxx @@ -0,0 +1,247 @@ +/* + * 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 _SVTRULERACCESSIBLE_HXX +#define _SVTRULERACCESSIBLE_HXX + +#include <com/sun/star/accessibility/XAccessible.hpp> +#include <com/sun/star/accessibility/XAccessibleComponent.hpp> +#include <com/sun/star/accessibility/XAccessibleContext.hpp> +#include <com/sun/star/accessibility/XAccessibleEventBroadcaster.hpp> +#include <com/sun/star/accessibility/IllegalAccessibleComponentStateException.hpp> + +#include <com/sun/star/beans/XPropertyChangeListener.hpp> +#include <com/sun/star/uno/Reference.hxx> +#include <cppuhelper/weak.hxx> +#include <com/sun/star/lang/XServiceInfo.hpp> +#include <com/sun/star/lang/XTypeProvider.hpp> +#include <com/sun/star/lang/XServiceName.hpp> +#include <com/sun/star/lang/IndexOutOfBoundsException.hpp> +#include <com/sun/star/lang/DisposedException.hpp> +#include <cppuhelper/interfacecontainer.h> +#include <cppuhelper/compbase5.hxx> +#include <comphelper/broadcasthelper.hxx> +#include <cppuhelper/implbase5.hxx> +#include <comphelper/servicehelper.hxx> + +namespace com { namespace sun { namespace star { namespace awt { + struct Point; + struct Rectangle; + struct Size; + class XFocusListener; +} } } } + +class Rectangle; +class Ruler; +class Window; + + +typedef ::cppu::WeakAggComponentImplHelper5< + ::com::sun::star::accessibility::XAccessible, + ::com::sun::star::accessibility::XAccessibleComponent, + ::com::sun::star::accessibility::XAccessibleContext, + ::com::sun::star::accessibility::XAccessibleEventBroadcaster, + ::com::sun::star::lang::XServiceInfo > + SvtRulerAccessible_Base; + +class SvtRulerAccessible : public ::comphelper::OBaseMutex, public SvtRulerAccessible_Base +{ +public: + //===== internal ======================================================== + SvtRulerAccessible( + const ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible>& rxParent, Ruler& rRepresentation, const ::rtl::OUString& rName ); +protected: + virtual ~SvtRulerAccessible(); +public: + //===== XAccessible ===================================================== + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessibleContext> SAL_CALL + getAccessibleContext( void ) throw( ::com::sun::star::uno::RuntimeException ); + + //===== XAccessibleComponent ============================================ + + virtual sal_Bool SAL_CALL + containsPoint( const ::com::sun::star::awt::Point& rPoint ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > SAL_CALL + getAccessibleAtPoint( const ::com::sun::star::awt::Point& rPoint ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::awt::Rectangle SAL_CALL + getBounds() throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::awt::Point SAL_CALL + getLocation() throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::awt::Point SAL_CALL + getLocationOnScreen() throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::awt::Size SAL_CALL + getSize() throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Bool SAL_CALL + isShowing() throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Bool SAL_CALL + isVisible() throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Bool SAL_CALL + isFocusTraversable() throw( ::com::sun::star::uno::RuntimeException ); + + virtual void SAL_CALL + addFocusListener( + const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XFocusListener >& xListener ) + throw( ::com::sun::star::uno::RuntimeException ); + + virtual void SAL_CALL + removeFocusListener( + const ::com::sun::star::uno::Reference< ::com::sun::star::awt::XFocusListener >& xListener ) + throw( ::com::sun::star::uno::RuntimeException ); + + virtual void SAL_CALL + grabFocus() throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::uno::Any SAL_CALL + getAccessibleKeyBinding() throw( ::com::sun::star::uno::RuntimeException ); + virtual sal_Int32 SAL_CALL + getForeground( ) throw (::com::sun::star::uno::RuntimeException); + virtual sal_Int32 SAL_CALL + getBackground( ) throw (::com::sun::star::uno::RuntimeException); + + //===== XAccessibleContext ============================================== + + virtual sal_Int32 SAL_CALL + getAccessibleChildCount( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible> SAL_CALL + getAccessibleChild( sal_Int32 nIndex ) + throw( ::com::sun::star::uno::RuntimeException, ::com::sun::star::lang::IndexOutOfBoundsException ); + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible> SAL_CALL + getAccessibleParent( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Int32 SAL_CALL + getAccessibleIndexInParent( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Int16 SAL_CALL + getAccessibleRole( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::rtl::OUString SAL_CALL + getAccessibleDescription( void ) throw (::com::sun::star::uno::RuntimeException); + + virtual ::rtl::OUString SAL_CALL + getAccessibleName( void ) throw (::com::sun::star::uno::RuntimeException); + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessibleRelationSet > SAL_CALL + getAccessibleRelationSet( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessibleStateSet > SAL_CALL + getAccessibleStateSet( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::lang::Locale SAL_CALL + getLocale( void ) + throw( ::com::sun::star::uno::RuntimeException, + ::com::sun::star::accessibility::IllegalAccessibleComponentStateException ); + //===== XAccessibleEventBroadcaster ===================================== + + virtual void SAL_CALL + addAccessibleEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessibleEventListener >& xListener )throw( com::sun::star::uno::RuntimeException ); + + virtual void SAL_CALL + removeAccessibleEventListener( const ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessibleEventListener >& xListener ) throw( com::sun::star::uno::RuntimeException ); + + //===== XServiceInfo ==================================================== + + virtual ::rtl::OUString SAL_CALL + getImplementationName( void ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual sal_Bool SAL_CALL + supportsService( const ::rtl::OUString& sServiceName ) throw( ::com::sun::star::uno::RuntimeException ); + + virtual ::com::sun::star::uno::Sequence< ::rtl::OUString> SAL_CALL + getSupportedServiceNames( void ) throw( ::com::sun::star::uno::RuntimeException ); + + //===== XTypeProvider =================================================== + + virtual ::com::sun::star::uno::Sequence<sal_Int8> SAL_CALL + getImplementationId( void ) throw( ::com::sun::star::uno::RuntimeException ); + + + + +public: + + /// Sets the name + void setName( const ::rtl::OUString& rName ); + + /// Sets the description + void setDescription( const ::rtl::OUString& rDescr ); +private: + static ::com::sun::star::uno::Sequence< sal_Int8 > getUniqueId( void ); +protected: + + /// @Return the object's current bounding box relative to the desktop. + virtual Rectangle GetBoundingBoxOnScreen( void ) throw( ::com::sun::star::uno::RuntimeException ); + + /// @Return the object's current bounding box relative to the parent object. + virtual Rectangle GetBoundingBox( void ) throw( ::com::sun::star::uno::RuntimeException ); + + + virtual void SAL_CALL disposing(); + + /// @returns true if it's disposed or in disposing + inline sal_Bool IsAlive( void ) const; + + /// @returns true if it's not disposed and no in disposing + inline sal_Bool IsNotAlive( void ) const; + + /// throws the exception DisposedException if it's not alive + void ThrowExceptionIfNotAlive( void ) throw( ::com::sun::star::lang::DisposedException ); + +private: + /** Description of this object. This is not a constant because it can + be set from the outside. + */ + ::rtl::OUString msDescription; + + /** Name of this object. + */ + ::rtl::OUString msName; + + /// Reference to the parent object. + ::com::sun::star::uno::Reference< ::com::sun::star::accessibility::XAccessible > + mxParent; + + /// pointer to internal representation + Ruler* mpRepr; + + /// client id in the AccessibleEventNotifier queue + sal_uInt32 mnClientId; + + +}; + +inline sal_Bool SvtRulerAccessible::IsAlive( void ) const +{ + return !rBHelper.bDisposed && !rBHelper.bInDispose; +} + +inline sal_Bool SvtRulerAccessible::IsNotAlive( void ) const +{ + return rBHelper.bDisposed || rBHelper.bInDispose; +} + +#endif |