2 * \file InsetPreview.cpp
\r
3 * This file is part of LyX, the document processor.
\r
4 * Licence details can be found in the file COPYING.
\r
6 * \author Vincent van Ravesteijn
\r
8 * Full author contact details are available in file CREDITS.
\r
12 #include "InsetPreview.h"
\r
15 #include "BufferParams.h"
\r
16 #include "BufferView.h"
\r
20 #include "MetricsInfo.h"
\r
21 #include "OutputParams.h"
\r
23 #include "frontends/Painter.h"
\r
25 #include "graphics/PreviewImage.h"
\r
29 using namespace std;
\r
34 InsetPreview::InsetPreview(Buffer * buf)
\r
36 preview_(new RenderPreview(this)), use_preview_(true)
\r
38 setAutoBreakRows(true);
\r
40 setFrameColor(Color_previewframe);
\r
44 InsetPreview::~InsetPreview()
\r
48 InsetPreview::InsetPreview(InsetPreview const & other)
\r
51 preview_.reset(new RenderPreview(*other.preview_, this));
\r
55 void InsetPreview::write(ostream & os) const
\r
57 os << "Preview" << "\n";
\r
62 void InsetPreview::addPreview(DocIterator const & inset_pos,
\r
63 graphics::PreviewLoader &) const
\r
65 preparePreview(inset_pos);
\r
69 void InsetPreview::preparePreview(DocIterator const & pos) const
\r
71 odocstringstream str;
\r
72 OutputParams runparams(&pos.buffer()->params().encoding());
\r
73 latex(str, runparams);
\r
74 docstring const snippet = str.str();
\r
75 preview_->addPreview(snippet, *pos.buffer());
\r
79 bool InsetPreview::previewState(BufferView * bv) const
\r
81 if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
\r
82 graphics::PreviewImage const * pimage =
\r
83 preview_->getPreviewImage(bv->buffer());
\r
84 return pimage && pimage->image();
\r
90 void InsetPreview::reloadPreview(DocIterator const & pos) const
\r
92 preparePreview(pos);
\r
93 preview_->startLoading(*pos.buffer());
\r
97 void InsetPreview::draw(PainterInfo & pi, int x, int y) const
\r
99 use_preview_ = previewState(pi.base.bv);
\r
101 if (use_preview_) {
\r
102 // one pixel gap in front
\r
103 preview_->draw(pi, x + 1 + TEXT_TO_INSET_OFFSET, y);
\r
104 setPosCache(pi, x, y);
\r
107 InsetText::draw(pi, x, y);
\r
111 void InsetPreview::edit(Cursor & cur, bool front, EntryDirection entry_from)
\r
114 InsetText::edit(cur, front, entry_from);
\r
118 Inset * InsetPreview::editXY(Cursor & cur, int x, int y)
\r
120 if (use_preview_) {
\r
121 edit(cur, true, ENTRY_DIRECTION_IGNORE);
\r
125 return InsetText::editXY(cur, x, y);
\r
129 void InsetPreview::metrics(MetricsInfo & mi, Dimension & dim) const
\r
131 if (previewState(mi.base.bv)) {
\r
132 preview_->metrics(mi, dim);
\r
133 mi.base.textwidth += 2 * TEXT_TO_INSET_OFFSET;
\r
135 dim.wid = max(dim.wid, 4);
\r
136 dim.asc = max(dim.asc, 4);
\r
138 dim.asc += TEXT_TO_INSET_OFFSET;
\r
139 dim.des += TEXT_TO_INSET_OFFSET;
\r
140 dim.wid += TEXT_TO_INSET_OFFSET;
\r
142 dim.wid += TEXT_TO_INSET_OFFSET;
\r
143 // insert a one pixel gap
\r
145 // Cache the inset dimension.
\r
146 setDimCache(mi, dim);
\r
147 Dimension dim_dummy;
\r
148 MetricsInfo mi_dummy = mi;
\r
149 InsetText::metrics(mi_dummy, dim_dummy);
\r
152 InsetText::metrics(mi, dim);
\r
156 bool InsetPreview::notifyCursorLeaves(Cursor const & old, Cursor & cur)
\r
158 reloadPreview(old);
\r
159 cur.screenUpdateFlags(Update::Force);
\r
160 return InsetText::notifyCursorLeaves(old, cur);
\r