X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FMetricsInfo.cpp;h=71d7a39de1a75c4e356d1967a9fc3093d284bc11;hb=3628ceec480c3d8fa9673f80f781eb1153fb9e1f;hp=9b0a0d5aa10b854ad6cc57121a2edc30c89d2ee5;hpb=e4808961c94b22cfa90ffb1e038a59e77dbb087e;p=lyx.git diff --git a/src/MetricsInfo.cpp b/src/MetricsInfo.cpp index 9b0a0d5aa1..71d7a39de1 100644 --- a/src/MetricsInfo.cpp +++ b/src/MetricsInfo.cpp @@ -3,7 +3,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author André Pönitz + * \author André Pönitz * * Full author contact details are available in file CREDITS. */ @@ -11,7 +11,7 @@ #include #include "BufferView.h" -#include "Color.h" +#include "ColorSet.h" #include "MetricsInfo.h" #include "insets/Inset.h" @@ -21,13 +21,18 @@ #include "frontends/Painter.h" #include "support/docstring.h" - #include "support/lassert.h" using namespace std; + namespace lyx { +///////////////////////////////////////////////////////////////////////// +// +// MetricsBase +// +///////////////////////////////////////////////////////////////////////// MetricsBase::MetricsBase() : bv(0), font(), style(LM_ST_TEXT), fontname("mathnormal"), @@ -41,15 +46,27 @@ MetricsBase::MetricsBase(BufferView * b, FontInfo const & f, int w) {} +///////////////////////////////////////////////////////////////////////// +// +// MetricsInfo +// +///////////////////////////////////////////////////////////////////////// + MetricsInfo::MetricsInfo(BufferView * bv, FontInfo const & font, int textwidth, MacroContext const & mc) : base(bv, font, textwidth), macrocontext(mc) {} +///////////////////////////////////////////////////////////////////////// +// +// PainterInfo +// +///////////////////////////////////////////////////////////////////////// + PainterInfo::PainterInfo(BufferView * bv, lyx::frontend::Painter & painter) - : pain(painter), ltr_pos(false), erased_(false), full_repaint(true), - background_color(Color_background) + : pain(painter), ltr_pos(false), change_(), selected(false), + do_spellcheck(true), full_repaint(true), background_color(Color_background) { base.bv = bv; } @@ -69,7 +86,7 @@ void PainterInfo::draw(int x, int y, docstring const & str) ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const { - ColorCode const color_bg = inset->backgroundColor(); + ColorCode const color_bg = inset->backgroundColor(*this); if (selected && sel) // This inset is in a selection @@ -90,6 +107,22 @@ ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const } +Color PainterInfo::textColor(Color const & color) const +{ + if (change_.changed()) + return change_.color(); + if (selected) + return Color_selectiontext; + return color; +} + + +///////////////////////////////////////////////////////////////////////// +// +// ScriptChanger +// +///////////////////////////////////////////////////////////////////////// + Styles smallerScriptStyle(Styles st) { switch (st) { @@ -103,11 +136,17 @@ Styles smallerScriptStyle(Styles st) } } + ScriptChanger::ScriptChanger(MetricsBase & mb) : StyleChanger(mb, smallerScriptStyle(mb.style)) {} +///////////////////////////////////////////////////////////////////////// +// +// FracChanger +// +///////////////////////////////////////////////////////////////////////// Styles smallerFracStyle(Styles st) { @@ -129,16 +168,26 @@ FracChanger::FracChanger(MetricsBase & mb) {} +///////////////////////////////////////////////////////////////////////// +// +// ArrayChanger +// +///////////////////////////////////////////////////////////////////////// ArrayChanger::ArrayChanger(MetricsBase & mb) : StyleChanger(mb, mb.style == LM_ST_DISPLAY ? LM_ST_TEXT : mb.style) {} +///////////////////////////////////////////////////////////////////////// +// +// ShapeChanger +// +///////////////////////////////////////////////////////////////////////// + ShapeChanger::ShapeChanger(FontInfo & font, FontShape shape) - : Changer(font) + : Changer(font, font.shape()) { - save_ = orig_.shape(); orig_.setShape(shape); } @@ -149,16 +198,20 @@ ShapeChanger::~ShapeChanger() } +///////////////////////////////////////////////////////////////////////// +// +// StyleChanger +// +///////////////////////////////////////////////////////////////////////// StyleChanger::StyleChanger(MetricsBase & mb, Styles style) - : Changer(mb) + : Changer(mb) { static const int diff[4][4] = { { 0, 0, -3, -5 }, { 0, 0, -3, -5 }, { 3, 3, 0, -2 }, { 5, 5, 2, 0 } }; - save_ = mb; int t = diff[mb.style][style]; if (t > 0) while (t--) @@ -176,41 +229,70 @@ StyleChanger::~StyleChanger() } +///////////////////////////////////////////////////////////////////////// +// +// FontSetChanger +// +///////////////////////////////////////////////////////////////////////// -FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name) - : Changer(mb) +FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name, + bool really_change_font) + : Changer(mb), change_(really_change_font) { - save_ = mb; - FontSize oldsize = save_.font.size(); - mb.fontname = name; - mb.font = sane_font; - augmentFont(mb.font, from_ascii(name)); - mb.font.setSize(oldsize); + if (change_) { + FontSize oldsize = save_.font.size(); + ColorCode oldcolor = save_.font.color(); + docstring const oldname = from_ascii(save_.fontname); + mb.fontname = name; + if (isMathFont(from_ascii(name)) || isMathFont(oldname)) + mb.font = sane_font; + augmentFont(mb.font, from_ascii(name)); + mb.font.setSize(oldsize); + if (string(name) != "lyxtex" + && ((isTextFont(oldname) && oldcolor != Color_foreground) + || (isMathFont(oldname) && oldcolor != Color_math))) + mb.font.setColor(oldcolor); + } } -FontSetChanger::FontSetChanger(MetricsBase & mb, docstring const & name) - : Changer(mb) +FontSetChanger::FontSetChanger(MetricsBase & mb, docstring const & name, + bool really_change_font) + : Changer(mb), change_(really_change_font) { - save_ = mb; - FontSize oldsize = save_.font.size(); - mb.fontname = to_utf8(name); - mb.font = sane_font; - augmentFont(mb.font, name); - mb.font.setSize(oldsize); + if (change_) { + FontSize oldsize = save_.font.size(); + ColorCode oldcolor = save_.font.color(); + docstring const oldname = from_ascii(save_.fontname); + mb.fontname = to_utf8(name); + if (isMathFont(name) || isMathFont(oldname)) + mb.font = sane_font; + augmentFont(mb.font, name); + mb.font.setSize(oldsize); + if (name != "lyxtex" + && ((isTextFont(oldname) && oldcolor != Color_foreground) + || (isMathFont(oldname) && oldcolor != Color_math))) + mb.font.setColor(oldcolor); + } } FontSetChanger::~FontSetChanger() { - orig_ = save_; + if (change_) + orig_ = save_; } +///////////////////////////////////////////////////////////////////////// +// +// WidthChanger +// +///////////////////////////////////////////////////////////////////////// + WidthChanger::WidthChanger(MetricsBase & mb, int w) - : Changer(mb) + : Changer(mb) { - save_ = mb; mb.textwidth = w; } @@ -221,19 +303,26 @@ WidthChanger::~WidthChanger() } +///////////////////////////////////////////////////////////////////////// +// +// ColorChanger +// +///////////////////////////////////////////////////////////////////////// - -ColorChanger::ColorChanger(FontInfo & font, string const & color) - : Changer(font) +ColorChanger::ColorChanger(FontInfo & font, ColorCode color, + bool really_change_color) + : Changer(font, font.color()), change_(really_change_color) { - save_ = lcolor.getFromLyXName(color); - font.setColor(lcolor.getFromLyXName(color)); + if (change_) { + font.setColor(color); + } } ColorChanger::~ColorChanger() { - orig_.setColor(lcolor.getFromLyXName(save_)); + if (change_) + orig_.setColor(save_); }