X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FMetricsInfo.cpp;h=93782f94765882948b245d7959d7965796b44d00;hb=99174acff85c4db06e677b87e36a99d4a16dd967;hp=96f2fc709c6abd6416319d72a84081371432e57e;hpb=a9eb87a89d2ba1a492f2a01fc92e360e056bf2d6;p=lyx.git diff --git a/src/MetricsInfo.cpp b/src/MetricsInfo.cpp index 96f2fc709c..93782f9476 100644 --- a/src/MetricsInfo.cpp +++ b/src/MetricsInfo.cpp @@ -19,6 +19,7 @@ #include "mathed/MathSupport.h" +#include "frontends/FontMetrics.h" #include "frontends/Painter.h" #include "support/docstring.h" @@ -41,46 +42,72 @@ MetricsBase::MetricsBase(BufferView * b, FontInfo f, int w) textwidth(w), macro_nesting(0), solid_line_thickness_(1), solid_line_offset_(1), dotted_line_thickness_(1) { - if (lyxrc.zoom >= 200) { + if (lyxrc.currentZoom >= 200) { // derive the line thickness from zoom factor // the zoom is given in percent // (increase thickness at 250%, 450% etc.) - solid_line_thickness_ = (lyxrc.zoom + 150) / 200; + solid_line_thickness_ = (lyxrc.currentZoom + 150) / 200; // adjust line_offset_ too solid_line_offset_ = 1 + solid_line_thickness_ / 2; } - if (lyxrc.zoom >= 100) { + if (lyxrc.currentZoom >= 100) { // derive the line thickness from zoom factor // the zoom is given in percent // (increase thickness at 150%, 250% etc.) - dotted_line_thickness_ = (lyxrc.zoom + 50) / 100; + dotted_line_thickness_ = (lyxrc.currentZoom + 50) / 100; } } -Changer MetricsBase::changeFontSet(string const & name, bool cond) +Changer MetricsBase::changeFontSet(string const & name) { RefChanger rc = make_save(*this); - if (!cond) - rc->keep(); - else { - ColorCode oldcolor = font.color(); - string const oldname = fontname; - fontname = name; - if (isMathFont(name) || isMathFont(oldname)) - font = sane_font; - augmentFont(font, name); - font.setSize(rc->old.font.size()); - font.setStyle(rc->old.font.style()); - if (name != "lyxtex" - && ((isTextFont(oldname) && oldcolor != Color_foreground) - || (isMathFont(oldname) && oldcolor != Color_math))) - font.setColor(oldcolor); - } + ColorCode oldcolor = font.color(); + string const oldname = fontname; + fontname = name; + if (isMathFont(name) || isMathFont(oldname)) + font = sane_font; + augmentFont(font, name); + font.setSize(rc->old.font.size()); + font.setStyle(rc->old.font.style()); + if (name != "lyxtex" + && ((isTextFont(oldname) && oldcolor != Color_foreground) + || (isMathFont(oldname) && oldcolor != Color_math))) + font.setColor(oldcolor); return move(rc); } +Changer MetricsBase::changeEnsureMath(Inset::mode_type mode) +{ + switch (mode) { + case Inset::UNDECIDED_MODE: + return Changer(); + case Inset::TEXT_MODE: + return isMathFont(fontname) ? changeFontSet("textnormal") : Changer(); + case Inset::MATH_MODE: + // FIXME: + // \textit{\ensuremath{\text{a}}} + // should appear in italics + return isTextFont(fontname) ? changeFontSet("mathnormal"): Changer(); + } + return Changer(); +} + + +int MetricsBase::inPixels(Length const & len) const +{ + FontInfo fi = font; + if (len.unit() == Length::MU) + // mu is 1/18th of an em in the math symbol font + fi.setFamily(SYMBOL_FAMILY); + else + // Math style is only taken into account in the case of mu + fi.setStyle(LM_ST_TEXT); + return len.inPixels(textwidth, theFontMetrics(fi).em()); +} + + ///////////////////////////////////////////////////////////////////////// // // MetricsInfo @@ -144,7 +171,7 @@ ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const Color PainterInfo::textColor(Color const & color) const { - if (change_.changed()) + if (change_.changed()) return change_.color(); if (selected) return Color_selectiontext; @@ -152,35 +179,42 @@ Color PainterInfo::textColor(Color const & color) const } -Changer MetricsBase::changeScript(bool cond) +Changer MetricsBase::changeScript() { switch (font.style()) { case LM_ST_DISPLAY: case LM_ST_TEXT: - return font.changeStyle(LM_ST_SCRIPT, cond); + return font.changeStyle(LM_ST_SCRIPT); case LM_ST_SCRIPT: case LM_ST_SCRIPTSCRIPT: - return font.changeStyle(LM_ST_SCRIPTSCRIPT, cond); + return font.changeStyle(LM_ST_SCRIPTSCRIPT); } //remove Warning - LASSERT(false, return Changer()); + return Changer(); } -Changer MetricsBase::changeFrac(bool cond) +Changer MetricsBase::changeFrac() { switch (font.style()) { case LM_ST_DISPLAY: - return font.changeStyle(LM_ST_TEXT, cond); + return font.changeStyle(LM_ST_TEXT); case LM_ST_TEXT: - return font.changeStyle(LM_ST_SCRIPT, cond); + return font.changeStyle(LM_ST_SCRIPT); case LM_ST_SCRIPT: case LM_ST_SCRIPTSCRIPT: - return font.changeStyle(LM_ST_SCRIPTSCRIPT, cond); + return font.changeStyle(LM_ST_SCRIPTSCRIPT); } //remove Warning return Changer(); } +Changer MetricsBase::changeArray() +{ + return (font.style() == LM_ST_DISPLAY) ? font.changeStyle(LM_ST_TEXT) + : Changer(); +} + + } // namespace lyx