1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 #ifndef _SVX_ACCESSIBILITY_ACCESSIBLE_SHAPE_TREE_INFO_HXX
25 #define _SVX_ACCESSIBILITY_ACCESSIBLE_SHAPE_TREE_INFO_HXX
26 
27 #include <com/sun/star/accessibility/XAccessibleComponent.hpp>
28 #include <com/sun/star/beans/XPropertySet.hpp>
29 #include <com/sun/star/document/XEventBroadcaster.hpp>
30 #include <com/sun/star/frame/XController.hpp>
31 #include <svx/IAccessibleViewForwarder.hxx>
32 #include "svx/svxdllapi.h"
33 
34 class SdrView;
35 class Window;
36 
37 namespace accessibility {
38 
39 /** This class bundles all information that is passed down the tree of
40     accessible shapes so that each shape has access to that info.
41 
42     There are basically four members that can be set and queried:
43     <ul>
44     <li>The model broadcaster is used for getting notified about shape
45     changes.  Using this broadcaster makes in unnecessary to register at
46     each shape separately.</li>
47     <li>The view forwarder is responsible for transformation between
48     coordinate systems and for providing the visible area both with respect
49     to a specific window.</li>
50     <li>The SdrView is used for creating accessible edit engines.</li>
51     <li>The Window is used for creating accessible edit engines.</li>
52     </ul>
53 */
54 class SVX_DLLPUBLIC AccessibleShapeTreeInfo
55 {
56 public:
57     /** Deprecated.  Don't use this constructor any more.
58     */
59     AccessibleShapeTreeInfo (
60         const ::com::sun::star::uno::Reference<
61             ::com::sun::star::accessibility::XAccessibleComponent>& rxDocumentWindow,
62         const ::com::sun::star::uno::Reference<
63             ::com::sun::star::document::XEventBroadcaster>& rxBroadcaster);
64 
65     /** Use this constructor to create an empty object that is filled later
66         with more meaningful data.
67     */
68     AccessibleShapeTreeInfo (void);
69 
70     /** Create a copy of the given shape info.
71         @param rInfo
72             The shape tree info object to copy.
73     */
74     AccessibleShapeTreeInfo (const AccessibleShapeTreeInfo& rInfo);
75 
76     ~AccessibleShapeTreeInfo (void);
77 
78     AccessibleShapeTreeInfo& operator= (const AccessibleShapeTreeInfo& rInfo);
79 
80     /** Deprecated.  Don't use this method.
81     */
82     void SetDocumentWindow (const ::com::sun::star::uno::Reference<
83         ::com::sun::star::accessibility::XAccessibleComponent>& rxViewWindow);
84     /** Deprecated.  Don't use this method.
85     */
86     ::com::sun::star::uno::Reference<
87         ::com::sun::star::accessibility::XAccessibleComponent>
88         GetDocumentWindow (void) const;
89 
90     /** Deprecated.   Use the correctly named SetModelBroadcaster method
91         instead.
92     */
93     void SetControllerBroadcaster (const ::com::sun::star::uno::Reference<
94         ::com::sun::star::document::XEventBroadcaster>& rxControllerBroadcaster);
95     /** Deprecated.   Use the correctly named GetModelBroadcaster method
96         instead.
97     */
98     ::com::sun::star::uno::Reference<
99         ::com::sun::star::document::XEventBroadcaster>
100         GetControllerBroadcaster (void) const;
101 
102     /** Set a new broadcaster that sends events indicating shape changes.
103         The broadcaster usually is or belongs to a document model.
104         @param rxModelBroadcaster
105             The new broadcaster.  It replaces the current one.  An empty
106             reference may be passed to unset the broadcaster
107     */
108     void SetModelBroadcaster (const ::com::sun::star::uno::Reference<
109         ::com::sun::star::document::XEventBroadcaster>& rxModelBroadcaster);
110 
111     /** Return the current model broadcaster.
112         @return
113             The returned reference may be empty if the broadcaster has not
114             been set or has been set to an empty reference.
115     */
116     ::com::sun::star::uno::Reference<
117         ::com::sun::star::document::XEventBroadcaster>
118         GetModelBroadcaster (void) const;
119 
120     /** Set the view that will be used to construct SvxTextEditSources which
121         in turn are used to create accessible edit engines.
122         @param pView
123             The new SdrView that replaces the current one.  A NULL pointer
124             may be passed to unset the view.
125     */
126     void SetSdrView (SdrView* pView);
127 
128     /** Return the current SdrView.
129         @return
130             The returned value may be NULL.
131     */
132     SdrView* GetSdrView (void) const;
133 
134     /** Set a new controller.  This will usually but not necessarily
135         correspond to the SdrView.
136         @param rxController
137             The new controller that replaces the current one.  An empty
138             reference may be passed to unset the controller.
139     */
140     void SetController (const ::com::sun::star::uno::Reference<
141         ::com::sun::star::frame::XController>& rxController);
142 
143     /** Return the currently set controller.
144         @return
145             The reference to the currently set controller may be empty.
146     */
147     ::com::sun::star::uno::Reference<
148         ::com::sun::star::frame::XController>
149         GetController (void) const;
150 
151     /** Set the window that is used to construct SvxTextEditSources which in
152         turn is used to create accessible edit engines.
153     */
154     void SetWindow (Window* pWindow);
155 
156     /** Return the current Window.
157         @return
158             The returned value may be NULL.
159     */
160     Window* GetWindow (void) const;
161 
162     /** The view forwarder allows the transformation between internal
163         and pixel coordinates and can be asked for the visible area.
164         @param pViewForwarder
165             This view forwarder replaces the current one.
166     */
167     void SetViewForwarder (const IAccessibleViewForwarder* pViewForwarder);
168 
169     /** Return the current view forwarder.
170         @return
171             The returned pointer may be NULL.
172     */
173     const IAccessibleViewForwarder* GetViewForwarder (void) const;
174 
175 private:
176     /** Deprecated.
177     */
178     ::com::sun::star::uno::Reference<
179         ::com::sun::star::accessibility::XAccessibleComponent> mxDocumentWindow;
180 
181     /** this broadcaster sends events indicating shape changes.
182         The broadcaster usually is or belongs to a document model.
183 
184         This once was named mxControllerBroadcaster.
185     */
186     ::com::sun::star::uno::Reference<
187         ::com::sun::star::document::XEventBroadcaster> mxModelBroadcaster;
188 
189     /** This view is necessary to construct an SvxTextEditSource which in
190         turn is used to create an accessible edit engine.
191     */
192     SdrView* mpView;
193 
194     /** The controller is used e.g. for obtaining the selected shapes.
195     */
196     ::com::sun::star::uno::Reference<
197         ::com::sun::star::frame::XController> mxController;
198 
199     /** This window is necessary to construct an SvxTextEditSource which in
200         turn is used to create an accessible edit engine.
201     */
202     Window* mpWindow;
203 
204     /** The view forwarder allows the transformation between internal
205         and pixel coordinates and can be asked for the visible area.
206     */
207     const IAccessibleViewForwarder* mpViewForwarder;
208 };
209 
210 } // end of namespace accessibility
211 
212 #endif
213