Jean-Marc Lasgouttes wrote:
> Angus> b m wrote:
>>> I have been a LyX user for many many years now and I would like to
>>> thank the developers for your dedication.
>>> 
>>> LyX used to have a block cursor, but in the Qt version now there is
>>> only a blinking line cursor. It is extremely hard to see the cursor
>>> on a page that is dense with equations. It would greatly enhance
>>> usability to add a block cursor.
> 
> Angus> I have to say that I too like emacs notion of a cursor. Looking
> Angus> at the code, it appears that all we are missing is a proper
> Angus> notion of 'width'. Ie, how wide the character embedded by the
> Angus> cursor actually is.
> 
> And then, wold the actual drawing of the cursor be easy?

It would need to redraw the current character with a 
LColor::cursor_background background color, that's all. This is the block 
of code that would be modified, which shows clearly the existing width 
kludge.

Angus


void QScreen::showCursor(int x, int y, int h, Cursor_Shape shape)
{
    cursor_x_ = x;
    cursor_y_ = y;
    cursor_h_ = h;

    switch (shape) {
        case BAR_SHAPE:
            cursor_w_ = 1;
            break;
        case L_SHAPE:
            cursor_w_ = cursor_h_ / 3;
            break;
        case REVERSED_L_SHAPE:
            cursor_w_ = cursor_h_ / 3;
            cursor_x_ = x - cursor_w_ + 1;
            break;
    }

    if (!nocursor_pixmap_.get()
        || cursor_w_ != nocursor_pixmap_->width()
        || cursor_h_ != nocursor_pixmap_->height()) {
        nocursor_pixmap_.reset(new QPixmap(cursor_w_, cursor_h_));
    }

    if (!qApp->focusWidget())
        return;

    // save old area
    bitBlt(nocursor_pixmap_.get(), 0, 0, owner_.getPixmap(),
        cursor_x_, cursor_y_, cursor_w_, cursor_h_);

    Painter & pain(owner_.getPainter());
    pain.start();
    pain.line(x, y, x, y + h - 1, LColor::cursor);

    switch (shape) {
        case BAR_SHAPE:
            break;
        case REVERSED_L_SHAPE:
        case L_SHAPE:
            pain.line(cursor_x_, y + h - 1, cursor_x_ + cursor_w_ - 1,
                y + h - 1, LColor::cursor);
            break;
    }

    pain.end();

    owner_.getContent()->repaint(
        cursor_x_, cursor_y_,
        cursor_w_, cursor_h_);
}


Reply via email to