X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FWorkArea.h;h=715f1f56e59b68a26958d310aa1f4dfd3a313acd;hb=98c966c64594611e469313314abd1e59524adb4a;hp=df91b43618dbd5d77ebb8f0974cca1725ca066d4;hpb=9062ce972e562477eb64c294769747ebf386fa6c;p=lyx.git diff --git a/src/WorkArea.h b/src/WorkArea.h index df91b43618..715f1f56e5 100644 --- a/src/WorkArea.h +++ b/src/WorkArea.h @@ -1,11 +1,11 @@ // -*- C++ -*- /* This file is part of * ====================================================== - * + * * LyX, The Document Processor - * + * * Copyright 1995 Matthias Ettrich - * Copyright 1995-2000 The LyX Team. + * Copyright 1995-2001 The LyX Team. * * ======================================================*/ @@ -23,19 +23,11 @@ #include FORMS_H_LOCATION #include "Painter.h" -#ifdef SIGC_CXX_NAMESPACES -using SigC::Signal0; -using SigC::Signal2; -using SigC::Signal3; -#endif - -class BufferView; - /// class WorkArea { public: /// - WorkArea(BufferView *, int xpos, int ypos, int width, int height); + WorkArea(int xpos, int ypos, int width, int height); /// ~WorkArea(); /// @@ -44,12 +36,16 @@ public: int workWidth() const { return work_area->w; } /// unsigned int width() const { return work_area->w + scrollbar->w; } + //unsigned int width() const { return backgroundbox->w + 15; } /// unsigned int height() const { return work_area->h; } + //unsigned int height() const { return backgroundbox->h; } /// int xpos() const { return work_area->x; } + //int xpos() const { return backgroundbox->x; } /// int ypos() const { return work_area->y; } + //int ypos() const { return backgroundbox->y; } /// void resize(int xpos, int ypos, int width, int height); /// @@ -86,7 +82,7 @@ public: return fl_get_scrollbar_value(scrollbar); } /// - std::pair getScrollbarBounds() const { + std::pair const getScrollbarBounds() const { std::pair p; fl_get_scrollbar_bounds(scrollbar, &p.first, &p.second); return p; @@ -99,52 +95,63 @@ public: int /*key*/, void * xev); /// xforms callback static void scroll_cb(FL_OBJECT *, long); + /// a selection exists + void haveSelection(bool) const; /// - string getClipboard() const; + string const getClipboard() const; /// void putClipboard(string const &) const; - /// - BufferView * owner() const { return owner_; } - // Signals /// - Signal0 workAreaExpose; + SigC::Signal0 workAreaExpose; /// - Signal2 workAreaKeyPress; + SigC::Signal1 scrollCB; /// - Signal3 workAreaButtonPress; + SigC::Signal2 workAreaKeyPress; /// - Signal3 workAreaButtonRelease; + SigC::Signal3 workAreaButtonPress; /// - Signal3 workAreaMotionNotify; + SigC::Signal3 workAreaButtonRelease; /// - Signal0 workAreaFocus; + SigC::Signal3 workAreaMotionNotify; /// - Signal0 workAreaUnfocus; + SigC::Signal0 workAreaFocus; /// - Signal0 workAreaEnter; + SigC::Signal0 workAreaUnfocus; /// - Signal0 workAreaLeave; + SigC::Signal0 workAreaEnter; /// - Signal3 workAreaDoubleClick; + SigC::Signal0 workAreaLeave; /// - Signal3 workAreaTripleClick; + SigC::Signal3 workAreaDoubleClick; + /// + SigC::Signal3 workAreaTripleClick; + /// emitted when an X client has requested our selection + SigC::Signal0 selectionRequested; + /// emitted when another X client has stolen our selection + SigC::Signal0 selectionLost; + + /// handles SelectionRequest X Event, to fill the clipboard + int event_cb(XEvent * xev); private: /// void createPixmap(int, int); + /// FL_OBJECT * backgroundbox; - /// + /// FL_OBJECT * work_area; /// FL_OBJECT * scrollbar; /// - BufferView * owner_; + mutable FL_OBJECT * splash_; + /// + mutable FL_OBJECT * splash_text_; /// The pixmap overlay on the workarea Pixmap workareapixmap; /// Painter painter_; - /// - FL_OBJECT * figinset_canvas; + /// if we call redraw with true needed for locking-insets + bool screen_cleared; }; #endif