mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-25 17:44:59 +00:00
7 out
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@5126 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
a1e77e762d
commit
b9d544874e
@ -40,6 +40,7 @@
|
|||||||
#include "ParagraphParameters.h"
|
#include "ParagraphParameters.h"
|
||||||
#include "undo_funcs.h"
|
#include "undo_funcs.h"
|
||||||
#include "funcrequest.h"
|
#include "funcrequest.h"
|
||||||
|
#include "box.h"
|
||||||
|
|
||||||
#include "insets/insetbib.h"
|
#include "insets/insetbib.h"
|
||||||
#include "insets/insettext.h"
|
#include "insets/insettext.h"
|
||||||
@ -110,6 +111,72 @@ boost::signals::connection kpresscon;
|
|||||||
boost::signals::connection selectioncon;
|
boost::signals::connection selectioncon;
|
||||||
boost::signals::connection lostcon;
|
boost::signals::connection lostcon;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the on-screen dimensions of the inset at the cursor.
|
||||||
|
* Pre-condition: the cursor must be at an inset.
|
||||||
|
*/
|
||||||
|
Box insetDimensions(BufferView * bv, LyXText const & text,
|
||||||
|
LyXCursor const & cursor)
|
||||||
|
{
|
||||||
|
Paragraph /*const*/ & par = *cursor.par();
|
||||||
|
pos_type const pos = cursor.pos();
|
||||||
|
|
||||||
|
lyx::Assert(par.getInset(pos));
|
||||||
|
|
||||||
|
Inset const & inset(*par.getInset(pos));
|
||||||
|
|
||||||
|
LyXFont const & font = text.getFont(bv->buffer(), &par, pos);
|
||||||
|
|
||||||
|
int const width = inset.width(bv, font);
|
||||||
|
int const inset_x = font.isVisibleRightToLeft()
|
||||||
|
? (cursor.ix() - width) : cursor.ix();
|
||||||
|
|
||||||
|
return Box(
|
||||||
|
inset_x + inset.scroll(),
|
||||||
|
inset_x + width,
|
||||||
|
cursor.iy() - inset.ascent(bv, font),
|
||||||
|
cursor.iy() + inset.descent(bv, font));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* check if the given co-ordinates are inside an inset at the
|
||||||
|
* given cursor, if one exists. If so, the inset is returned,
|
||||||
|
* and the co-ordinates are made relative. Otherwise, 0 is returned.
|
||||||
|
*/
|
||||||
|
Inset * checkInset(BufferView * bv, LyXText const & text,
|
||||||
|
LyXCursor const & cursor, int & x, int & y)
|
||||||
|
{
|
||||||
|
pos_type const pos = cursor.pos();
|
||||||
|
Paragraph /*const*/ & par(*cursor.par());
|
||||||
|
|
||||||
|
if (pos >= par.size() || !par.isInset(pos)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Inset /*const*/ * inset = par.getInset(pos);
|
||||||
|
|
||||||
|
if (!isEditableInset(inset))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
Box b = insetDimensions(bv, text, cursor);
|
||||||
|
|
||||||
|
if (!b.contained(x, y)) {
|
||||||
|
lyxerr[Debug::GUI] << "Missed inset at x,y " << x << "," << y
|
||||||
|
<< " box " << b << endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
text.setCursor(bv, &par, pos, true);
|
||||||
|
|
||||||
|
x -= b.x1;
|
||||||
|
// The origin of an inset is on the baseline
|
||||||
|
y -= text.cursor.iy();
|
||||||
|
|
||||||
|
return inset;
|
||||||
|
}
|
||||||
|
|
||||||
} // anon namespace
|
} // anon namespace
|
||||||
|
|
||||||
|
|
||||||
@ -801,63 +868,6 @@ void BufferView::Pimpl::workAreaButtonRelease(int x, int y,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Box BufferView::Pimpl::insetDimensions(LyXText const & text,
|
|
||||||
LyXCursor const & cursor) const
|
|
||||||
{
|
|
||||||
Paragraph /*const*/ & par = *cursor.par();
|
|
||||||
pos_type const pos = cursor.pos();
|
|
||||||
|
|
||||||
lyx::Assert(par.getInset(pos));
|
|
||||||
|
|
||||||
Inset const & inset(*par.getInset(pos));
|
|
||||||
|
|
||||||
LyXFont const & font = text.getFont(buffer_, &par, pos);
|
|
||||||
|
|
||||||
int const width = inset.width(bv_, font);
|
|
||||||
int const inset_x = font.isVisibleRightToLeft()
|
|
||||||
? (cursor.ix() - width) : cursor.ix();
|
|
||||||
|
|
||||||
return Box(
|
|
||||||
inset_x + inset.scroll(),
|
|
||||||
inset_x + width,
|
|
||||||
cursor.iy() - inset.ascent(bv_, font),
|
|
||||||
cursor.iy() + inset.descent(bv_, font));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Inset * BufferView::Pimpl::checkInset(LyXText const & text,
|
|
||||||
LyXCursor const & cursor,
|
|
||||||
int & x, int & y) const
|
|
||||||
{
|
|
||||||
pos_type const pos(cursor.pos());
|
|
||||||
Paragraph /*const*/ & par(*cursor.par());
|
|
||||||
|
|
||||||
if (pos >= par.size() || !par.isInset(pos)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Inset /*const*/ * inset = par.getInset(pos);
|
|
||||||
|
|
||||||
if (!isEditableInset(inset)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Box b(insetDimensions(text, cursor));
|
|
||||||
|
|
||||||
if (!b.contained(x, y)) {
|
|
||||||
lyxerr[Debug::GUI] << "Missed inset at x,y " << x << "," << y
|
|
||||||
<< " box " << b << endl;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
text.setCursor(bv_, &par, pos, true);
|
|
||||||
|
|
||||||
x -= b.x1;
|
|
||||||
// The origin of an inset is on the baseline
|
|
||||||
y -= text.cursor.iy();
|
|
||||||
|
|
||||||
return inset;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Inset * BufferView::Pimpl::checkInsetHit(LyXText * text, int & x, int & y)
|
Inset * BufferView::Pimpl::checkInsetHit(LyXText * text, int & x, int & y)
|
||||||
@ -867,7 +877,7 @@ Inset * BufferView::Pimpl::checkInsetHit(LyXText * text, int & x, int & y)
|
|||||||
LyXCursor cursor;
|
LyXCursor cursor;
|
||||||
text->setCursorFromCoordinates(bv_, cursor, x, y_tmp);
|
text->setCursorFromCoordinates(bv_, cursor, x, y_tmp);
|
||||||
|
|
||||||
Inset * inset = checkInset(*text, cursor, x, y_tmp);
|
Inset * inset = checkInset(bv_, *text, cursor, x, y_tmp);
|
||||||
|
|
||||||
if (inset) {
|
if (inset) {
|
||||||
y = y_tmp;
|
y = y_tmp;
|
||||||
@ -882,7 +892,7 @@ Inset * BufferView::Pimpl::checkInsetHit(LyXText * text, int & x, int & y)
|
|||||||
// move back one
|
// move back one
|
||||||
text->setCursor(bv_, cursor, cursor.par(), cursor.pos() - 1, true);
|
text->setCursor(bv_, cursor, cursor.par(), cursor.pos() - 1, true);
|
||||||
|
|
||||||
inset = checkInset(*text, cursor, x, y_tmp);
|
inset = checkInset(bv_, *text, cursor, x, y_tmp);
|
||||||
if (inset) {
|
if (inset) {
|
||||||
y = y_tmp;
|
y = y_tmp;
|
||||||
}
|
}
|
||||||
|
@ -15,8 +15,6 @@
|
|||||||
#include "frontends/key_state.h"
|
#include "frontends/key_state.h"
|
||||||
#include "frontends/mouse_state.h"
|
#include "frontends/mouse_state.h"
|
||||||
#include "frontends/LyXKeySym.h"
|
#include "frontends/LyXKeySym.h"
|
||||||
#include "box.h"
|
|
||||||
#include "insets/insetspecialchar.h"
|
|
||||||
#include "support/types.h"
|
#include "support/types.h"
|
||||||
|
|
||||||
#include <boost/scoped_ptr.hpp>
|
#include <boost/scoped_ptr.hpp>
|
||||||
@ -73,8 +71,7 @@ struct BufferView::Pimpl : public boost::signals::trackable {
|
|||||||
/// wheel mouse scroll
|
/// wheel mouse scroll
|
||||||
int scroll(long time);
|
int scroll(long time);
|
||||||
///
|
///
|
||||||
void workAreaKeyPress(LyXKeySymPtr key,
|
void workAreaKeyPress(LyXKeySymPtr key, key_modifier::state state);
|
||||||
key_modifier::state state);
|
|
||||||
///
|
///
|
||||||
void workAreaMotionNotify(int x, int y, mouse_button::state state);
|
void workAreaMotionNotify(int x, int y, mouse_button::state state);
|
||||||
///
|
///
|
||||||
@ -122,22 +119,8 @@ struct BufferView::Pimpl : public boost::signals::trackable {
|
|||||||
///
|
///
|
||||||
bool dispatch(FuncRequest const & ev);
|
bool dispatch(FuncRequest const & ev);
|
||||||
private:
|
private:
|
||||||
/**
|
|
||||||
* Return the on-screen dimensions of the inset at the cursor.
|
|
||||||
* Pre-condition: the cursor must be at an inset.
|
|
||||||
*/
|
|
||||||
Box insetDimensions(LyXText const & text, LyXCursor const & cursor) const;
|
|
||||||
/**
|
|
||||||
* check if the given co-ordinates are inside an inset at the
|
|
||||||
* given cursor, if one exists. If so, the inset is returned,
|
|
||||||
* and the co-ordinates are made relative. Otherwise, 0 is returned.
|
|
||||||
*/
|
|
||||||
Inset * checkInset(LyXText const & text, LyXCursor const & cursor,
|
|
||||||
int & x, int & y) const;
|
|
||||||
///
|
///
|
||||||
friend class BufferView;
|
friend class BufferView;
|
||||||
///
|
|
||||||
void hfill();
|
|
||||||
|
|
||||||
///
|
///
|
||||||
BufferView * bv_;
|
BufferView * bv_;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user