#include "frontends/WorkArea.h"
-#include "FuncRequest.h"
-#include "support/Timeout.h"
-
#include <QAbstractScrollArea>
-#include <QMouseEvent>
-#include <QPixmap>
-#include <QResizeEvent>
+#include <QTabBar>
#include <QTabWidget>
-#include <QTimer>
-class QContextMenuEvent;
class QDragEnterEvent;
class QDropEvent;
-class QKeyEvent;
-class QWheelEvent;
-class QPaintEvent;
+class QToolButton;
class QWidget;
#ifdef CursorShape
namespace frontend {
+class GuiCompleter;
class GuiView;
-/// types of cursor in work area
-enum CursorShape {
- /// normal I-beam
- BAR_SHAPE,
- /// L-shape for locked insets of a different language
- L_SHAPE,
- /// reverse L-shape for RTL text
- REVERSED_L_SHAPE
-};
-
-/// for emulating triple click
-class DoubleClick {
-public:
- ///
- DoubleClick() : state(Qt::NoButton), active(false) {}
- ///
- DoubleClick(QMouseEvent * e) : state(e->button()), active(true) {}
- ///
- bool operator==(QMouseEvent const & e) { return state == e.button(); }
- ///
-public:
- ///
- Qt::MouseButton state;
- ///
- bool active;
-};
-
-/** Qt only emits mouse events when the mouse is being moved, but
- * we want to generate 'pseudo' mouse events when the mouse button is
- * pressed and the mouse cursor is below the bottom, or above the top
- * of the work area. In this way, we'll be able to continue scrolling
- * (and selecting) the text.
- *
- * This class stores all the parameters needed to make this happen.
- */
-class SyntheticMouseEvent
-{
-public:
- SyntheticMouseEvent();
-
- FuncRequest cmd;
- Timeout timeout;
- bool restart_timeout;
- int x_old;
- int y_old;
- double scrollbar_value_old;
-};
-
-
-/**
- * Implementation of the work area (buffer view GUI)
-*/
-class CursorWidget;
-
class GuiWorkArea : public QAbstractScrollArea, public WorkArea
{
Q_OBJECT
public:
///
- GuiWorkArea(Buffer & buffer, GuiView & lv);
+ GuiWorkArea(QWidget *);
+ ///
+ GuiWorkArea(Buffer & buffer, GuiView & gv);
///
~GuiWorkArea();
///
- void scheduleRedraw() { schedule_redraw_ = true; }
+ void init();
///
- BufferView & bufferView();
+ void setBuffer(Buffer &);
///
- BufferView const & bufferView() const;
+ void setGuiView(GuiView &);
///
- void redraw();
+ void setFullScreen(bool full_screen);
+ /// is GuiView in fullscreen mode?
+ bool isFullScreen() const;
///
- void stopBlinkingCursor();
+ void scheduleRedraw();
///
- void startBlinkingCursor();
+ BufferView & bufferView();
+ ///
+ BufferView const & bufferView() const;
+ ///
+ void redraw(bool update_metrics);
+
+ /// return true if the key is part of a shortcut
+ bool queryKeySym(KeySymbol const & key, KeyModifier mod) const;
/// Process Key pressed event.
/// This needs to be public because it is accessed externally by GuiView.
void processKeySym(KeySymbol const & key, KeyModifier mod);
+
+ bool inDialogMode() const;
+ void setDialogMode(bool mode);
+
+ ///
+ GuiCompleter & completer();
+
+ Qt::CursorShape cursorShape() const;
+
+ /// Return the GuiView this workArea belongs to
+ GuiView const & view() const;
+ GuiView & view();
+
+ /// Current ratio between physical pixels and device-independent pixels
+ double pixelRatio() const;
+
+public Q_SLOTS:
///
- void resizeBufferView();
+ void stopBlinkingCursor();
+ ///
+ void startBlinkingCursor();
Q_SIGNALS:
///
void titleChanged(GuiWorkArea *);
+ ///
+ void busy(bool);
+ ///
+ void bufferViewChanged();
private Q_SLOTS:
/// Scroll the BufferView.
void doubleClickTimeout();
/// toggle the cursor's visibility
void toggleCursor();
-
/// close this work area.
/// Slot for Buffer::closing signal.
void close();
+ /// Slot to restore proper scrollbar behaviour.
+ void fixVerticalScrollBar();
private:
- /// update the passed area.
- void update(int x, int y, int w, int h);
- ///
- void updateScreen();
-
- /// paint the cursor and store the background
- virtual void showCursor(int x, int y, int h, CursorShape shape);
-
- /// hide the cursor
- virtual void removeCursor();
-
- /// This function is called when the buffer readonly status change.
- void setReadOnly(bool);
-
/// Update window titles of all users.
void updateWindowTitle();
///
void mouseMoveEvent(QMouseEvent * ev);
/// wheel event
void wheelEvent(QWheelEvent * ev);
- /// key press
+ /// key press event. It also knows how to handle ShortcutOverride events to
+ /// avoid code duplication.
void keyPressEvent(QKeyEvent * ev);
/// IM events
void inputMethodEvent(QInputMethodEvent * ev);
/// The slot connected to SyntheticMouseEvent::timeout.
void generateSyntheticMouseEvent();
- ///
- void dispatch(FuncRequest const & cmd0, KeyModifier = NoModifier);
- /// hide the visible cursor, if it is visible
- void hideCursor();
- /// show the cursor if it is not visible
- void showCursor();
- ///
- void updateScrollbar();
- ///
- BufferView * buffer_view_;
- ///
- GuiView * lyx_view_;
- /// is the cursor currently displayed
- bool cursor_visible_;
+ friend class GuiCompleter;
+ struct Private;
+ Private * const d;
+}; // GuiWorkArea
- ///
- QTimer cursor_timeout_;
- ///
- SyntheticMouseEvent synthetic_mouse_event_;
- ///
- DoubleClick dc_event_;
+class EmbeddedWorkArea : public GuiWorkArea
+{
+ Q_OBJECT
+public:
///
- CursorWidget * cursor_;
- ///
- QPixmap screen_;
+ EmbeddedWorkArea(QWidget *);
+ ~EmbeddedWorkArea();
+
+ /// Dummy methods for Designer.
+ void setWidgetResizable(bool) {}
+ void setWidget(QWidget *) {}
+
+ QSize sizeHint () const;
///
- bool need_resize_;
+ void disable();
+
+protected:
///
- bool schedule_redraw_;
+ void closeEvent(QCloseEvent * ev);
///
- int preedit_lines_;
-}; // GuiWorkArea
+ void hideEvent(QHideEvent *ev);
+
+private:
+ /// Embedded Buffer.
+ Buffer * buffer_;
+}; // EmbeddedWorkArea
/// A tabbed set of GuiWorkAreas.
public:
TabWorkArea(QWidget * parent = 0);
+ ///
+ void setFullScreen(bool full_screen);
void showBar(bool show);
void closeAll();
bool setCurrentWorkArea(GuiWorkArea *);
bool removeWorkArea(GuiWorkArea *);
GuiWorkArea * currentWorkArea();
GuiWorkArea * workArea(Buffer & buffer);
+ GuiWorkArea * workArea(int index);
+ void paintEvent(QPaintEvent *);
Q_SIGNALS:
///
void currentWorkAreaChanged(GuiWorkArea *);
+ ///
+ void lastWorkAreaRemoved();
public Q_SLOTS:
+ /// close current buffer, or the one given by \c clicked_tab_
+ void closeCurrentBuffer();
+ /// hide current tab, or the one given by \c clicked_tab_
+ void hideCurrentTab();
+ /// close the tab given by \c index
+ void closeTab(int index);
+ ///
+ void moveTab(int fromIndex, int toIndex);
+ ///
+ void updateTabTexts();
+
+private Q_SLOTS:
///
void on_currentTabChanged(int index);
///
- void closeCurrentTab();
+ void showContextMenu(const QPoint & pos);
+ /// enable closing tab on middle-click
+ void mousePressEvent(QMouseEvent * me);
+ void mouseReleaseEvent(QMouseEvent * me);
+ ///
+ void mouseDoubleClickEvent(QMouseEvent * event);
+
+private:
+ /// true if position is a tab (rather than the blank space in tab bar)
+ bool posIsTab(QPoint position);
+
+ int clicked_tab_;
+ ///
+ int midpressed_tab_;
///
- void updateTabText(GuiWorkArea *);
+ QToolButton * closeBufferButton;
}; // TabWorkArea
+
+class DragTabBar : public QTabBar
+{
+ Q_OBJECT
+public:
+ ///
+ DragTabBar(QWidget * parent = 0);
+
+protected:
+ ///
+ void mousePressEvent(QMouseEvent * event);
+ ///
+ void mouseMoveEvent(QMouseEvent * event);
+ ///
+ void dragEnterEvent(QDragEnterEvent * event);
+ ///
+ void dropEvent(QDropEvent * event);
+
+private:
+ ///
+ QPoint dragStartPos_;
+
+Q_SIGNALS:
+ ///
+ void tabMoveRequested(int fromIndex, int toIndex);
+};
+
} // namespace frontend
} // namespace lyx