X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FWorkArea.h;h=715f1f56e59b68a26958d310aa1f4dfd3a313acd;hb=98c966c64594611e469313314abd1e59524adb4a;hp=2dbfd3878346b37e432dd2ed0695a70a7e3eb973;hpb=82fa210ea8d38d51aafb131f10d843e27e056429;p=lyx.git diff --git a/src/WorkArea.h b/src/WorkArea.h index 2dbfd38783..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. * * ======================================================*/ @@ -18,41 +18,40 @@ #include +#include + #include FORMS_H_LOCATION #include "Painter.h" -class BufferView; - -#define USE_FL_SCROLLBAR 1 - +/// class WorkArea { public: /// - WorkArea(BufferView *, int xpos, int ypos, int width, int height); + WorkArea(int xpos, int ypos, int width, int height); /// ~WorkArea(); /// Painter & getPainter() { return painter_; } /// - unsigned int workWidth() const { return work_area->w; } + 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); /// void redraw() const { fl_redraw_object(work_area); fl_redraw_object(scrollbar); -#ifndef USE_FL_SCROLLBAR - fl_redraw_object(button_down); - fl_redraw_object(button_up); -#endif } /// void setFocus() const; @@ -72,11 +71,7 @@ public: void setScrollbar(double pos, double length_fraction) const; /// void setScrollbarValue(double y) const { -#ifdef USE_FL_SCROLLBAR fl_set_scrollbar_value(scrollbar, y); -#else - fl_set_slider_value(scrollbar, y); -#endif } /// void setScrollbarBounds(double, double) const; @@ -84,63 +79,79 @@ public: void setScrollbarIncrements(double inc) const; /// double getScrollbarValue() const { -#ifdef USE_FL_SCROLLBAR return fl_get_scrollbar_value(scrollbar); -#else - return fl_get_slider_value(scrollbar); -#endif } -#ifdef USE_FL_SCROLLBAR /// - std::pair getScrollbarBounds() const { + std::pair const getScrollbarBounds() const { std::pair p; fl_get_scrollbar_bounds(scrollbar, &p.first, &p.second); return p; } -#else - /// - std::pair getScrollbarBounds() const { - std::pair p; - fl_get_slider_bounds(scrollbar, &p.first, &p.second); - return p; - } -#endif /// Pixmap getPixmap() const { return workareapixmap; } /// xforms callback static int work_area_handler(FL_OBJECT *, int event, FL_Coord, FL_Coord, int /*key*/, void * xev); -#ifndef USE_FL_SCROLLBAR - /// xforms callback - static void up_cb(FL_OBJECT *, long); - /// xforms callback - static void down_cb(FL_OBJECT *, long); -#endif /// xforms callback static void scroll_cb(FL_OBJECT *, long); + /// a selection exists + void haveSelection(bool) const; + /// + string const getClipboard() const; + /// + void putClipboard(string const &) const; + // Signals + /// + SigC::Signal0 workAreaExpose; + /// + SigC::Signal1 scrollCB; + /// + SigC::Signal2 workAreaKeyPress; + /// + SigC::Signal3 workAreaButtonPress; + /// + SigC::Signal3 workAreaButtonRelease; + /// + SigC::Signal3 workAreaMotionNotify; + /// + SigC::Signal0 workAreaFocus; + /// + SigC::Signal0 workAreaUnfocus; + /// + SigC::Signal0 workAreaEnter; + /// + SigC::Signal0 workAreaLeave; + /// + 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; -#ifndef USE_FL_SCROLLBAR - /// - FL_OBJECT * button_down; /// - FL_OBJECT * button_up; -#endif + mutable FL_OBJECT * splash_; /// - BufferView * owner; + 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