X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBufferView.h;h=5b277c4edc8e7dab79584040e114f90cfb3ecdc7;hb=2098f1d8c20d51e63e670bcdc9da8996068975bf;hp=9335a85ab4b22b452847364304d002f62ebd3608;hpb=b0d53e325060099374b6fb72259bae9b9184c8a1;p=lyx.git diff --git a/src/BufferView.h b/src/BufferView.h index 9335a85ab4..5b277c4edc 100644 --- a/src/BufferView.h +++ b/src/BufferView.h @@ -32,6 +32,7 @@ class Change; class CoordCache; class Cursor; class DocIterator; +class DocumentClass; class FuncRequest; class FuncStatus; class Intl; @@ -158,6 +159,11 @@ public: /// if needed. /// \param recenter Whether the cursor should be centered on screen void showCursor(DocIterator const & dit, bool recenter = false); + /// Scroll to the cursor. + void scrollToCursor(); + /// Scroll to the cursor. + /// \param recenter Whether the cursor should be centered on screen + bool scrollToCursor(DocIterator const & dit, bool recenter); /// LFUN_SCROLL Helper. void lfunScroll(FuncRequest const & cmd); /// scroll down document by the given number of pixels. @@ -190,8 +196,8 @@ public: /// translate and insert a character, using the correct keymap. void translateAndInsert(char_type c, Text * t, Cursor & cur); - /// return true for events that will handle. - FuncStatus getStatus(FuncRequest const & cmd); + /// \return true if we've made a decision + bool getStatus(FuncRequest const & cmd, FuncStatus & flag); /// execute the given function. /// \return true if the function has been processed. bool dispatch(FuncRequest const & argument); @@ -256,6 +262,10 @@ public: Point getPos(DocIterator const & dit, bool boundary) const; /// is the paragraph of the cursor visible ? bool paragraphVisible(DocIterator const & dit) const; + /// is the cursor currently visible in the view + bool cursorInView(Point const & p, int h) const; + /// get the position and height of the cursor + void cursorPosAndHeight(Point & p, int & h) const; /// @@ -294,6 +304,10 @@ public: void insertLyXFile(support::FileName const & f); /// save temporary bookmark for jump back navigation void bookmarkEditPosition(); + /// Find and return the inset associated with given dialog name. + Inset * editedInset(std::string const & name) const; + /// Associate an inset associated with given dialog name. + void editInset(std::string const & name, Inset * inset); private: /// noncopyable @@ -306,6 +320,10 @@ private: /// \return true if no further update is needed. bool singleParUpdate(); + /// The minimal size of the document that is visible. Used + /// when it is allowed to scroll below the document. + int minVisiblePart(); + /// Search recursively for the the innermost inset that covers (x, y) position. /// \retval 0 if no inset is found. Inset const * getCoveringInset( @@ -314,6 +332,8 @@ private: int y //< y-coordinate on screen ) const; + /// + void updateLayout(DocumentClass const * const oldlayout); /// int width_; ///