#include "BufferView.h"
#include "buffer.h"
#include "bufferparams.h"
+#include "coordcache.h"
#include "cursor.h"
#include "debug.h"
#include "language.h"
#include "rowpainter.h"
#include "version.h"
-#include "insets/updatableinset.h"
-
#include "graphics/GraphicsImage.h"
#include "graphics/GraphicsLoader.h"
void LyXScreen::showCursor(BufferView & bv)
{
- // this is needed to make sure we copy back the right
- // pixmap on the hide for the Qt frontend
- lyx_gui::sync_events();
-
if (cursor_visible_)
return;
if (realfont.language() == latex_language)
shape = BAR_SHAPE;
- int ascent, descent;
- bv.cursor().getDim(ascent, descent);
- int h = ascent + descent;
+ LyXFont const font = bv.cursor().getFont();
+ int const asc = font_metrics::maxAscent(font);
+ int const des = font_metrics::maxDescent(font);
+ int h = asc + des;
int x = 0;
int y = 0;
bv.cursor().getPos(x, y);
- y -= ascent;
+ y -= asc;
//lyxerr << "LyXScreen::showCursor x: " << x << " y: " << y << endl;
- // if it doesn't fit entirely on the screen, don't try to show it
- if (y < 0 || y + h > workarea().workHeight())
+ // if it doesn't touch the screen, don't try to show it
+ if (y + h < 0 || y >= workarea().workHeight())
return;
cursor_visible_ = true;
}
+void LyXScreen::prepareCursor()
+{
+ cursor_visible_ = false;
+}
+
+
void LyXScreen::redraw(BufferView & bv, ViewMetricsInfo const & vi)
{
greyed_out_ = false;
workarea().getPainter().start();
- hideCursor();
paintText(bv, vi);
lyxerr[Debug::DEBUG] << "Redraw screen" << endl;
expose(0, 0, workarea().workWidth(), workarea().workHeight());
workarea().getPainter().end();
- showCursor(bv);
+ theCoords.doneUpdating();
}