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 INCLUDED_EDITENG_UNOEDSRC_HXX
21 : #define INCLUDED_EDITENG_UNOEDSRC_HXX
22 :
23 : #include <com/sun/star/accessibility/TextSegment.hpp>
24 :
25 : #include <i18nlangtag/lang.h>
26 : #include <rtl/ustring.hxx>
27 : #include <tools/gen.hxx>
28 : #include <vcl/mapmod.hxx>
29 : #include <tools/color.hxx>
30 : #include <svl/poolitem.hxx>
31 : #include <svl/itempool.hxx>
32 : #include <editeng/editengdllapi.h>
33 : #include <editeng/editeng.hxx>
34 :
35 : #include <list>
36 :
37 : struct ESelection;
38 : struct EFieldInfo;
39 : struct EBulletInfo;
40 : class OutputDevice;
41 : class SfxItemSet;
42 : class SvxTextForwarder;
43 : class SvxViewForwarder;
44 : class SvxEditViewForwarder;
45 : class SvxFieldItem;
46 : class SfxBroadcaster;
47 : class SvxUnoTextRangeBase;
48 :
49 : typedef std::list< SvxUnoTextRangeBase* > SvxUnoTextRangeBaseList;
50 :
51 : /** Wrapper class for unified EditEngine/Outliner access
52 :
53 : This class wraps a textual object, which might or might not
54 : contain an EditEngine/Outliner. Is used e.g. for filling an
55 : EditEngine with the content of a cell, note page or page template.
56 : */
57 134793 : class EDITENG_DLLPUBLIC SvxEditSource
58 : {
59 : public:
60 : virtual ~SvxEditSource();
61 :
62 : /// Returns a new reference to the same object. This is a shallow copy
63 : virtual SvxEditSource* Clone() const = 0;
64 :
65 : /** Query the text forwarder
66 :
67 : @return the text forwarder, or NULL if the underlying object is dead
68 : */
69 : virtual SvxTextForwarder* GetTextForwarder() = 0;
70 :
71 : /** Query the view forwarder
72 :
73 : @return the view forwarder, or NULL if the underlying object
74 : is dead, or if no view is available
75 :
76 : @derive default implementation provided, overriding is optional
77 : */
78 : virtual SvxViewForwarder* GetViewForwarder();
79 :
80 : /** Query the edit view forwarder
81 :
82 : @param bCreate
83 : Determines whether an EditView should be created, if there is
84 : none active. If set to sal_True, and the underlying object is
85 : not in EditMode, the text forwarder changes and the object is
86 : set to EditMode.
87 :
88 : @return the edit view forwarder, or NULL if the underlying
89 : object is dead, or if no view is available (if bCreate is
90 : sal_False, NULL is also returned if the object is not in
91 : EditMode)
92 :
93 : @derive default implementation provided, overriding is optional
94 :
95 : @attention If this method is called with bCreate equal to
96 : sal_True, all previously returned text forwarder can become
97 : invalid
98 : */
99 : virtual SvxEditViewForwarder* GetEditViewForwarder( bool bCreate = false );
100 :
101 : /// Write back data to model
102 : virtual void UpdateData() = 0;
103 :
104 : /** Returns broadcaster the underlying edit engine's events are sent from
105 :
106 : @derive default implementation provided, overriding is optional
107 : */
108 : virtual SfxBroadcaster& GetBroadcaster() const;
109 :
110 : /** adds the given SvxUnoTextRangeBase to the text object
111 : capsulated by this SvxEditSource. This allows the text
112 : object to inform all created text ranges about changes
113 : and also allows to re use already created instances.
114 : All SvxUnoTextRangeBase must remove itself with
115 : removeRange() before theire deleted. */
116 : virtual void addRange( SvxUnoTextRangeBase* pNewRange );
117 :
118 : /** removes the given SvxUnoTextRangeBase from the text
119 : object capsulated by this SvxEditSource. This text range
120 : will not be informed any longer of changes on the underlying
121 : text and will also not re used anymore. */
122 : virtual void removeRange( SvxUnoTextRangeBase* pOldRange );
123 :
124 : /** returns a const list of all text ranges that are registered
125 : for the underlying text object. */
126 : virtual const SvxUnoTextRangeBaseList& getRanges() const;
127 : };
128 :
129 :
130 : /** Contains an EditEngine or an Outliner and unifies access to them.
131 :
132 : The EditEngine-UNO objects use this class only. To reflect changes
133 : not only in the EditEngine, but also in the model data, call
134 : SvxEditSource::UpdateData(). This copies back the data to the model's
135 : EditTextObject/OutlinerParaObject.
136 : */
137 25483 : class EDITENG_DLLPUBLIC SvxTextForwarder
138 : {
139 : public:
140 : virtual ~SvxTextForwarder();
141 :
142 : virtual sal_Int32 GetParagraphCount() const = 0;
143 : virtual sal_Int32 GetTextLen( sal_Int32 nParagraph ) const = 0;
144 : virtual OUString GetText( const ESelection& rSel ) const = 0;
145 : virtual SfxItemSet GetAttribs( const ESelection& rSel, EditEngineAttribs nOnlyHardAttrib = EditEngineAttribs_All ) const = 0;
146 : virtual SfxItemSet GetParaAttribs( sal_Int32 nPara ) const = 0;
147 : virtual void SetParaAttribs( sal_Int32 nPara, const SfxItemSet& rSet ) = 0;
148 : virtual void RemoveAttribs( const ESelection& rSelection, bool bRemoveParaAttribs, sal_uInt16 nWhich ) = 0;
149 : virtual void GetPortions( sal_Int32 nPara, std::vector<sal_Int32>& rList ) const = 0;
150 :
151 : virtual SfxItemState GetItemState( const ESelection& rSel, sal_uInt16 nWhich ) const = 0;
152 : virtual SfxItemState GetItemState( sal_Int32 nPara, sal_uInt16 nWhich ) const = 0;
153 :
154 : virtual void QuickInsertText( const OUString& rText, const ESelection& rSel ) = 0;
155 : virtual void QuickInsertField( const SvxFieldItem& rFld, const ESelection& rSel ) = 0;
156 : virtual void QuickSetAttribs( const SfxItemSet& rSet, const ESelection& rSel ) = 0;
157 : virtual void QuickInsertLineBreak( const ESelection& rSel ) = 0;
158 :
159 : virtual OUString CalcFieldValue( const SvxFieldItem& rField, sal_Int32 nPara, sal_Int32 nPos, Color*& rpTxtColor, Color*& rpFldColor ) = 0;
160 : virtual void FieldClicked( const SvxFieldItem& rField, sal_Int32 nPara, sal_Int32 nPos ) = 0;
161 :
162 : virtual SfxItemPool* GetPool() const = 0;
163 :
164 : virtual const SfxItemSet* GetEmptyItemSetPtr() = 0;
165 :
166 : // implementation functions for XParagraphAppend and XTextPortionAppend
167 : virtual void AppendParagraph() = 0;
168 : virtual sal_Int32 AppendTextPortion( sal_Int32 nPara, const OUString &rText, const SfxItemSet &rSet ) = 0;
169 :
170 : // XTextCopy
171 : virtual void CopyText(const SvxTextForwarder& rSource) = 0;
172 :
173 : /** Query state of forwarder
174 :
175 : @return false, if no longer valid
176 : */
177 : virtual bool IsValid() const = 0;
178 :
179 : /** Query language of character at given position on the underlying edit engine
180 :
181 : @param nPara[0 .. n-1]
182 : Index of paragraph to query language in
183 :
184 : @param nIndex[0 .. m-1]
185 : Index of character to query language of
186 : */
187 : virtual LanguageType GetLanguage( sal_Int32 nPara, sal_Int32 nIndex ) const = 0;
188 :
189 : /** Query number of fields in the underlying edit engine
190 :
191 : @param nPara[0 .. n-1]
192 : Index of paragraph to query field number in
193 : */
194 : virtual sal_Int32 GetFieldCount( sal_Int32 nPara ) const = 0;
195 :
196 : /** Query information for given field number in the underlying edit engine
197 :
198 : @param nPara[0 .. n-1]
199 : Index of paragraph to query field info in
200 :
201 : @param nField[0 .. m-1]
202 : Index of field to query information of
203 : */
204 : virtual EFieldInfo GetFieldInfo( sal_Int32 nPara, sal_uInt16 nField ) const = 0;
205 :
206 : /** Query information regarding bullets for given paragraph on the underlying edit engine
207 :
208 : @param nPara[0 .. n-1]
209 : Index of paragraph to query bullet info on
210 : */
211 : virtual EBulletInfo GetBulletInfo( sal_Int32 nPara ) const = 0;
212 :
213 0 : virtual OUString GetNumStr(sal_uInt16) const { return OUString(); }
214 0 : virtual void SetUpdateModeForAcc(bool) {}
215 0 : virtual bool GetUpdateModeForAcc() const { return true; }
216 :
217 : /** Query the bounding rectangle of the given character
218 :
219 : @param nPara[0 .. n]
220 : Index of paragraph to query the bounds in. <p>The virtual
221 : character after the last character of the represented text,
222 : i.e. the one at position n is a special case. Because it does
223 : not represent an existing character its bounding box is
224 : defined in relation to preceding characters. It should be
225 : roughly equivalent to the bounding box of some character when
226 : inserted at the end of the text. Its height typically being
227 : the maximal height of all the characters in the text or the
228 : height of the preceding character, its width being at least
229 : one pixel so that the bounding box is not degenerate.<br>
230 :
231 : @param nIndex[0 .. m-1]
232 : Index of character to query the bounds of
233 :
234 : @return rectangle in logical coordinates, relative to upper
235 : left corner of text. The coordinates returned here are to be
236 : interpreted in the map mode given by GetMapMode().
237 : */
238 : virtual Rectangle GetCharBounds( sal_Int32 nPara, sal_Int32 nIndex ) const = 0;
239 :
240 : /** Query the bounding rectangle of the given paragraph
241 :
242 : @param nPara[0 .. n-1]
243 : Index of paragraph to query the bounds of
244 :
245 : @return rectangle in logical coordinates, relative to upper
246 : left corner of text. The coordinates returned here are to be
247 : interpreted in the map mode given by GetMapMode().
248 : */
249 : virtual Rectangle GetParaBounds( sal_Int32 nPara ) const = 0;
250 :
251 : /** Query the map mode of the underlying EditEngine/Outliner
252 :
253 : @return the map mode used on the EditEngine/Outliner. The
254 : values returned by GetParaBounds() and GetCharBounds() are to
255 : be interpreted in this map mode, the point given to
256 : GetIndexAtPoint() is interpreted in this map mode.
257 : */
258 : virtual MapMode GetMapMode() const = 0;
259 :
260 : /** Query the reference output device of the underlying EditEngine/Outliner
261 :
262 : @return the OutputDevice used from the EditEngine/Outliner to
263 : format the text. It should be used when performing e.g. font
264 : calculations, since this is usually a printer with fonts and
265 : resolution different from the screen.
266 : */
267 : virtual OutputDevice* GetRefDevice() const = 0;
268 :
269 : /** Query paragraph and character index of the character at the
270 : given point. Returns sal_True on success, sal_False otherwise
271 :
272 : @param rPoint
273 : Point to query text position of. Is interpreted in logical
274 : coordinates, relativ to the upper left corner of the text, and
275 : in the map mode given by GetMapMode()
276 :
277 : @param rPara[0 .. n-1]
278 : Index of paragraph the point is within
279 :
280 : @param rIndex[0 .. m-1]
281 : Index of character the point is over
282 :
283 : @return true, if the point is over any text and both rPara and rIndex are valid
284 :
285 : */
286 : virtual bool GetIndexAtPoint( const Point& rPoint, sal_Int32& rPara, sal_Int32& rIndex ) const = 0;
287 :
288 : /** Get the start and the end index of the word at the given index
289 :
290 : An index value on a word leads from the first character of
291 : that word up to and including the last space before the next
292 : word. The index values returned do not contain any leading or
293 : trailing white-space. If the input indices are invalid,
294 : sal_False is returned.
295 :
296 : @param nPara[0 .. n-1]
297 : Index of paragraph to start the search in
298 :
299 : @param nIndex[0 .. m-1]
300 : Index of character to query the search on
301 :
302 : @param rStart
303 : Start index (in the same paragraph)
304 :
305 : @param rEnd
306 : End index (in the same paragraph), this point to the last
307 : character still contained in the query
308 :
309 : @return true, if the result is non-empty
310 : */
311 : virtual bool GetWordIndices( sal_Int32 nPara, sal_Int32 nIndex, sal_Int32& rStart, sal_Int32& rEnd ) const = 0;
312 :
313 : /** Query range of similar attributes
314 :
315 : Please note that the range returned is half-open: [nStartIndex,nEndIndex)
316 :
317 : @param nStartIndex
318 : Herein, the start index of the range of similar attributes is returned
319 :
320 : @param nEndIndex
321 : Herein, the end index (exclusive) of the range of similar attributes is returned
322 :
323 : @param nIndex
324 : The character index from which the range of similar attributed characters is requested
325 :
326 : @return true, if the range has been successfully determined
327 : */
328 : virtual bool GetAttributeRun( sal_Int32& nStartIndex, sal_Int32& nEndIndex, sal_Int32 nPara, sal_Int32 nIndex, bool bInCell = false ) const = 0;
329 :
330 : /** Query number of lines in the formatted paragraph
331 :
332 : @param nPara[0 .. n-1]
333 : Index of paragraph to query number of lines in
334 :
335 : @return number of lines in given paragraph
336 :
337 : */
338 : virtual sal_Int32 GetLineCount( sal_Int32 nPara ) const = 0;
339 :
340 : /** Query line length
341 :
342 : @param nPara[0 .. n-1]
343 : Index of paragraph to query line length in
344 :
345 : @param nLine[0 .. m-1]
346 : Index of line in paragraph to query line length of
347 :
348 : */
349 : virtual sal_Int32 GetLineLen( sal_Int32 nPara, sal_Int32 nLine ) const = 0;
350 :
351 : /** Query bounds of line in paragraph
352 :
353 : @param rStart [output param; 0 .. text_len]
354 : The index in the paragraph text that belongs to the chara at the start of the line
355 :
356 : @param rEnd [output param; 0 .. text_len]
357 : The index in the paragraph text that follows the last chara in the line
358 :
359 : @param nParagraph[0 .. n-1]
360 : Index of paragraph to query line length in
361 :
362 : @param nLine[0 .. m-1]
363 : Index of line in paragraph to query line length of
364 :
365 : */
366 : virtual void GetLineBoundaries( /*out*/sal_Int32 &rStart, /*out*/sal_Int32 &rEnd, sal_Int32 nParagraph, sal_Int32 nLine ) const = 0;
367 :
368 : /** Query the line number for a index in the paragraphs text
369 :
370 : @param nPara[0 .. n-1]
371 : Index of paragraph to query line length in
372 :
373 : @param nIndex[0 .. m-1]
374 : Index of of the chara in the paragraph text
375 :
376 : @returns [0 .. k-1]
377 : The line number of the chara in the paragraph
378 : */
379 : virtual sal_Int32 GetLineNumberAtIndex( sal_Int32 nPara, sal_Int32 nIndex ) const = 0;
380 :
381 : /** Delete given text range and reformat text
382 :
383 : @param rSelection
384 : The text range to be deleted
385 :
386 : @return true if text has been successfully deleted
387 : */
388 : virtual bool Delete( const ESelection& rSelection ) = 0;
389 :
390 : /** Insert/Replace given text in given range and reformat text
391 :
392 : @param rText
393 : Text to insert/replace
394 :
395 : @param rSel
396 : Selection where text should be replaced. The empty selection inserts
397 :
398 : @return true if text has been successfully inserted
399 : */
400 : virtual bool InsertText( const OUString& rText, const ESelection& rSel ) = 0;
401 :
402 : /** Updates the formatting
403 :
404 : @see EditEngine::QuickFormatDoc() for details
405 :
406 : @return true if text have been successfully reformatted
407 : */
408 : virtual bool QuickFormatDoc( bool bFull = false ) = 0;
409 :
410 : /** Get the outline depth of given paragraph
411 :
412 : @param nPara
413 : Index of the paragraph to query the depth of
414 :
415 : @return the outline level of the given paragraph. The range is
416 : [0,n), where n is the maximal outline level.
417 : */
418 : virtual sal_Int16 GetDepth( sal_Int32 nPara ) const = 0;
419 :
420 : /** Set the outline depth of given paragraph
421 :
422 : @param nPara
423 : Index of the paragraph to set the depth of
424 :
425 : @param nNewDepth
426 : The depth to set on the given paragraph. The range is
427 : [0,n), where n is the maximal outline level.
428 :
429 : @return true, if depth could be successfully set. Reasons for
430 : failure are e.g. the text does not support outline level
431 : (EditEngine), or the depth range is exceeded.
432 : */
433 : virtual bool SetDepth( sal_Int32 nPara, sal_Int16 nNewDepth ) = 0;
434 :
435 : virtual sal_Int32 GetNumberingStartValue( sal_Int32 nPara );
436 : virtual void SetNumberingStartValue( sal_Int32 nPara, sal_Int32 nNumberingStartValue );
437 :
438 : virtual bool IsParaIsNumberingRestart( sal_Int32 nPara );
439 : virtual void SetParaIsNumberingRestart( sal_Int32 nPara, bool bParaIsNumberingRestart );
440 : };
441 :
442 : /** Encapsulates the document view for the purpose of unified
443 : EditEngine/Outliner access.
444 :
445 : This one has to be different from the SvxEditViewForwarder, since
446 : the latter is only valid in edit mode.
447 : */
448 109299 : class EDITENG_DLLPUBLIC SvxViewForwarder
449 : {
450 : public:
451 : virtual ~SvxViewForwarder();
452 :
453 : /** Query state of forwarder
454 :
455 : @return sal_False, if no longer valid
456 : */
457 : virtual bool IsValid() const = 0;
458 :
459 : /** Query visible area of the view containing the text
460 :
461 : @return the visible rectangle of the text, i.e. the part of
462 : the EditEngine or Outliner that is currently on screen. The
463 : values are already in screen coordinates (pixel), and have to
464 : be relative to the EditEngine/Outliner's upper left corner.
465 : */
466 : virtual Rectangle GetVisArea() const = 0;
467 :
468 : /** Convert from logical, EditEngine-relative coordinates to screen coordinates
469 :
470 : @param rPoint
471 : Point in logical, EditEngine-relative coordinates.
472 :
473 : @param rMapMode
474 : The map mode to interpret the coordinates in.
475 :
476 : @return the point in screen coordinates
477 : */
478 : virtual Point LogicToPixel( const Point& rPoint, const MapMode& rMapMode ) const = 0;
479 :
480 : /** Convert from screen to logical, EditEngine-relative coordinates
481 :
482 : @param rPoint
483 : Point in screen coordinates
484 :
485 : @param rMapMode
486 : The map mode to interpret the coordinates in.
487 :
488 : @return the point in logical coordinates.
489 : */
490 : virtual Point PixelToLogic( const Point& rPoint, const MapMode& rMapMode ) const = 0;
491 :
492 : };
493 :
494 :
495 : /** Encapsulates EditView and OutlinerView for the purpose of unified
496 : EditEngine/Outliner access
497 : */
498 144 : class SvxEditViewForwarder : public SvxViewForwarder
499 : {
500 : public:
501 :
502 : /** Query current selection.
503 :
504 : @param rSelection
505 : Contains the current selection after method call
506 :
507 : @return false, if there is no view or no selection (the empty selection _is_ a selection)
508 :
509 : */
510 : virtual bool GetSelection( ESelection& rSelection ) const = 0;
511 :
512 : /** Set selection in view.
513 :
514 : @param rSelection
515 : The selection to set
516 :
517 : @return false, if there is no view or selection is invalid
518 : */
519 : virtual bool SetSelection( const ESelection& rSelection ) = 0;
520 :
521 : /** Copy current selection to clipboard.
522 :
523 : @return false if no selection or no view (the empty selection _is_ a selection)
524 : */
525 : virtual bool Copy() = 0;
526 :
527 : /** Cut current selection to clipboard.
528 :
529 : @eturn balse if no selection or no view (the empty selection _is_ a selection)
530 : */
531 : virtual bool Cut() = 0;
532 :
533 : /** Paste clipboard into current selection.
534 :
535 : @return false if no view or no selection (the empty selection _is_ a selection)
536 : */
537 : virtual bool Paste() = 0;
538 :
539 0 : virtual bool IsWrongSpelledWordAtPos( sal_Int32, sal_Int32 ) { return false; };
540 0 : virtual bool IsShapeParaFocusable( ) { return true; };
541 0 : virtual bool BreakParaWrongList(sal_Int32, sal_Int32&, sal_Int32&, sal_Int32){ return false; };
542 : };
543 :
544 : #endif
545 :
546 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|