/* -*- 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 .
*/
namespace com::sun::star::xml::dom { class XNode; } namespace editeng { class SvxFieldItemUpdater; } namespace vcl { class Font; } namespace com::sun::star::presentation { class XPresentation2; } class SdOutliner; class Timer; class SfxObjectShell; class SdPage; class SdAnimationInfo; class SdStyleSheetPool; class SfxMedium; class SvxSearchItem; class EditStatus; class Point; class SdTransferable; struct SpellCallbackInfo; class SdCustomShowList; class SdUndoGroup; class SdrObject; class Idle; class Outliner; class SdrOutliner; class SdrPage; class SdrTextObj; class SfxItemPool; class Size; class SdXImpressDocument;
namespace sd
{ class DrawDocShell; #ifndef SV_DECL_DRAW_DOC_SHELL_DEFINED #define SV_DECL_DRAW_DOC_SHELL_DEFINED typedef rtl::Reference<DrawDocShell> DrawDocShellRef; #endif class UndoManager; class ShapeList; class FrameView;
}
class ImpDrawPageListWatcher; class ImpMasterPageListWatcher;
/** * Type aliases for commonly used data structures
*/ typedef std::vector<OUString> PageNameList; // List of page/bookmark names typedef std::vector<OUString> SlideLayoutNameList; // List of slide layout names typedef std::map<OUString, sal_Int32> SlideLayoutMap; // Map of slide layout names to indices typedef std::map<OUString, std::shared_ptr<model::Theme>> ThemeMap; // Map of theme names to theme objects
/** * Context for style sheet transfers during page operations * * This structure contains all data required for transferring styles (graphic, cell, table) * between documents or pages. It maintains collections of styles that need to be * transferred and manages pointers to source and destination style sheet pools.
*/ struct StyleTransferContext
{ // Style collections to be transferred
StyleSheetCopyResultVector aGraphicStyles; // Graphic styles to be transferred
StyleSheetCopyResultVector aCellStyles; // Cell styles to be transferred
XStyleVector aTableStyles; // Table styles to be transferred
OUString aRenameString; // String for style renaming operations
// Layout information
SlideLayoutMap aSlideLayouts; // Layouts to be transferred
ThemeMap aThemes; // Themes to be transferred
// Style sheet pools (optional, set by the caller)
SdStyleSheetPool* pSourceStyleSheetPool; // Source style sheet pool
SdStyleSheetPool* pDestStyleSheetPool; // Destination style sheet pool
/** * Options for inserting bookmarks as pages * * This structure defines all parameters for controlling how pages/bookmarks * are inserted into documents. It covers operations like linking, replacing, * and various flags to control the behavior during page insertion.
*/ struct InsertBookmarkOptions
{ bool bLink; // Insert bookmarks as links bool bReplace; // Replace pages instead of inserting bool bNoDialogs; // No dialogs allowed bool bCopy; // Copy source document bool bMergeMasterPages; // Merge master pages bool bMergeMasterPagesOnly; // Only merge master pages bool bPreservePageNames; // Preserve page names bool bIsClipboardOperation; // Operation triggered by clipboard bool bIsDragAndDropOperation; // Operation triggered by drag and drop bool bIsSameDocumentOperation; // Operation within the same document bool bIsFileDocument; // Operation involves a file document
// Preset for document import operations static InsertBookmarkOptions ForDocumentImport(bool bMergeMasterPagesOnly = false) {
InsertBookmarkOptions options;
options.bLink = false; // No linking for document import
options.bReplace = true; // Replace pages when importing document
options.bNoDialogs = true; // No dialogs for document import
options.bCopy = true; // Always copy when importing document
options.bMergeMasterPages = true; // Always merge master pages
options.bPreservePageNames = false; // Don't preserve page names
options.bIsFileDocument = true; // This is a file document operation
options.bMergeMasterPagesOnly = bMergeMasterPagesOnly;// Only merge master pages return options;
}
};
/** * Properties of a document page, used for page insertion and scaling operations * * This structure stores the geometric properties of a page including size, margins, * orientation, and a pointer to the page object itself. Used primarily during * page insertion and scaling operations.
*/ struct PageProperties
{
Size size; // Page size dimensions
sal_Int32 left; // Left margin
sal_Int32 right; // Right margin
sal_Int32 upper; // Upper (top) margin
sal_Int32 lower; // Lower (bottom) margin
Orientation orientation; // Page orientation (portrait/landscape)
SdPage* pPage; // Pointer to the page object
};
/** * Document page count information * * Tracks counts of different page types during document operations, * particularly useful during page insertion and master page handling.
*/ struct DocumentPageCounts
{
sal_uInt16 nDestPageCount; // Count of standard pages in destination document
sal_uInt16 nSourcePageCount; // Count of standard pages in source document
sal_uInt16 nMasterPageCount; // Count of master pages in destination document
sal_uInt16 nNewMPageCount; // Count of new master pages after processing
// Check if all counts are valid (non-zero) bool areValid() const { return !(nDestPageCount == 0 || nSourcePageCount == 0 || nMasterPageCount == 0);
}
};
/** * Parameters related to page insertion operations * * Collects all parameters needed for page insertion operations including * insertion position, bookmark name, replacement count, undo status, scaling options, * and property information for both main and notes pages.
*/ struct PageInsertionParams
{
sal_uInt16 nInsertPos; // Position where to insert pages
OUString aBookmarkName; // Name of the bookmark for insertion
sal_uInt16 nReplacedStandardPages; // Number of replaced standard pages bool bUndo; // Whether undo is enabled bool bScaleObjects; // Whether to scale objects
PageNameList* pExchangeList; // List of pages for exchange operations
SdDrawDocument* pBookmarkDoc; // Source document for page insertion
PageProperties mainProps; // Properties of main pages (size, borders, etc.)
PageProperties notesProps; // Properties of notes pages (size, borders, etc.)
/** * Initialize the bookmark document for page/object operations
*/ bool initBookmarkDoc(::sd::DrawDocShell* pBookmarkDocSh, SdDrawDocument*& pBookmarkDoc, OUString& aBookmarkName);
/** * Get page properties from the first standard and notes pages
*/ void getPageProperties(PageProperties& mainProps, PageProperties& notesProps, sal_uInt16 nSdPageCount);
// --- Page insertion and document handling operations ---
/** * Insert specific pages selected from the bookmark list
*/ void insertSelectedPages(const PageNameList& rBookmarkList,
PageInsertionParams& rParams,
InsertBookmarkOptions rOptions);
/** * Insert all pages from the source document
*/ void insertAllPages(PageInsertionParams& rParams, const InsertBookmarkOptions& rOptions, const DocumentPageCounts& rPageCounts);
/** * Determine whether objects should be scaled during insertion
*/ bool determineScaleObjects(bool bNoDialogs, const PageNameList& rBookmarkList,
PageInsertionParams& rParams);
/** * Collect layouts that need to be transferred from source document
*/ void collectLayoutsToTransfer(const PageNameList& rBookmarkList,
SdDrawDocument* pBookmarkDoc,
SlideLayoutNameList& rLayoutsToTransfer, const DocumentPageCounts& rPageCounts, bool bMergeMasterPagesOnly);
/** * Transfer layout styles from source document to destination
*/ void transferLayoutStyles(const SlideLayoutNameList& layoutsToTransfer,
SdDrawDocument* pBookmarkDoc,
SfxUndoManager* pUndoMgr,
StyleTransferContext& rStyleContext);
/** * Copy styles between documents with options for replacement and dialog suppression
*/ staticvoid copyStyles(bool bReplace, bool bNoDialogs,
StyleTransferContext& rStyleContext);
/** if the document does not contain at least one handout, one slide and one notes page with at least one master each this methods creates them. If a reference document is given, the sizes and border settings of that document are used for newly created slides.
*/ void CreateFirstPages( SdDrawDocument const * pRefDocument = nullptr ); bool CreateMissingNotesAndHandoutPages();
/** * Paste pages from clipboard - handles regular paste operations * * This method is called when the user performs a paste operation from the clipboard. * It handles the insertion of pages that were previously copied or cut to the clipboard. * * @param rBookmarkList List of page names to be pasted * @param pExchangeList Optional list of names to use for the pasted pages * @param nInsertPos Position where pages should be inserted * @param pBookmarkDocSh Source document shell * @param bMergeMasterPages Whether to merge master pages from source * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool PasteBookmarkAsPage( const PageNameList &rBookmarkList,
PageNameList *pExchangeList,
sal_uInt16 nInsertPos,
::sd::DrawDocShell* pBookmarkDocSh, bool bMergeMasterPages, bool bMergeMasterPagesOnly = false);
/** * Insert pages from external files * * This method is called when inserting pages from external files, either through * the Insert > Page from File menu command or when handling file links. * It manages the transfer of pages from an external document to the current one. * * @param rBookmarkList List of page names to be inserted * @param pExchangeList Optional list of names to use for the inserted pages * @param bLink Whether to link to the source pages instead of copying * @param nInsertPos Position where pages should be inserted * @param pBookmarkDocSh Source document shell * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool InsertFileAsPage( const PageNameList &rBookmarkList,
PageNameList *pExchangeList, bool bLink,
sal_uInt16 nInsertPos,
::sd::DrawDocShell* pBookmarkDocSh, bool bMergeMasterPagesOnly = false);
/** * Handle drag and drop operations * * This method is called when pages are dragged and dropped, either within * the same document or from another document. It processes the dropped pages * and inserts them at the specified position. * * @param rBookmarkList List of page names to be dropped * @param nInsertPos Position where pages should be inserted * @param pBookmarkDocSh Source document shell * @param bMergeMasterPages Whether to merge master pages from source * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool DropBookmarkAsPage( const PageNameList &rBookmarkList,
sal_uInt16 nInsertPos,
::sd::DrawDocShell* pBookmarkDocSh, bool bMergeMasterPages, bool bMergeMasterPagesOnly = false);
/** * Resolve page links * * This method is called when linked pages need to be resolved, typically * when a document with linked pages is opened or when the user chooses * to update or break links to external pages. * * @param rBookmarkList List of page names to resolve links for * @param nInsertPos Position where resolved pages should be inserted * @param bNoDialogs Whether to suppress dialogs during operation * @param bCopy Whether to copy the linked pages * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool ResolvePageLinks( const PageNameList &rBookmarkList,
sal_uInt16 nInsertPos, bool bNoDialogs, bool bCopy, bool bMergeMasterPagesOnly = false);
/** * Copy or move pages within the same document * * This method is called for internal page operations such as duplicating pages * or moving pages within the same document. It handles the copying or moving * of pages while maintaining proper references and styles. * * @param rBookmarkList List of page names to be copied or moved * @param pExchangeList Optional list of names to use for the destination pages * @param nInsertPos Position where pages should be inserted * @param bPreservePageNames Whether to preserve original page names * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool CopyOrMovePagesWithinDocument( const PageNameList &rBookmarkList,
PageNameList *pExchangeList,
sal_uInt16 nInsertPos, bool bPreservePageNames, bool bMergeMasterPagesOnly = false);
/** * Import a whole document * * This method is called when importing an entire document, such as when * using Insert > Document or when merging presentations. It handles the * transfer of all pages and associated resources from the source document. * * @param rBookmarkList List of page names to be imported (empty for all pages) * @param nInsertPos Position where imported pages should be inserted * @param pBookmarkDocSh Source document shell * @param bMergeMasterPagesOnly Whether to only merge master pages (not content pages) * @return true if operation was successful
*/ bool ImportDocumentPages( const PageNameList &rBookmarkList,
sal_uInt16 nInsertPos,
::sd::DrawDocShell* pBookmarkDocSh, bool bMergeMasterPagesOnly = false);
/** Return the first page that has the given name. Regular pages and notes pages are searched first. When not found then the master pages are searched. @param rPgName Name of the page to return. @param rbIsMasterPage Is set by the method to indicate whether the returned index belongs to a master page (<TRUE/>) or a regular or notes page (<FALSE/>). The given value is ignored. @return Returns the index of the page with the given name or SDRPAGE_NOTFOUND (=0xffff) when such a page does not exist.
*/
SAL_DLLPRIVATE sal_uInt16 GetPageByName(std::u16string_view rPgName, bool& rbIsMasterPage ) const; /** checks, if the given name is a *unique* name for an *existing* slide
@param rPageName the name of an existing slide
@return true, if the name is unique and the slide exists
*/ bool IsPageNameUnique( std::u16string_view rPageName ) const;
SdPage*GetSdPage(sal_uInt16 nPgNum, PageKind ePgKind) const;
sal_uInt16 GetSdPageCount(PageKind ePgKind) const;
/** Set the mode that controls whether (and later how) the formatting of the document depends on the current printer metrics. @param nMode Use <const scope="css::document::PrinterIndependentLayout">ENABLED</const> to make formatting printer-independent and <const scope="css::document::PrinterIndependentLayout">DISABLED</const> to make formatting depend on the current printer metrics.
*/
SAL_DLLPRIVATE void SetPrinterIndependentLayout (sal_Int32 nMode);
/** Get the flag that controls whether the formatting of the document depends on the current printer metrics. @return Use <const scope="css::document::PrinterIndependentLayout">ENABLED</const> when formatting is printer-independent and <const scope="css::document::PrinterIndependentLayout">DISABLED</const> when formatting depends on the current printer metrics.
*/
SAL_DLLPRIVATE sal_Int32 GetPrinterIndependentLayout() const { return mnPrinterIndependentLayout;}
/** replacespOldPage from all custom shows with pNewPage or removes pOldPage from all custom shows if pNewPage is 0.
*/
SAL_DLLPRIVATE void ReplacePageInCustomShows( const SdPage* pOldPage, const SdPage* pNewPage );
public:
/// static to prevent recursions while resolving links
SAL_DLLPRIVATE static SdDrawDocument* s_pDocLockedInsertingLinks;
/** Create and insert a set of two new pages: a standard (draw) page and the associated notes page. The new pages are inserted directly after the specified page set. @param pCurrentPage This page is used to retrieve the layout for the page to create. @param ePageKind This specifies whether <argument>pCurrentPage</argument> is a standard (draw) page or a notes page. @param sStandardPageName Name of the standard page. An empty string leads to using an automatically created name. @param sNotesPageName Name of the standard page. An empty string leads to using an automatically created name. @param eStandardLayout Layout to use for the new standard page. Note that this layout is not used when the given <argument>pCurrentPage</argument> is not a standard page. In this case the layout is taken from the standard page associated with <argument>pCurrentPage</argument>. @param eNotesLayout Layout to use for the new notes page. Note that this layout is not used when the given <argument>pCurrentPage</argument> is not a notes page. In this case the layout is taken from the notes page associated with <argument>pCurrentPage</argument>. @param bIsPageBack This flag indicates whether to show the background shape. @param bIsPageObj This flag indicates whether to show the shapes on the master page. @param nInsertPosition Position where to insert the standard page. When -1 then the new page set is inserted after the current page.
@return Returns an index of the inserted pages that can be used with the <member>GetSdPage()</member> method.
*/
SAL_DLLPRIVATE sal_uInt16 CreatePage (
SdPage* pCurrentPage,
PageKind ePageKind, const OUString& sStandardPageName, const OUString& sNotesPageName,
AutoLayout eStandardLayout,
AutoLayout eNotesLayout, bool bIsPageBack, bool bIsPageObj, const sal_Int32 nInsertPosition);
/** This method acts as a simplified front end for the more complex <member>DuplicatePage()</member> method. @param nPageNum The page number as passed to the <member>GetSdPage()</member> method for which the standard page and the notes page are to be copied. @return Returns an index of the inserted pages that can be used with the <member>GetSdPage()</member> method.
*/
SAL_DLLPRIVATE sal_uInt16 DuplicatePage (sal_uInt16 nPageNum);
/** Create and insert a set of two new pages that are copies of the given <argument>pCurrentPage</argument> and its associated notes resp. standard page. The copies are inserted directly after the specified page set. @param pCurrentPage This page and its associated notes/standard page is copied. @param ePageKind This specifies whether <argument>pCurrentPage</argument> is a standard (draw) page or a notes page. @param sStandardPageName Name of the standard page. An empty string leads to using an automatically created name. @param sNotesPageName Name of the standard page. An empty string leads to using an automatically created name. @param bIsPageBack This flag indicates whether to show the background shape. @param bIsPageObj This flag indicates whether to show the shapes on the master page. @param nInsertPosition Position where to insert the standard page. When -1 then the new page set is inserted after the current page.
@return Returns an index of the inserted pages that can be used with the <member>GetSdPage()</member> method.
*/
SAL_DLLPRIVATE sal_uInt16 DuplicatePage (
SdPage* pCurrentPage,
PageKind ePageKind, const OUString& sStandardPageName, const OUString& sNotesPageName, bool bIsPageBack, bool bIsPageObj, const sal_Int32 nInsertPosition);
/** return the document fonts for latin, cjk and ctl according to the current
languages set at this document */
SAL_DLLPRIVATE void getDefaultFonts( vcl::Font& rLatinFont, vcl::Font& rCJKFont, vcl::Font& rCTLFont );
sd::UndoManager* GetUndoManager() const;
/** converts the given western font height to a corresponding ctl font height, depending on the system language */
SAL_DLLPRIVATE static sal_uInt32 convertFontHeightToCTL( sal_uInt32 nWesternFontHeight );
/** Get the style sheet pool if it was a SdStyleSheetPool.
*/
SdStyleSheetPool* GetSdStyleSheetPool() const;
/** Extract the base layout name from a layout name by removing the separator and anything after it * @param rLayoutName The full layout name that may include a separator and suffix * @return The base layout name without separator and suffix
*/ static OUString GetBaseLayoutName(std::u16string_view rLayoutName);
/** Generate a new layout name based on the original name by appending a number to it * @param aOriginalName The original layout name * @return A new layout name that is unique and based on the original name
*/ static OUString GenerateNewLayoutName(std::u16string_view rOriginalName);
/** Create a new master page based on an existing master page. * This function is useful for copy/paste operations of master pages. * * @param pSourceMasterPage The master page to copy from. * @param pBookmarkDoc The document containing the source master page. If null, assumes this document. * @param bUndo Whether to support undo for this operation. * @param sNewName Optional new name for the master page. If empty, a new name will be generated. * @return The newly created master page.
*/
SdPage* AddNewMasterPageFromExisting(
SdPage* pSourceMasterPage,
SdDrawDocument* pBookmarkDoc = nullptr, bool bUndo = true, const OUString& sNewName = OUString());
/** This member stores the printer independent layout mode. Please refer to <member>SetPrinterIndependentLayout()</member> for its values.
*/
sal_Int32 mnPrinterIndependentLayout;
/** Insert a given set of standard and notes page after the given <argument>pCurrentPage</argument>. @param pCurrentPage This page and its associated notes/standard page is copied. @param ePageKind This specifies whether <argument>pCurrentPage</argument> is a standard (draw) page or a notes page. @param sStandardPageName Name of the standard page. An empty string leads to using an automatically created name. @param sNotesPageName Name of the standard page. An empty string leads to using an automatically created name. @param bIsPageBack This flag indicates whether to show the background shape. @param bIsPageObj This flag indicates whether to show the shapes on the master page. @param pStandardPage The standard page to insert. @param pNotesPage The notes page to insert. @param nInsertPosition Position where to insert the standard page. When -1 then the new page set is inserted after the current page.
@return Returns an index of the inserted pages that can be used with the <member>GetSdPage()</member> method.
*/
SAL_DLLPRIVATE sal_uInt16 InsertPageSet (
SdPage* pCurrentPage,
PageKind ePageKind, const OUString& sStandardPageName, const OUString& sNotesPageName, bool bIsPageBack, bool bIsPageObj,
SdPage* pStandardPage,
SdPage* pNotesPage,
sal_Int32 nInsertPosition);
/** Set up a newly created page and insert it into the list of pages. @param pPreviousPage A page to take the size and border geometry from. @param pPage This is the page to set up and insert. @param sPageName The name of the new page. @param nInsertionPoint Index of the page before which the new page will be inserted. @param bIsPageBack This flag indicates whether to show the background shape. @param bIsPageObj This flag indicates whether to show the shapes on the master page.
*/
SAL_DLLPRIVATE void SetupNewPage (
SdPage const * pPreviousPage,
SdPage* pPage, const OUString& sPageName,
sal_uInt16 nInsertionPoint, bool bIsPageBack, bool bIsPageObj);
/**an instance of this guard disables modification of a document
during its lifetime*/ class ModifyGuard
{ public:
ModifyGuard( SdDrawDocument* pDoc );
~ModifyGuard();
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.