/* -*- 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 . */ #pragma once #include #include #include #include #include #include #include #include #include #include #include #include namespace tools { class Rectangle; } class AbsoluteScreenPixelRectangle; /** @descr This base class provides an implementation of the AccessibleContext service. */ typedef cppu::WeakComponentImplHelper< css::accessibility::XAccessible, css::accessibility::XAccessibleComponent, css::accessibility::XAccessibleContext, css::accessibility::XAccessibleEventBroadcaster, css::lang::XServiceInfo > ScAccessibleContextBaseWeakImpl; class ScAccessibleContextBase : public cppu::BaseMutex, public ScAccessibleContextBaseWeakImpl, public SfxListener { class ScAccessibleContextBaseEventListener; public: //===== internal ======================================================== ScAccessibleContextBase( css::uno::Reference xParent, const sal_Int16 aRole); virtual void Init(); virtual void SAL_CALL disposing() override; protected: virtual ~ScAccessibleContextBase() override; public: /// @throws css::uno::RuntimeException bool isShowing(); /// @throws css::uno::RuntimeException virtual bool isVisible(); ///===== SfxListener ===================================================== virtual void Notify( SfxBroadcaster& rBC, const SfxHint& rHint ) override; ///===== XAccessible ===================================================== /// Return the XAccessibleContext. virtual css::uno::Reference< css::accessibility::XAccessibleContext> SAL_CALL getAccessibleContext() override; ///===== XAccessibleComponent ============================================ virtual sal_Bool SAL_CALL containsPoint( const css::awt::Point& rPoint ) override; virtual css::uno::Reference< css::accessibility::XAccessible > SAL_CALL getAccessibleAtPoint( const css::awt::Point& rPoint ) override; virtual css::awt::Rectangle SAL_CALL getBounds( ) override; virtual css::awt::Point SAL_CALL getLocation( ) override; virtual css::awt::Point SAL_CALL getLocationOnScreen( ) override; virtual css::awt::Size SAL_CALL getSize( ) override; virtual void SAL_CALL grabFocus( ) override; virtual sal_Int32 SAL_CALL getForeground( ) override; virtual sal_Int32 SAL_CALL getBackground( ) override; ///===== XAccessibleContext ============================================== /// Return the number of currently visible children. virtual sal_Int64 SAL_CALL getAccessibleChildCount() override; /// Return the specified child or NULL if index is invalid. virtual css::uno::Reference< css::accessibility::XAccessible> SAL_CALL getAccessibleChild(sal_Int64 nIndex) override; /// Return a reference to the parent. virtual css::uno::Reference< css::accessibility::XAccessible> SAL_CALL getAccessibleParent() override; /// Return this objects index among the parents children. virtual sal_Int64 SAL_CALL getAccessibleIndexInParent() override; /// Return this object's role. virtual sal_Int16 SAL_CALL getAccessibleRole() override; /// Return this object's description. virtual OUString SAL_CALL getAccessibleDescription() override; /// Return the object's current name. virtual OUString SAL_CALL getAccessibleName() override; /// Return NULL to indicate that an empty relation set. virtual css::uno::Reference SAL_CALL getAccessibleRelationSet() override; /// Return the set of current states. virtual sal_Int64 SAL_CALL getAccessibleStateSet() override; /** Return the parents locale or throw exception if this object has no parent yet/anymore. */ virtual css::lang::Locale SAL_CALL getLocale() override; ///===== XAccessibleEventBroadcaster ===================================== /** Add listener that is informed of future changes of name, description and so on events. */ virtual void SAL_CALL addAccessibleEventListener( const css::uno::Reference& xListener) override; // Remove an existing event listener. virtual void SAL_CALL removeAccessibleEventListener( const css::uno::Reference& xListener) override; ///===== XServiceInfo ==================================================== /** Returns an identifier for the implementation of this object. */ virtual OUString SAL_CALL getImplementationName() override; /** Return whether the specified service is supported by this class. */ virtual sal_Bool SAL_CALL supportsService(const OUString& sServiceName) override; /** Returns a list of all supported services. In this case that is just the AccessibleContext and Accessible service. */ virtual css::uno::Sequence< OUString> SAL_CALL getSupportedServiceNames() override; protected: /// Return this object's description. /// /// @throws css::uno::RuntimeException virtual OUString createAccessibleDescription(); /// Return the object's current name. /// /// @throws css::uno::RuntimeException virtual OUString createAccessibleName(); /// Return the object's current bounding box relative to the desktop. /// /// @throws css::uno::RuntimeException virtual AbsoluteScreenPixelRectangle GetBoundingBoxOnScreen() const; /// Return the object's current bounding box relative to the parent object. /// /// @throws css::uno::RuntimeException virtual tools::Rectangle GetBoundingBox() const; public: /// Calls all Listener to tell they the change. void CommitChange(const css::accessibility::AccessibleEventObject& rEvent) const; /// Use this method to set initial Name without notification void SetName(const OUString& rName) { msName = rName; } /// Use this method to set initial Description without notification void SetDescription(const OUString& rDesc) { msDescription = rDesc; } void SetParent(const css::uno::Reference& rParent) { mxParent = rParent; } protected: /// Calls all FocusListener to tell they that the focus is gained. void CommitFocusGained() const; /// Calls all FocusListener to tell they that the focus is lost. void CommitFocusLost() const; bool IsDefunc() const { return rBHelper.bDisposed; } /// @throws css::lang::DisposedException void IsObjectValid() const; /// Reference to the parent object. css::uno::Reference mxParent; private: /** Description of this object. This is not a constant because it can be set from the outside. Furthermore, it changes according to the draw page's display mode. */ OUString msDescription; /** Name of this object. It changes according the draw page's display mode. */ OUString msName; /// client id in the AccessibleEventNotifier queue sal_uInt32 mnClientId; /** This is the role of this object. */ sal_Int16 maRole; rtl::Reference mxEventListener; }; /* vim:set shiftwidth=4 softtabstop=4 expandtab: */