X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetLine.cpp;h=70469be37a653028aa0f67696ded24e954e811a2;hb=b198a36a363bb6a084407d476942d68ef5fb5e86;hp=8b80f0d3ecbd29d96ae02bf665e030ae4e0109a1;hpb=66fa801e74e1775b31008df548332436ce79e2e1;p=lyx.git diff --git a/src/insets/InsetLine.cpp b/src/insets/InsetLine.cpp index 8b80f0d3ec..70469be37a 100644 --- a/src/insets/InsetLine.cpp +++ b/src/insets/InsetLine.cpp @@ -21,10 +21,10 @@ #include "FuncRequest.h" #include "FuncStatus.h" #include "LaTeXFeatures.h" -#include "Length.h" #include "MetricsInfo.h" -#include "OutputParams.h" +#include "output_docbook.h" #include "output_xhtml.h" +#include "texstream.h" #include "Text.h" #include "frontends/FontMetrics.h" @@ -33,6 +33,7 @@ #include "support/debug.h" #include "support/docstream.h" #include "support/gettext.h" +#include "support/Length.h" #include "support/lstrings.h" #include @@ -45,7 +46,7 @@ using frontend::Painter; InsetLine::InsetLine(Buffer * buf, InsetCommandParams const & p) - : InsetCommand(buf, p) + : InsetCommand(buf, p), height_(0), offset_(0) {} @@ -111,7 +112,7 @@ void InsetLine::metrics(MetricsInfo & mi, Dimension & dim) const int const max_width = mi.base.textwidth; Length const width(to_ascii(getParam("width"))); - dim.wid = width.inPixels(mi.base); + dim.wid = mi.base.inPixels(width); // assure that the line inset is not outside of the window // check that it doesn't exceed the outer boundary @@ -123,25 +124,14 @@ void InsetLine::metrics(MetricsInfo & mi, Dimension & dim) const dim.wid = max(minw, abs(dim.wid)); Length height = Length(to_ascii(getParam("height"))); - height_ = height.inPixels(mi.base); + height_ = mi.base.inPixels(height); // get the length of the parameters in pixels Length offset = Length(to_ascii(getParam("offset"))); - offset_ = offset.inPixels(mi.base); + offset_ = mi.base.inPixels(offset); dim.asc = max(fm.maxAscent(), offset_ + height_); dim.des = max(fm.maxDescent(), - offset_); - - // Cache the inset dimension - setDimCache(mi, dim); -} - - -Dimension const InsetLine::dimension(BufferView const & bv) const -{ - // We cannot use InsetCommand::dimension() as this returns the dimension - // of the button, which is not used here. - return Inset::dimension(bv); } @@ -150,16 +140,10 @@ void InsetLine::draw(PainterInfo & pi, int x, int y) const Dimension const dim = dimension(*pi.base.bv); // get the surrounding text color - Color Line_color = pi.base.font.realColor(); + Color line_color = pi.base.font.realColor(); // the offset is a vertical one - // the horizontal dimension must be corrected with the heigth because - // of left and right border of the painted line for big heigth. - pi.pain.line(x + height_/2 + 1, - y - offset_ - height_/2, - x + dim.wid - height_/2 - 2, - y - offset_ - height_/2, - Line_color, Painter::line_solid, float(height_)); + pi.pain.fillRectangle(x, y - offset_ - height_, dim.wid, height_, line_color); } @@ -193,16 +177,15 @@ int InsetLine::plaintext(odocstringstream & os, } -int InsetLine::docbook(odocstream & os, OutputParams const &) const +void InsetLine::docbook(XMLStream & xs, OutputParams const &) const { - os << '\n'; - return 0; + xs << xml::CR(); } -docstring InsetLine::xhtml(XHTMLStream & xs, OutputParams const &) const +docstring InsetLine::xhtml(XMLStream & xs, OutputParams const &) const { - xs << html::CompTag("hr") << html::CR(); + xs << xml::CompTag("hr") << xml::CR(); return docstring(); }