/* -*- 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 . */ // MyEDITVIEW, due to exported EditView #ifndef INCLUDED_EDITENG_EDITVIEW_HXX #define INCLUDED_EDITENG_EDITVIEW_HXX #include #include #include #include #include #include #include #include #include #include #include #include #include class EditTextObject; class EditEngine; class ImpEditEngine; class ImpEditView; class OutlinerViewShell; class SvxSearchItem; class SvxFieldItem; namespace vcl { class Window; } class KeyEvent; class MouseEvent; class CommandEvent; class SvStream; class SvKeyValueIterator; class SfxStyleSheet; class SfxItemSet; namespace vcl { class Cursor; } namespace vcl { class Font; } class FontList; class OutputDevice; enum class TransliterationFlags; enum class PointerStyle; namespace com { namespace sun { namespace star { namespace datatransfer { class XTransferable; namespace dnd { class XDropTarget; } } namespace linguistic2 { class XSpellChecker1; class XLanguageGuessing; } }}} template class Link; enum class ScrollRangeCheck { NoNegative = 1, // No negative VisArea when scrolling PaperWidthTextSize = 2, // VisArea must be within paper width, Text Size }; // Helper class that allows to set a callback at the EditView. When // set, Invalidates and repaints are suppressed at the EditView, but // EditViewInvalidate() will be triggered to allow the consumer to // react itself as needed. // Also Selection visualization is suppressed and EditViewSelectionChange // is triggered when Selection changes and needs reaction. class EDITENG_DLLPUBLIC EditViewCallbacks { public: EditViewCallbacks() {} virtual ~EditViewCallbacks(); // call this when text visualization changed in any way. It // will also update selection, so no need to call this self // additionally (but will also do no harm) virtual void EditViewInvalidate(const tools::Rectangle& rRect) const = 0; // call this when only selection is changed. Text change will // then *not* be checked and not be reacted on. Still, when // only the selection is changed, this is useful and faster virtual void EditViewSelectionChange() const = 0; // return the OutputDevice that the EditView will draw to virtual OutputDevice& EditViewOutputDevice() const = 0; // implemented if drag and drop support is wanted virtual css::uno::Reference GetDropTarget() const { return nullptr; } }; class EDITENG_DLLPUBLIC EditView final { friend class EditEngine; friend class ImpEditEngine; friend class EditSelFunctionSet; public: typedef std::vector> OutWindowSet; public: // Needed for Undo ImpEditView* GetImpEditView() const { return pImpEditView.get(); } ImpEditEngine* GetImpEditEngine() const; private: std::unique_ptr pImpEditView; OUString aDicNameSingle; EditView( const EditView& ) = delete; EditView& operator=( const EditView& ) = delete; public: EditView( EditEngine* pEng, vcl::Window* pWindow ); ~EditView(); // set EditViewCallbacks for external handling of Repaints/Visualization void setEditViewCallbacks(const EditViewCallbacks* pEditViewCallbacks); const EditViewCallbacks* getEditViewCallbacks() const; void SetEditEngine( EditEngine* pEditEngine ); EditEngine* GetEditEngine() const; void SetWindow( vcl::Window* pWin ); vcl::Window* GetWindow() const; bool HasOtherViewWindow( vcl::Window* pWin ); bool AddOtherViewWindow( vcl::Window* pWin ); bool RemoveOtherViewWindow( vcl::Window* pWin ); void Paint( const tools::Rectangle& rRect, OutputDevice* pTargetDevice = nullptr ); tools::Rectangle GetInvalidateRect() const; void InvalidateWindow(const tools::Rectangle& rClipRect); void InvalidateOtherViewWindows( const tools::Rectangle& rInvRect ); void Invalidate(); Pair Scroll( long nHorzScroll, long nVertScroll, ScrollRangeCheck nRangeCheck = ScrollRangeCheck::NoNegative ); void ShowCursor( bool bGotoCursor = true, bool bForceVisCursor = true, bool bActivate = false ); void HideCursor( bool bDeactivate = false ); void SetSelectionMode( EESelectionMode eMode ); void SetReadOnly( bool bReadOnly ); bool IsReadOnly() const; bool HasSelection() const; ESelection GetSelection() const; void SetSelection( const ESelection& rNewSel ); void SelectCurrentWord( sal_Int16 nWordType = css::i18n::WordType::ANYWORD_IGNOREWHITESPACES ); /// Returns the rectangles of the current selection in TWIPs. void GetSelectionRectangles(std::vector& rLogicRects) const; bool IsInsertMode() const; void SetInsertMode( bool bInsert ); OUString GetSelected(); void DeleteSelected(); SvtScriptType GetSelectedScriptType() const; // VisArea position of the Output window. // A size change also affects the VisArea void SetOutputArea( const tools::Rectangle& rRect ); const tools::Rectangle& GetOutputArea() const; // Document position. // A size change also affects the VisArea void SetVisArea( const tools::Rectangle& rRect ); const tools::Rectangle& GetVisArea() const; PointerStyle GetPointer() const; vcl::Cursor* GetCursor() const; void InsertText( const OUString& rNew, bool bSelect = false ); void InsertParaBreak(); bool PostKeyEvent( const KeyEvent& rKeyEvent, vcl::Window const * pFrameWin = nullptr ); bool MouseButtonUp( const MouseEvent& rMouseEvent ); bool MouseButtonDown( const MouseEvent& rMouseEvent ); void ReleaseMouse(); bool MouseMove( const MouseEvent& rMouseEvent ); void Command( const CommandEvent& rCEvt ); void Cut(); void Copy(); void Paste(); void PasteSpecial(); void Undo(); void Redo(); // especially for Oliver Specht Point GetWindowPosTopLeft( sal_Int32 nParagraph ); void MoveParagraphs( Range aParagraphs, sal_Int32 nNewPos ); void MoveParagraphs( long nDiff ); const SfxItemSet& GetEmptyItemSet(); SfxItemSet GetAttribs(); void SetAttribs( const SfxItemSet& rSet ); void RemoveAttribs( bool bRemoveParaAttribs = false, sal_uInt16 nWhich = 0 ); void RemoveCharAttribs( sal_Int32 nPara, sal_uInt16 nWhich ); void RemoveAttribsKeepLanguages( bool bRemoveParaAttribs ); ErrCode Read( SvStream& rInput, EETextFormat eFormat, SvKeyValueIterator* pHTTPHeaderAttrs ); void SetBackgroundColor( const Color& rColor ); Color const & GetBackgroundColor() const; /// Informs this edit view about which view shell contains it. void RegisterViewShell(OutlinerViewShell* pViewShell); /// Informs this edit view about which other shell listens to it. void RegisterOtherShell(OutlinerViewShell* pOtherShell); void SetControlWord( EVControlBits nWord ); EVControlBits GetControlWord() const; std::unique_ptr CreateTextObject(); void InsertText( const EditTextObject& rTextObject ); void InsertText( css::uno::Reference< css::datatransfer::XTransferable > const & xDataObj, const OUString& rBaseURL, bool bUseSpecial ); css::uno::Reference< css::datatransfer::XTransferable > GetTransferable(); // An EditView, so that when TRUE the update will be free from flickering: void SetEditEngineUpdateMode( bool bUpdate ); void ForceUpdate(); const SfxStyleSheet* GetStyleSheet() const; SfxStyleSheet* GetStyleSheet(); void SetAnchorMode( EEAnchorMode eMode ); EEAnchorMode GetAnchorMode() const; void CompleteAutoCorrect( vcl::Window const * pFrameWin = nullptr ); EESpellState StartSpeller( bool bMultipleDoc = false ); EESpellState StartThesaurus(); sal_Int32 StartSearchAndReplace( const SvxSearchItem& rSearchItem ); // for text conversion void StartTextConversion( LanguageType nSrcLang, LanguageType nDestLang, const vcl::Font *pDestFont, sal_Int32 nOptions, bool bIsInteractive, bool bMultipleDoc ); void TransliterateText( TransliterationFlags nTransliterationMode ); bool IsCursorAtWrongSpelledWord(); bool IsWrongSpelledWordAtPos( const Point& rPosPixel, bool bMarkIfWrong = false ); void ExecuteSpellPopup( const Point& rPosPixel, Link const * pCallBack ); void InsertField( const SvxFieldItem& rFld ); const SvxFieldItem* GetFieldUnderMousePointer() const; const SvxFieldItem* GetFieldUnderMousePointer( sal_Int32& nPara, sal_Int32& nPos ) const; const SvxFieldItem* GetField( const Point& rPos, sal_Int32* pnPara = nullptr, sal_Int32* pnPos = nullptr ) const; const SvxFieldItem* GetFieldAtSelection() const; /// Select and return the field at the current cursor position const SvxFieldData* GetFieldAtCursor(); void SetInvalidateMore( sal_uInt16 nPixel ); sal_uInt16 GetInvalidateMore() const; // grows or shrinks the font height for the current selection void ChangeFontSize( bool bGrow, const FontList* pList ); static bool ChangeFontSize( bool bGrow, SfxItemSet& rSet, const FontList* pFontList ); OUString GetSurroundingText() const; Selection GetSurroundingTextSelection() const; /** Tries to determine the language of 'rText', returning a matching known locale if possible, or a fallback, or LANGUAGE_NONE if nothing found or matched. @param bIsParaText If TRUE, rText is a paragraph and the language is obtained by passing the text to xLangGuess. IF FALSE, a language match is tried for, in order, 1. the default document language (non-CTL, non-CJK, aka LATIN) 2. the UI language (Tools->Options->LanguageSettings->Languages User Interface) 3. the locale (Tools->Options->LanguageSettings->Languages Locale) 4. en-US If nothing matched, LANGUAGE_NONE is returned. */ static LanguageType CheckLanguage( const OUString &rText, const css::uno::Reference< css::linguistic2::XSpellChecker1 >& xSpell, const css::uno::Reference< css::linguistic2::XLanguageGuessing >& xLangGuess, bool bIsParaText ); /// Allows adjusting the point or mark of the selection to a document coordinate. void SetCursorLogicPosition(const Point& rPosition, bool bPoint, bool bClearMark); /// Trigger selection drawing callback in pOtherShell based on our shell's selection state. void DrawSelectionXOR(OutlinerViewShell* pOtherShell); }; #endif // INCLUDED_EDITENG_EDITVIEW_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */