Version 7.6.3.2-android, tag libreoffice-7.6.3.2-android
[LibreOffice.git] / include / vcl / accessibletable.hxx
blob7d6af73e89344d72965c62b1087869b55bb58160
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
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/.
9 * This file incorporates work covered by the following license notice:
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 .
20 #ifndef INCLUDED_VCL_ACCESSIBLETABLE_HXX
21 #define INCLUDED_VCL_ACCESSIBLETABLE_HXX
23 #include <tools/gen.hxx>
25 #include <com/sun/star/uno/Reference.hxx>
27 namespace com::sun::star::accessibility { class XAccessible; }
28 namespace vcl { class Window; }
30 namespace vcl::table
33 typedef sal_Int32 RowPos;
35 enum AccessibleTableControlObjType
37 TCTYPE_GRIDCONTROL, /// The GridControl itself.
38 TCTYPE_TABLE, /// The data table.
39 TCTYPE_ROWHEADERBAR, /// The row header bar.
40 TCTYPE_COLUMNHEADERBAR, /// The horizontal column header bar.
41 TCTYPE_TABLECELL, /// A cell of the data table.
42 TCTYPE_ROWHEADERCELL, /// A cell of the row header bar.
43 TCTYPE_COLUMNHEADERCELL, /// A cell of the column header bar.
47 /** This abstract class provides methods to implement an accessible table object.
49 class IAccessibleTable
51 public:
52 /** @return The position of the current row. */
53 virtual sal_Int32 GetCurrentRow() const = 0;
54 /** @return The position of the current column. */
55 virtual sal_Int32 GetCurrentColumn() const = 0;
56 virtual css::uno::Reference< css::accessibility::XAccessible > CreateAccessibleControl( sal_Int32 _nIndex )= 0;
57 virtual OUString GetAccessibleObjectName(AccessibleTableControlObjType eObjType, sal_Int32 _nRow, sal_Int32 _nCol) const= 0;
58 virtual void GoToCell( sal_Int32 _nColumnPos, sal_Int32 _nRow )= 0;
59 virtual bool HasColHeader() = 0;
60 virtual bool HasRowHeader() = 0;
62 /** return the description of the specified object.
63 @param eObjType
64 The type to ask for
65 @return
66 The description of the specified object.
68 virtual OUString GetAccessibleObjectDescription(AccessibleTableControlObjType eObjType) const= 0;
70 /** Fills the StateSet with all states (except DEFUNC and SHOWING, done by
71 the accessible object), depending on the specified object type. */
72 virtual void FillAccessibleStateSet( sal_Int64& rStateSet,
73 AccessibleTableControlObjType eObjType ) const= 0;
75 // Window
76 virtual tools::Rectangle GetWindowExtentsRelative(const vcl::Window *pRelativeWindow) const = 0;
77 virtual void GrabFocus()= 0;
78 virtual css::uno::Reference< css::accessibility::XAccessible > GetAccessible()= 0;
79 virtual vcl::Window* GetAccessibleParentWindow() const= 0;
80 virtual vcl::Window* GetWindowInstance()= 0;
81 virtual sal_Int32 GetAccessibleControlCount() const = 0;
82 virtual bool ConvertPointToControlIndex( sal_Int32& _rnIndex, const Point& _rPoint )= 0;
83 virtual sal_Int32 GetRowCount() const= 0;
84 virtual sal_Int32 GetColumnCount() const= 0;
85 virtual bool ConvertPointToCellAddress( sal_Int32& _rnRow, sal_Int32& _rnColPos, const Point& _rPoint )= 0;
86 virtual tools::Rectangle calcHeaderRect( bool _bIsColumnBar ) = 0;
87 virtual tools::Rectangle calcHeaderCellRect( bool _bColHeader, sal_Int32 _nPos ) = 0;
88 virtual tools::Rectangle calcTableRect() = 0;
89 virtual tools::Rectangle calcCellRect( sal_Int32 _nRowPos, sal_Int32 _nColPos ) = 0;
90 virtual tools::Rectangle GetFieldCharacterBounds(sal_Int32 _nRow,sal_Int32 _nColumnPos,sal_Int32 nIndex)= 0;
91 virtual sal_Int32 GetFieldIndexAtPoint(sal_Int32 _nRow,sal_Int32 _nColumnPos,const Point& _rPoint)= 0;
92 virtual void FillAccessibleStateSetForCell( sal_Int64& _rStateSet, sal_Int32 _nRow, sal_uInt16 _nColumnPos ) const= 0;
93 virtual OUString GetRowName(sal_Int32 _nIndex) const = 0;
94 virtual OUString GetColumnName( sal_Int32 _nIndex ) const = 0;
95 virtual OUString GetAccessibleCellText(sal_Int32 _nRowPos, sal_Int32 _nColPos) const = 0;
97 virtual sal_Int32 GetSelectedRowCount() const = 0;
98 virtual sal_Int32 GetSelectedRowIndex( sal_Int32 const i_selectionIndex ) const = 0;
99 virtual bool IsRowSelected( sal_Int32 const i_rowIndex ) const = 0;
100 virtual void SelectRow( sal_Int32 const i_rowIndex, bool const i_select ) = 0;
101 virtual void SelectAllRows( bool const i_select ) = 0;
103 protected:
104 ~IAccessibleTable() {}
108 /** interface for an implementation of a table control's Accessible component
110 class IAccessibleTableControl
112 public:
113 /** returns the XAccessible object itself
115 The reference returned here can be used to control the life time of the
116 IAccessibleTableImplementation object.
118 The returned reference is guaranteed to not be <NULL/>.
120 virtual css::uno::Reference< css::accessibility::XAccessible >
121 getMyself() = 0;
123 /** disposes the accessible implementation, so that it becomes defunc
125 virtual void DisposeAccessImpl() = 0;
127 /** checks whether the accessible implementation, and its context, are still alive
128 @return <TRUE/>, if the object is not disposed or disposing.
130 virtual bool isAlive() const = 0;
132 /** commits the event at all listeners of the cell
133 @param nEventId
134 the event id
135 @param rNewValue
136 the new value
137 @param rOldValue
138 the old value
140 virtual void commitCellEvent(
141 sal_Int16 nEventId,
142 const css::uno::Any& rNewValue,
143 const css::uno::Any& rOldValue
144 ) = 0;
145 /** commits the event at all listeners of the table
146 @param nEventId
147 the event id
148 @param rNewValue
149 the new value
150 @param rOldValue
151 the old value
153 virtual void commitTableEvent(
154 sal_Int16 nEventId,
155 const css::uno::Any& rNewValue,
156 const css::uno::Any& rOldValue
157 ) = 0;
159 ///** Commits an event to all listeners. */
160 virtual void commitEvent(
161 sal_Int16 nEventId,
162 const css::uno::Any& rNewValue
163 ) = 0;
165 protected:
166 ~IAccessibleTableControl() {}
169 } // namespace vcl::table
171 #endif // INCLUDED_VCL_ACCESSIBLETABLE_HXX
173 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */