/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef SD_FRAME_VIEW_HXX #define SD_FRAME_VIEW_HXX #include "ViewShell.hxx" #include #include "pres.hxx" class SdDrawDocument; class SdOptions; namespace sd { /************************************************************************* |* |* View fuer den MDIFrame |* \************************************************************************/ class SD_DLLPUBLIC FrameView : public SdrView { public: FrameView(SdDrawDocument* pDrawDoc, FrameView* pFrameView = NULL ); FrameView(const FrameView& rFrameView); virtual ~FrameView(); void Connect(); void Disconnect(); void Update(SdOptions* pOptions); void SetStandardHelpLines(const SdrHelpLineList& rHelpLines) { maStandardHelpLines = rHelpLines; } const SdrHelpLineList& GetStandardHelpLines() { return maStandardHelpLines; } void SetNotesHelpLines(const SdrHelpLineList& rHelpLines) { maNotesHelpLines = rHelpLines; } const SdrHelpLineList& GetNotesHelpLines() { return maNotesHelpLines; } void SetHandoutHelpLines(const SdrHelpLineList& rHelpLines) { maHandoutHelpLines = rHelpLines; } const SdrHelpLineList& GetHandoutHelpLines() { return maHandoutHelpLines; } void SetVisibleLayers(const SetOfByte& rVisibleLayers) { maVisibleLayers = rVisibleLayers; } const SetOfByte& GetVisibleLayers() { return maVisibleLayers; } void SetLockedLayers(const SetOfByte& rLockedLayers) { maLockedLayers = rLockedLayers; } const SetOfByte& GetLockedLayers() { return maLockedLayers; } void SetPrintableLayers(const SetOfByte& rPrintableLayers) { maPrintableLayers = rPrintableLayers; } const SetOfByte& GetPrintableLayers() { return maPrintableLayers; } void SetRuler(const sal_Bool bRulerOn) { mbRuler = bRulerOn; } sal_Bool HasRuler() const { return mbRuler; } void SetNoColors(const sal_Bool bNoCol) { mbNoColors = bNoCol; } sal_Bool IsNoColors() const { return mbNoColors; } void SetNoAttribs(const sal_Bool bNoAttr) { mbNoAttribs = bNoAttr; } sal_Bool IsNoAttribs() const { return mbNoAttribs; } void SetVisArea(const Rectangle& rVisArea) { maVisArea = rVisArea; } const Rectangle GetVisArea() { return maVisArea; } void SetPageKind(PageKind eKind) { mePageKind = eKind; } PageKind GetPageKind() const { return mePageKind; } /** is used in FrameView::ReadUserDataSequence() only to store the page kind that was selected while last saving this document */ void SetPageKindOnLoad(PageKind eKind) { mePageKindOnLoad = eKind; } /** can be used to get the page kind that was selected on last save of this document */ PageKind GetPageKindOnLoad() const { return mePageKindOnLoad; } void SetSelectedPage (sal_uInt16 nPage); sal_uInt16 GetSelectedPage () const; /** is used in FrameView::ReadUserDataSequence() only to store the page that was selected while last saving this document */ void SetSelectedPageOnLoad (sal_uInt16 nPage) { mnSelectedPageOnLoad = nPage; } /** can be used to get the page that was selected on last save of this document */ sal_uInt16 GetSelectedPageOnLoad () const { return mnSelectedPageOnLoad; } void SetViewShEditMode(EditMode eMode, PageKind eKind); EditMode GetViewShEditMode (PageKind eKind); /** Remember the edit mode of the main view shell at the time when the document is loaded. */ void SetViewShEditModeOnLoad (const EditMode eMode); /** Return the value of the edit mode as it was when the document was loaded. */ EditMode GetViewShEditModeOnLoad (void) const; void SetLayerMode(sal_Bool bMode) { mbLayerMode = bMode; } sal_Bool IsLayerMode() const { return mbLayerMode; } void SetQuickEdit(sal_Bool bQEdit) { mbQuickEdit = bQEdit; } sal_Bool IsQuickEdit() const { return mbQuickEdit; } void SetDoubleClickTextEdit( sal_Bool bOn = sal_True ) { mbDoubleClickTextEdit = bOn; } sal_Bool IsDoubleClickTextEdit() const { return mbDoubleClickTextEdit; } void SetClickChangeRotation( sal_Bool bOn = sal_True ) { mbClickChangeRotation = bOn; } sal_Bool IsClickChangeRotation() const { return mbClickChangeRotation; } /** Remember the type of the view shell that was (or soon will be) previously associated with this frame view. @param eType The type of the previous view shell or ViewShell::ST_NONE to indicate that there is no previous view shell. */ void SetPreviousViewShellType (ViewShell::ShellType eType); /** Return the type of the view shell previously associated with this frame view. */ ViewShell::ShellType GetPreviousViewShellType (void) const; /** Remember the type of the view shell at the time when the document is loaded or, rather, when the ViewShellBase is constructed. */ void SetViewShellTypeOnLoad (ViewShell::ShellType eType); ViewShell::ShellType GetViewShellTypeOnLoad (void) const; void SetPresentationViewShellId(sal_uInt16 nId) { mnPresViewShellId = nId; } sal_uInt16 GetPresentationViewShellId() const { return mnPresViewShellId; } void SetSlotId(sal_uInt16 nId) { mnSlotId = nId; } sal_uInt16 GetSlotId() const { return mnSlotId; } void SetSlidesPerRow(sal_uInt16 nSlides) { mnSlidesPerRow = nSlides; } sal_uInt16 GetSlidesPerRow() const { return mnSlidesPerRow; } void SetDrawMode(sal_uLong nNewDrawMode) { mnDrawMode = nNewDrawMode; }; sal_uLong GetDrawMode() const { return mnDrawMode; }; void SetTabCtrlPercent( double nPercent ) { mnTabCtrlPercent = nPercent; } double GetTabCtrlPercent() const { return mnTabCtrlPercent; } void SetIsNavigatorShowingAllShapes (const bool bIsNavigatorShowingAllShapes); bool IsNavigatorShowingAllShapes (void) const; virtual void WriteUserDataSequence ( ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool bBrowse = sal_False ); virtual void ReadUserDataSequence ( const ::com::sun::star::uno::Sequence < ::com::sun::star::beans::PropertyValue >&, sal_Bool bBrowse = sal_False ); private: sal_uInt16 mnRefCount; VirtualDevice* mpVDev; sal_Bool mbRuler; SetOfByte maVisibleLayers; SetOfByte maLockedLayers; SetOfByte maPrintableLayers; SdrHelpLineList maStandardHelpLines; SdrHelpLineList maNotesHelpLines; SdrHelpLineList maHandoutHelpLines; sal_Bool mbNoColors; // Gliederungsmodus sal_Bool mbNoAttribs; // Gliederungsmodus Rectangle maVisArea; // Sichtbarer Bereich PageKind mePageKind; // Seitentyp (Standard, Notizen, Handzettel) sal_uInt16 mnSelectedPage; // Selektierte Seite PageKind mePageKindOnLoad; sal_uInt16 mnSelectedPageOnLoad; EditMode meStandardEditMode; // Editmode im Zeichenmodus (Page/MasterPage) EditMode meNotesEditMode; // Editmode im Notizen-Modus (Page/MasterPage) EditMode meHandoutEditMode; // Editmode im Handzettel-Modus (Page/MasterPage) EditMode meEditModeOnLoad; sal_Bool mbLayerMode; // Layer an/aus sal_Bool mbQuickEdit; // QuickEdit an/aus sal_Bool mbDoubleClickTextEdit; // Textmodus nach Doppelklick sal_Bool mbClickChangeRotation; // Einfachklick wechselt Selektions-/Rotationsmodus sal_uInt16 mnPresViewShellId; // ViewShell aus der die Pres. gestartet wurde sal_uInt16 mnSlotId; // SlotId, welche initial ausgefuehrt wird sal_uInt16 mnSlidesPerRow; // Dias pro Reihe auf dem Diatisch sal_uLong mnDrawMode; // Drawmode fuer das normale Fenster double mnTabCtrlPercent; /** Remember whether the navigator shows all shapes () or only the names ones (). Not persistent. */ bool mbIsNavigatorShowingAllShapes; /** The type of the previous view shell. The (default) value ViewShell::ST_NONE indicates that there was no previous view shell. Note that this value is used only temporarily and is not saved or restored. */ ViewShell::ShellType mePreviousViewShellType; ViewShell::ShellType meViewShellTypeOnLoad; }; } // end of namespace sd #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */