mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-03 08:28:25 +00:00
When selecting text with the mouse, inset selection happens in the middle
This commit is contained in:
parent
86d9abeea7
commit
eb4a2a190f
@ -95,7 +95,7 @@ double Row::Element::pos2x(pos_type const i) const
|
||||
}
|
||||
|
||||
|
||||
pos_type Row::Element::x2pos(int &x) const
|
||||
pos_type Row::Element::x2pos(int &x, bool const select) const
|
||||
{
|
||||
//lyxerr << "x2pos: x=" << x << " w=" << width() << " " << *this;
|
||||
size_t i = 0;
|
||||
@ -112,17 +112,18 @@ pos_type Row::Element::x2pos(int &x) const
|
||||
x = isRTL() ? int(full_width()) : 0;
|
||||
break;
|
||||
case INSET:
|
||||
case SPACE:
|
||||
case SPACE: {
|
||||
int const boundary = select ? (full_width() + 1) / 2 : full_width();
|
||||
// those elements contain only one position. Round to
|
||||
// the closest side.
|
||||
if (x > full_width()) {
|
||||
if (x > boundary) {
|
||||
x = int(full_width());
|
||||
i = !isRTL();
|
||||
} else {
|
||||
x = 0;
|
||||
i = isRTL();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
//lyxerr << "=> p=" << pos + i << " x=" << x << endl;
|
||||
return pos + i;
|
||||
|
@ -80,12 +80,13 @@ public:
|
||||
/** Return position in pixels (from the left) of position
|
||||
* \param i in the row element.
|
||||
*/
|
||||
double pos2x(pos_type const i) const;
|
||||
double pos2x(pos_type i) const;
|
||||
/** Return character position that is the closest to
|
||||
* pixel position \param x. The value \param x is
|
||||
* adjusted to the actual pixel position.
|
||||
*/
|
||||
pos_type x2pos(int &x) const;
|
||||
* \param select if true, return the right edge when closer.
|
||||
*/
|
||||
pos_type x2pos(int & x, bool select = false) const;
|
||||
/** Break the element if possible, so that its width is less
|
||||
* than \param w. Returns true on success. When \param force
|
||||
* is true, the string is cut at any place, other wise it
|
||||
|
@ -1690,7 +1690,7 @@ void Text::dispatch(Cursor & cur, FuncRequest & cmd)
|
||||
int const wh = bv->workHeight();
|
||||
int const y = max(0, min(wh - 1, cmd.y()));
|
||||
|
||||
tm->setCursorFromCoordinates(cur, cmd.x(), y);
|
||||
tm->setCursorFromCoordinates(cur, cmd.x(), y, true);
|
||||
cur.setTargetX(cmd.x());
|
||||
// Don't allow selecting a separator inset
|
||||
if (cur.pos() && cur.paragraph().isEnvSeparator(cur.pos() - 1))
|
||||
|
@ -1094,7 +1094,7 @@ void TextMetrics::setRowHeight(Row & row) const
|
||||
// returns the column near the specified x-coordinate of the row
|
||||
// x is set to the real beginning of this column
|
||||
pos_type TextMetrics::getPosNearX(Row const & row, int & x,
|
||||
bool & boundary) const
|
||||
bool & boundary, bool const select) const
|
||||
{
|
||||
//LYXERR0("getPosNearX(" << x << ") row=" << row);
|
||||
/// For the main Text, it is possible that this pit is not
|
||||
@ -1124,7 +1124,7 @@ pos_type TextMetrics::getPosNearX(Row const & row, int & x,
|
||||
for ( ; cit != cend; ++cit) {
|
||||
if (w <= x && w + cit->full_width() > x) {
|
||||
int x_offset = int(x - w);
|
||||
pos = cit->x2pos(x_offset);
|
||||
pos = cit->x2pos(x_offset, select);
|
||||
x = int(x_offset + w);
|
||||
break;
|
||||
}
|
||||
@ -1382,7 +1382,8 @@ Inset * TextMetrics::editXY(Cursor & cur, int x, int y,
|
||||
}
|
||||
|
||||
|
||||
void TextMetrics::setCursorFromCoordinates(Cursor & cur, int const x, int const y)
|
||||
void TextMetrics::setCursorFromCoordinates(Cursor & cur, int const x,
|
||||
int const y, bool const select)
|
||||
{
|
||||
LASSERT(text_ == cur.text(), return);
|
||||
pit_type const pit = getPitNearY(y);
|
||||
@ -1409,7 +1410,7 @@ void TextMetrics::setCursorFromCoordinates(Cursor & cur, int const x, int const
|
||||
|
||||
bool bound = false;
|
||||
int xx = x;
|
||||
pos_type const pos = getPosNearX(row, xx, bound);
|
||||
pos_type const pos = getPosNearX(row, xx, bound, select);
|
||||
|
||||
LYXERR(Debug::DEBUG, "setting cursor pit: " << pit << " pos: " << pos);
|
||||
|
||||
|
@ -150,7 +150,8 @@ public:
|
||||
/// returns the position near the specified x-coordinate of the row.
|
||||
/// x is an absolute screen coord, it is set to the real beginning
|
||||
/// of this column. This takes in account horizontal cursor row scrolling.
|
||||
pos_type getPosNearX(Row const & row, int & x, bool & boundary) const;
|
||||
pos_type getPosNearX(Row const & row, int & x, bool & boundary,
|
||||
bool select = false) const;
|
||||
|
||||
/// returns pos in given par at given x coord.
|
||||
pos_type x2pos(pit_type pit, int row, int x) const;
|
||||
@ -188,7 +189,10 @@ public:
|
||||
|
||||
/// sets cursor only within this Text.
|
||||
/// x,y are screen coordinates
|
||||
void setCursorFromCoordinates(Cursor & cur, int x, int y);
|
||||
/// If select is true, move to the next position if closer to the right
|
||||
/// edge.
|
||||
void setCursorFromCoordinates(Cursor & cur, int x, int y,
|
||||
bool select = false);
|
||||
|
||||
///
|
||||
int cursorX(CursorSlice const & cursor, bool boundary) const;
|
||||
|
Loading…
Reference in New Issue
Block a user