xref: /aoo41x/main/vcl/inc/vcl/pdfextoutdevdata.hxx (revision cdf0e10c)
1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 #ifndef _VCL_PDFEXTOUTDEVDATA_HXX
29 #define _VCL_PDFEXTOUTDEVDATA_HXX
30 
31 #include <vcl/dllapi.h>
32 
33 #include <vcl/pdfwriter.hxx>
34 #include <vcl/extoutdevdata.hxx>
35 #include <vcl/gdimtf.hxx>
36 #include <vcl/mapmod.hxx>
37 #include <tools/rtti.hxx>
38 #include <vector>
39 #include <deque>
40 
41 class Graphic;
42 
43 namespace vcl {	class PDFWriter; }
44 
45 namespace vcl
46 {
47 
48 /*
49 	A PDFExtOutDevBookmarkEntry is being created by the EditEngine if
50 	a bookmark URL has been parsed. The Application is requested to take
51 	care of each bookmark entry by emptying out the bookmark vector.
52 */
53 struct PDFExtOutDevBookmarkEntry
54 {
55     /** ID of the link pointing to the bookmark, or -1 if the entry denotes a destination instead of a link.
56     */
57 	sal_Int32		nLinkId;
58 
59     /** ID of the named destination denoted by the bookmark, or -1 if the entry denotes a link instead of a named destination.
60     */
61     sal_Int32       nDestId;
62 
63     /** link target name, respectively destination name
64     */
65 	rtl::OUString	aBookmark;
66 
67     PDFExtOutDevBookmarkEntry()
68         :nLinkId( -1 )
69         ,nDestId( -1 )
70         ,aBookmark()
71     {
72     }
73 };
74 
75 /*
76  Class that is being set at the OutputDevice allowing the
77  application to send enhanced PDF commands like CreateLink
78 */
79 struct PageSyncData;
80 struct GlobalSyncData;
81 class VCL_DLLPUBLIC PDFExtOutDevData : public ExtOutDevData
82 {
83 
84 	const OutputDevice& mrOutDev;
85 
86     sal_Bool                        mbTaggedPDF;
87 	sal_Bool				    	mbExportNotes;
88 	sal_Bool					    mbTransitionEffects;
89 	sal_Bool					    mbUseLosslessCompression;
90 	sal_Bool					    mbReduceImageResolution;
91     sal_Bool                        mbExportFormFields;
92     sal_Bool                        mbExportBookmarks;
93     sal_Bool                        mbExportNDests; //i56629
94     sal_Int32                       mnFormsFormat;
95 	sal_Int32					    mnPage;
96     com::sun::star::lang::Locale    maDocLocale;
97 
98 	PageSyncData*				mpPageSyncData;
99 	GlobalSyncData*				mpGlobalSyncData;
100 
101 	std::vector< PDFExtOutDevBookmarkEntry > maBookmarks;
102 
103 public :
104 
105 	TYPEINFO();
106 	PDFExtOutDevData( const OutputDevice& rOutDev );
107 	virtual ~PDFExtOutDevData();
108 
109 	sal_Bool PlaySyncPageAct( PDFWriter& rWriter, sal_uInt32& rCurGDIMtfAction );
110 	void ResetSyncData();
111 
112 	void PlayGlobalActions( PDFWriter& rWriter );
113 
114 
115 
116 	sal_Bool	GetIsExportNotes() const;
117 	void		SetIsExportNotes( const sal_Bool bExportNotes );
118 
119 	sal_Bool	GetIsExportTaggedPDF() const;
120 	void		SetIsExportTaggedPDF( const sal_Bool bTaggedPDF );
121 
122 	sal_Bool	GetIsExportTransitionEffects() const;
123 	void		SetIsExportTransitionEffects( const sal_Bool bTransitionalEffects );
124 
125     sal_Bool    GetIsExportFormFields() const;
126     void        SetIsExportFormFields( const sal_Bool bExportFormFields );
127 
128 	sal_Int32	GetFormsFormat() const;
129 	void		SetFormsFormat( const sal_Int32 nFormsFormat );
130 
131     sal_Bool    GetIsExportBookmarks() const;
132     void        SetIsExportBookmarks( const sal_Bool bExportBookmarks );
133 
134     sal_Bool    GetIsExportNamedDestinations() const; //i56629
135     void        SetIsExportNamedDestinations( const sal_Bool bExportNDests ); //i56629
136 
137 	// PageNumber, Compression is being set by the PDFExport
138 	sal_Int32	GetCurrentPageNumber() const;
139 	void		SetCurrentPageNumber( const sal_Int32 nPage );
140 
141 	sal_Bool	GetIsLosslessCompression() const;
142 	void		SetIsLosslessCompression( const sal_Bool bLosslessCompression );
143 
144 	sal_Bool	GetIsReduceImageResolution() const;
145 	void		SetIsReduceImageResolution( const sal_Bool bReduceImageResolution );
146 
147     const com::sun::star::lang::Locale& GetDocumentLocale() const;
148     void        SetDocumentLocale( const com::sun::star::lang::Locale& rLoc );
149 
150 	std::vector< PDFExtOutDevBookmarkEntry >& GetBookmarks();
151 
152     /** Start a new group of render output
153 
154     	Use this method to group render output.
155      */
156     void		BeginGroup();
157 
158     /** End render output
159 
160     	This method ends grouped render output without
161         further actions.
162      */
163     void		EndGroup();
164 
165     /** End render output
166 
167     	This method ends grouped render output, that can be
168         represented by a GfxLink. This is typically used for
169         external graphic files, such as JPEGs, EPS files etc.
170         The BeginGroup/EndGroup calls must exactly enclose the
171         relevant OutputDevice calls issued to render the
172         graphic the normal way.
173 
174         @param rGraphic
175         The link to the original graphic
176 
177         @param nTransparency
178         Eight bit transparency value, with 0 denoting full opacity,
179         and 255 full transparency.
180 
181         @param rOutputRect
182         The output rectangle of the graphic.
183 
184         @param rVisibleOutputRect
185         The visible part of the output. This might be less than
186         rOutputRect, e.g. for cropped graphics.
187      */
188     void		EndGroup( const Graphic& 	rGraphic,
189                           sal_uInt8				nTransparency,
190                           const Rectangle& 	rOutputRect,
191                           const Rectangle& 	rVisibleOutputRect );
192 //--->i56629
193     /** Create a new named destination to be used in a link to this document from another PDF document
194  (see PDF spec 1.4, 8.2.1)
195 
196     @parm sDestName
197     the name this destination will be addressed with from others PDF document
198 
199     @param rRect
200     target rectangle on page to be displayed if dest is jumped to
201 
202     @param nPageNr
203     number of page the dest is on (as returned by NewPage)
204     or -1 in which case the current page is used
205 
206     @param eType
207     what dest type to use
208 
209     @returns
210     the destination id (to be used in SetLinkDest) or
211     -1 if page id does not exist
212     */
213 	sal_Int32 CreateNamedDest( const String& sDestName,  const Rectangle& rRect, sal_Int32 nPageNr = -1, PDFWriter::DestAreaType eType = PDFWriter::XYZ );
214 
215     /** registers a destination for which a destinatin ID needs to be known immediately, instead of later on setting it via
216         SetLinkDest.
217 
218         This is used in contexts where a destination is referenced by means other than a link.
219 
220         Later in the export process, a call to DescribeRegisteredDest must be made, providing the information about
221         the destination.
222 
223         @return
224             the unique Id of the destination
225     */
226     sal_Int32   RegisterDest();
227 
228     /** provides detailed information about a destination range which previously has been registered using RegisterDest.
229     */
230     void        DescribeRegisteredDest( sal_Int32 nDestId, const Rectangle& rRect, sal_Int32 nPageNr = -1, PDFWriter::DestAreaType eType = PDFWriter::XYZ );
231 
232 //<---i56629
233 
234     /** Create a new destination to be used in a link
235 
236     @param rRect
237     target rectangle on page to be displayed if dest is jumped to
238 
239     @param nPageNr
240     number of page the dest is on (as returned by NewPage)
241     or -1 in which case the current page is used
242 
243     @param eType
244     what dest type to use
245 
246     @returns
247     the destination id (to be used in SetLinkDest) or
248     -1 if page id does not exist
249     */
250 	sal_Int32 CreateDest( const Rectangle& rRect, sal_Int32 nPageNr = -1, PDFWriter::DestAreaType eType = PDFWriter::XYZ );
251     /** Create a new link on a page
252 
253     @param rRect
254     active rectangle of the link (that is the area that has to be
255     hit to activate the link)
256 
257     @param nPageNr
258     number of page the link is on (as returned by NewPage)
259     or -1 in which case the current page is used
260 
261     @returns
262     the link id (to be used in SetLinkDest, SetLinkURL) or
263     -1 if page id does not exist
264     */
265     sal_Int32 CreateLink( const Rectangle& rRect, sal_Int32 nPageNr = -1 );
266     /** Set the destination for a link
267         <p>will change a URL type link to a dest link if necessary</p>
268 
269         @param nLinkId
270         the link to be changed
271 
272         @param nDestId
273         the dest the link shall point to
274         @returns
275         0 for success
276         -1 in case the link id does not exist
277         -2 in case the dest id does not exist
278     */
279     sal_Int32 SetLinkDest( sal_Int32 nLinkId, sal_Int32 nDestId );
280     /** Set the URL for a link
281         <p>will change a dest type link to an URL type link if necessary</p>
282         @param nLinkId
283         the link to be changed
284 
285         @param rURL
286         the URL the link shall point to.
287         there will be no error checking or any kind of
288         conversion done to this parameter execept this:
289         it will be output as 7bit Ascii. The URL
290         will appear literally in the PDF file produced
291 
292         @returns
293         0 for success
294         -1 in case the link id does not exist
295     */
296     sal_Int32 SetLinkURL( sal_Int32 nLinkId, const rtl::OUString& rURL );
297     /** Create a new outline item
298 
299         @param nParent
300         declares the parent of the new item in the outline hierarchy.
301         An invalid value will result in a new toplevel item.
302 
303         @param rText
304         sets the title text of the item
305 
306         @param nDestId
307         declares which Dest (created with CreateDest) the outline item
308         will point to
309 
310         @returns
311         the outline item id of the new item
312     */
313     sal_Int32 CreateOutlineItem( sal_Int32 nParent = 0, const rtl::OUString& rText = rtl::OUString(), sal_Int32 nDestID = -1 );
314 
315     /** Set an outline item's parent
316 
317     @param nItem
318     specififies which item should be reparented.
319 
320     @param nNewParent
321     specifies which outline item will be the item's new parent.
322     Use 0 for reparenting to top level.
323 
324     @returns
325     -1 if the item does not exist
326     -2 if the new parent does not exist, item will be reparented to top level.
327     */
328     sal_Int32 SetOutlineItemParent( sal_Int32 nItem, sal_Int32 nNewParent );
329 
330     /** Set an outline item's title text
331 
332     @param nItem
333     specififies which item should get a new text
334 
335     @param rText
336     sets the title text of the item
337 
338     @returns
339     0 if the item exists and the text was changed
340     -1 if the item does not exist
341     */
342     sal_Int32 SetOutlineItemText( sal_Int32 nItem, const rtl::OUString& rText );
343 
344     /** Set an outline item's destination
345 
346     @param nItem
347     specififies which item should get a new dest
348 
349     @param nDestID
350     specifies the item's new destination
351 
352     @returns
353     -1 if the item does not exist
354     -2 if the new dest does not exist, dest will remain unchanged
355     */
356     sal_Int32 SetOutlineItemDest( sal_Int32 nItem, sal_Int32 nDestID );
357 
358     /** Create a new note on a page
359 
360     @param rRect
361     active rectangle of the note (that is the area that has to be
362     hit to popup the annotation)
363 
364     @param rNote
365     specifies the contents of the note
366 
367     @param nPageNr
368     number of page the note is on (as returned by NewPage)
369     or -1 in which case the current page is used
370     */
371 	void CreateNote( const Rectangle& rRect, const PDFNote& rNote, sal_Int32 nPageNr = -1 );
372 
373     /** begin a new logical structure element
374 
375     BeginStructureElement/EndStructureElement calls build the logical structure
376     of the PDF - the basis for tagged PDF. Structural elements are implemented
377     using marked content tags. Each structural element can contain sub elements
378     (e.g. a section can contain a heading and a paragraph). The structure hierarchy
379     is build automatically from the Begin/EndStructureElement calls.
380 
381     A structural element need not be contained on one page; e.g. paragraphs often
382     run from one page to the next. In this case the corresponding EndStructureElement
383     must be called while drawing the next page.
384 
385     BeginStructureElement and EndStructureElement must be called only after
386     <member scope="vcl">PDFWriter::NewPage</member> has been called and before
387     <member scope="vcl">PDFWriter::Emit</member>gets called. The current page
388     number is an implicit context parameter for Begin/EndStructureElement.
389 
390     For pagination artifacts that are not part of the logical structure
391     of the document (like header, footer or page number) the special
392     StructElement <code>NonStructElement</code> exists. To place content
393     outside of the struture tree simply call
394     <code>BeginStructureElement( NonStructElement )</code> then draw your
395     content and then call <code>EndStructureElement()</code>. Any children
396     of a <code>NonStructElement</code> will not be part of the structure as well.
397 
398     @param eType
399     denotes what kind of element to begin (e.g. a heading or paragraph)
400 
401     @param rAlias
402     the specified alias will be used as structure tag. Also an entry in the PDF's
403     role map will be created mapping alias to regular structure type.
404 
405     @returns
406     the id of the newly created structural element
407      */
408      sal_Int32 BeginStructureElement( PDFWriter::StructElement eType, const rtl::OUString& rAlias = rtl::OUString() );
409     /** end a logical structure element
410 
411     @see BeginStructureElement
412      */
413     void EndStructureElement();
414     /** set the current structure element
415 
416     <p>
417     For different purposes it may be useful to paint a structure element's
418     content discontinously. In that case an already existing structure element
419     can be appended to by using <code>SetCurrentStructureElement</code>. The
420     refenrenced structure element becomes the current structure element with
421     all consequences: all following structure elements are appended as children
422     of the current element.
423     </p>
424 
425     @param nElement
426     the id of the new current structure element
427 
428     @returns
429     <true/> if the current structure element could be set successfully
430     <false/> if the current structure element could not be changed
431     (e.g. if the passed element id is invalid)
432      */
433     bool SetCurrentStructureElement( sal_Int32 nElement );
434     /** get the current structure element id
435 
436     @returns
437     the id of the current structure element
438     */
439     sal_Int32 GetCurrentStructureElement();
440 
441     /** set a structure attribute on the current structural element
442 
443     SetStructureAttribute sets an attribute of the current structural element to a
444     new value. A consistency check is performed before actually setting the value;
445     if the check fails, the function returns <FALSE/> and the attribute remains
446     unchanged.
447 
448     @param eAttr
449     denotes what attribute to change
450 
451     @param eVal
452     the value to set the attribute to
453 
454     @returns
455     <TRUE/> if the value was valid and the change has been performed,
456     <FALSE/> if the attribute or value was invalid; attribute remains unchanged
457      */
458     bool SetStructureAttribute( PDFWriter::StructAttribute eAttr, PDFWriter::StructAttributeValue eVal );
459     /** set a structure attribute on the current structural element
460 
461     SetStructureAttributeNumerical sets an attribute of the current structural element
462     to a new numerical value. A consistency check is performed before actually setting
463     the value; if the check fails, the function returns <FALSE/> and the attribute
464     remains unchanged.
465 
466     @param eAttr
467     denotes what attribute to change
468 
469     @param nValue
470     the value to set the attribute to
471 
472     @returns
473     <TRUE/> if the value was valid and the change has been performed,
474     <FALSE/> if the attribute or value was invalid; attribute remains unchanged
475      */
476 	bool SetStructureAttributeNumerical( PDFWriter::StructAttribute eAttr, sal_Int32 nValue );
477     /** set the bounding box of a structural element
478 
479     SetStructureBoundingBox sets the BBox attribute to a new value. Since the BBox
480     attribute can only be applied to <code>Table</code>, <code>Figure</code>,
481     <code>Form</code> and <code>Formula</code> elements, a call of this function
482     for other element types will be ignored and the BBox attribute not be set.
483 
484     @param rRect
485     the new bounding box for the structural element
486      */
487     void SetStructureBoundingBox( const Rectangle& rRect );
488 
489     /** set the ActualText attribute of a structural element
490 
491     ActualText contains the Unicode text without layout artifacts that is shown by
492     a structural element. For example if a line is ended prematurely with a break in
493     a word and continued on the next line (e.g. "happen-<newline>stance") the
494     corresponding ActualText would contain the unbroken line (e.g. "happenstance").
495 
496     @param rText
497     contains the complete logical text the structural element displays.
498      */
499     void SetActualText( const String& rText );
500 
501     /** set the Alt attribute of a strutural element
502 
503     Alt is s replacement text describing the contents of a structural element. This
504     is mainly used by accessibility applications; e.g. a screen reader would read
505     the Alt replacement text for an image to a visually impaired user.
506 
507     @param rText
508     contains the replacement text for the structural element
509     */
510     void SetAlternateText( const String& rText );
511 
512     /** Sets the time in seconds a page will appear before the next
513         page is shown automatically
514 
515         @param nSeconds
516         time in seconds the current page will be shown; pass 0 for manual advancement
517 
518         @param nPageNr
519         the page number to apply the autoadvance time to; -1 denotes the current page
520     */
521     void SetAutoAdvanceTime( sal_uInt32 nSeconds, sal_Int32 nPageNr = -1 );
522 
523     /** Sets the transitional effect to be applied when the current page gets shown.
524 
525     @param eType
526     the kind of effect to be used; use Regular to disable transitional effects
527     for this page
528 
529     @param nMilliSec
530     the duration of the transitional effect in milliseconds;
531     set 0 to disable transitional effects
532 
533     @param nPageNr
534     the page number to apply the effect to; -1 denotes the current page
535     */
536 	void SetPageTransition( PDFWriter::PageTransition eType, sal_uInt32 nMilliSec, sal_Int32 nPageNr = -1 );
537 
538     /** create a new form control
539 
540     This function creates a new form control in the PDF and sets its various
541     properties. Do not pass an actual AnyWidget as <code>rControlType</code>
542     will be cast to the type described by the type member.
543 
544     @param rControlType
545     a descendant of <code>AnyWidget</code> determing the control's properties
546      */
547     void    CreateControl( const PDFWriter::AnyWidget& rControlType, sal_Int32 nPageNr = -1 );
548 };
549 
550 }
551 
552 #endif
553