X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FMetricsInfo.cpp;h=ba5748d32da5cd7f33aefdd5983f1e809c7754e3;hb=4b7f1b3c3918cd32070c72b6d8e95a888981c7a2;hp=1c93af98188aae5fd543087c8afda07b2fed897e;hpb=09a0e37b15d99167e6320af56aa124aac3694dd4;p=lyx.git diff --git a/src/MetricsInfo.cpp b/src/MetricsInfo.cpp index 1c93af9818..ba5748d32d 100644 --- a/src/MetricsInfo.cpp +++ b/src/MetricsInfo.cpp @@ -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,12 +46,24 @@ 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), change_(), selected(false), full_repaint(true), background_color(Color_background) @@ -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,12 @@ ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const } +///////////////////////////////////////////////////////////////////////// +// +// ScriptChanger +// +///////////////////////////////////////////////////////////////////////// + Styles smallerScriptStyle(Styles st) { switch (st) { @@ -103,11 +126,17 @@ Styles smallerScriptStyle(Styles st) } } + ScriptChanger::ScriptChanger(MetricsBase & mb) : StyleChanger(mb, smallerScriptStyle(mb.style)) {} +///////////////////////////////////////////////////////////////////////// +// +// FracChanger +// +///////////////////////////////////////////////////////////////////////// Styles smallerFracStyle(Styles st) { @@ -129,12 +158,23 @@ 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) { @@ -149,9 +189,14 @@ ShapeChanger::~ShapeChanger() } +///////////////////////////////////////////////////////////////////////// +// +// StyleChanger +// +///////////////////////////////////////////////////////////////////////// StyleChanger::StyleChanger(MetricsBase & mb, Styles style) - : Changer(mb) + : Changer(mb) { static const int diff[4][4] = { { 0, 0, -3, -5 }, @@ -176,9 +221,14 @@ StyleChanger::~StyleChanger() } +///////////////////////////////////////////////////////////////////////// +// +// FontSetChanger +// +///////////////////////////////////////////////////////////////////////// FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name) - : Changer(mb) + : Changer(mb) { save_ = mb; FontSize oldsize = save_.font.size(); @@ -190,7 +240,7 @@ FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name) FontSetChanger::FontSetChanger(MetricsBase & mb, docstring const & name) - : Changer(mb) + : Changer(mb) { save_ = mb; FontSize oldsize = save_.font.size(); @@ -207,8 +257,14 @@ FontSetChanger::~FontSetChanger() } +///////////////////////////////////////////////////////////////////////// +// +// WidthChanger +// +///////////////////////////////////////////////////////////////////////// + WidthChanger::WidthChanger(MetricsBase & mb, int w) - : Changer(mb) + : Changer(mb) { save_ = mb; mb.textwidth = w; @@ -221,7 +277,11 @@ WidthChanger::~WidthChanger() } - +///////////////////////////////////////////////////////////////////////// +// +// ColorChanger +// +///////////////////////////////////////////////////////////////////////// ColorChanger::ColorChanger(FontInfo & font, string const & color) : Changer(font)