/* -*- 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/. * */ #ifndef INCLUDED_VCL_ITILEDRENDERABLE_HXX #define INCLUDED_VCL_ITILEDRENDERABLE_HXX #include #include #include #include #include #include #include #include #include namespace vcl { /* * Map directly to css cursor styles to avoid further mapping in the client. * Gtk (via gdk_cursor_new_from_name) also supports the same css cursor styles. * * This was created partially with help of the mappings in gtkdata.cxx. * The list is incomplete as some cursor style simply aren't supported * by css, it might turn out to be worth mapping some of these missing cursors * to available cursors? */ #ifdef _MSC_VER #pragma warning(push) #pragma warning( disable : 4592) #endif static const std::map gaLOKPointerMap { { PointerStyle::Arrow, "default" }, // PointerStyle::Null ? { PointerStyle::Wait, "wait" }, { PointerStyle::Text, "text" }, { PointerStyle::Help, "help" }, { PointerStyle::Cross, "crosshair" }, { PointerStyle::Fill, "fill" }, { PointerStyle::Move, "move" }, { PointerStyle::NSize, "n-resize" }, { PointerStyle::SSize, "s-resize" }, { PointerStyle::WSize, "w-resize" }, { PointerStyle::ESize, "e-resize" }, { PointerStyle::NWSize, "ne-resize" }, { PointerStyle::NESize, "ne-resize" }, { PointerStyle::SWSize, "sw-resize" }, { PointerStyle::SESize, "se-resize" }, // WindowNSize through WindowSESize { PointerStyle::HSplit, "col-resize" }, { PointerStyle::VSplit, "row-resize" }, { PointerStyle::HSizeBar, "col-resize" }, { PointerStyle::VSizeBar, "row-resize" }, { PointerStyle::Hand, "grab" }, { PointerStyle::RefHand, "grabbing" }, // Pen, Magnify, Fill, Rotate // HShear, VShear // Mirror, Crook, Crop, MovePoint, MoveBezierWeight // MoveData { PointerStyle::CopyData, "copy" }, { PointerStyle::LinkData, "alias" }, // MoveDataLink, CopyDataLink //MoveFile, CopyFile, LinkFile // MoveFileLink, CopyFileLink, MoveFiless, CopyFiles { PointerStyle::NotAllowed, "not-allowed" }, // DrawLine through DrawCaption // Chart, Detective, PivotCol, PivotRow, PivotField, Chain, ChainNotAllowed // TimeEventMove, TimeEventSize // AutoScrollN through AutoScrollNSWE // Airbrush { PointerStyle::TextVertical, "vertical-text" } // Pivot Delete, TabSelectS through TabSelectSW // PaintBrush, HideWhiteSpace, ShowWhiteSpace }; #ifdef _MSC_VER #pragma warning(pop) #endif class VCL_DLLPUBLIC ITiledRenderable { protected: int mnTilePixelWidth, mnTilePixelHeight; int mnTileTwipWidth, mnTileTwipHeight; public: struct LOKAsyncEventData { VclPtr mpWindow; VclEventId mnEvent; MouseEvent maMouseEvent; KeyEvent maKeyEvent; }; static void LOKPostAsyncEvent(void* pEv, void*) { LOKAsyncEventData* pLOKEv = static_cast(pEv); if (pLOKEv->mpWindow->IsDisposed()) return; switch (pLOKEv->mnEvent) { case VclEventId::WindowKeyInput: pLOKEv->mpWindow->KeyInput(pLOKEv->maKeyEvent); break; case VclEventId::WindowKeyUp: pLOKEv->mpWindow->KeyUp(pLOKEv->maKeyEvent); break; case VclEventId::WindowMouseButtonDown: pLOKEv->mpWindow->LogicMouseButtonDown(pLOKEv->maMouseEvent); // Invoke the context menu if (pLOKEv->maMouseEvent.GetButtons() & MOUSE_RIGHT) { const CommandEvent aCEvt(pLOKEv->maMouseEvent.GetPosPixel(), CommandEventId::ContextMenu, true, nullptr); pLOKEv->mpWindow->Command(aCEvt); } break; case VclEventId::WindowMouseButtonUp: pLOKEv->mpWindow->LogicMouseButtonUp(pLOKEv->maMouseEvent); // sometimes MouseButtonDown captures mouse and starts tracking, and VCL // will not take care of releasing that with tiled rendering if (pLOKEv->mpWindow->IsTracking()) pLOKEv->mpWindow->EndTracking(TrackingEventFlags::DontCallHdl); break; case VclEventId::WindowMouseMove: pLOKEv->mpWindow->LogicMouseMove(pLOKEv->maMouseEvent); break; default: assert(false); break; } delete pLOKEv; } virtual ~ITiledRenderable(); /** * Paint a tile to a given VirtualDevice. * * Output parameters are measured in pixels, tile parameters are in * twips. */ virtual void paintTile( VirtualDevice &rDevice, int nOutputWidth, int nOutputHeight, int nTilePosX, int nTilePosY, long nTileWidth, long nTileHeight ) = 0; /** * Get the document size in twips. */ virtual Size getDocumentSize() = 0; /** * Set the document "part", i.e. slide for a slideshow, and * tab for a spreadsheet. */ virtual void setPart( int ) {} /** * Get the number of parts -- see setPart for further details. */ virtual int getParts() { return 1; } /** * Get the currently displayed/selected part -- see setPart for further * details. */ virtual int getPart() { return 0; } /** * Get the name of the currently displayed part, i.e. sheet in a spreadsheet * or slide in a presentation. */ virtual OUString getPartName(int) { return OUString(); } /** * Get the vcl::Window for the document being edited */ virtual VclPtr getDocWindow() = 0; /** * Get the hash of the currently displayed part, i.e. sheet in a spreadsheet * or slide in a presentation. */ virtual OUString getPartHash(int nPart) = 0; /// @see lok::Document::setPartMode(). virtual void setPartMode(int) {} /** * Setup various document properties that are needed for the document to * be renderable via tiled rendering. */ virtual void initializeForTiledRendering(const css::uno::Sequence& rArguments) = 0; /** * Posts a keyboard event on the document. * * @see lok::Document::postKeyEvent(). */ virtual void postKeyEvent(int nType, int nCharCode, int nKeyCode) = 0; /** * Posts a mouse event on the document. * * @see lok::Document::postMouseEvent(). */ virtual void postMouseEvent(int nType, int nX, int nY, int nCount, int nButtons, int nModifier) = 0; /** * Sets the start or end of a text selection. * * @see lok::Document::setTextSelection(). */ virtual void setTextSelection(int nType, int nX, int nY) = 0; /** * Gets the text selection. * * @see lok::Document::getTextSelection(). */ virtual OString getTextSelection(const char* pMimeType, OString& rUsedMimeType) = 0; /** * Adjusts the graphic selection. * * @see lok::Document::setGraphicSelection(). */ virtual void setGraphicSelection(int nType, int nX, int nY) = 0; /** * @see lok::Document::resetSelection(). */ virtual void resetSelection() = 0; /** * @see lok::Document::getPartPageRectangles(). */ virtual OUString getPartPageRectangles() { return OUString(); } /** * Get position and content of row/column headers of Calc documents. * * @param rRectangle - if not empty, then limit the output only to the area of this rectangle * @return a JSON describing position/content of rows/columns */ virtual OUString getRowColumnHeaders(const tools::Rectangle& /*rRectangle*/) { return OUString(); } /** * Get position and size of cell cursor in Calc. * (This could maybe also be used for tables in Writer/Impress in future?) */ virtual OString getCellCursor(int /*nOutputWidth*/, int /*nOutputHeight*/, long /*nTileWidth*/, long /*nTileHeight*/) { return OString(); } virtual Pointer getPointer() = 0; /// Sets the clipboard of the component. virtual void setClipboard(const css::uno::Reference& xClipboard) = 0; /// If the current contents of the clipboard is something we can paste. virtual bool isMimeTypeSupported() = 0; /** * Save the client's view so that we can compute the right zoom level * for the mouse events. * @param nTilePixelWidth - tile width in pixels * @param nTilePixelHeight - tile height in pixels * @param nTileTwipWidth - tile width in twips * @param nTileTwipHeight - tile height in twips */ virtual void setClientZoom(int /*nTilePixelWidth*/, int /*nTilePixelHeight*/, int /*nTileTwipWidth*/, int /*nTileTwipHeight*/) {} /// @see lok::Document::setClientVisibleArea(). virtual void setClientVisibleArea(const tools::Rectangle& /*rRectangle*/) { } /** * Show/Hide a single row/column header outline for Calc documents. * * @param bColumn - if we are dealing with a column or row group * @param nLevel - the level to which the group belongs * @param nIndex - the group entry index * @param bHidden - the new group state (collapsed/expanded) */ virtual void setOutlineState(bool /*bColumn*/, int /*nLevel*/, int /*nIndex*/, bool /*bHidden*/) { return; } /// Implementation for /// lok::Document::getCommandValues(".uno:AcceptTrackedChanges") when there /// is no matching UNO API. virtual OUString getTrackedChanges() { return OUString(); } /// Implementation for /// lok::Document::getCommandValues(".uno:TrackedChangeAuthors"). virtual OUString getTrackedChangeAuthors() { return OUString(); } /// Implementation for /// lok::Document::getCommandValues(".uno:ViewAnnotations"); virtual OUString getPostIts() { return OUString(); } /// Implementation for /// lok::Document::getCommandValues(".uno:ViewAnnotationsPosition"); virtual OUString getPostItsPos() { return OUString(); } /// Implementation for /// lok::Document::getCommandValues(".uno:RulerState"); virtual OUString getRulerState() { return OUString(); } }; } // namespace vcl #endif // INCLUDED_VCL_ITILEDRENDERABLE_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */