]> git.lyx.org Git - lyx.git/blobdiff - src/MetricsInfo.cpp
Merge branch 'master' of git.lyx.org:lyx
[lyx.git] / src / MetricsInfo.cpp
index ff03e6214e8478cdcc604ad1b5b526218f442b5c..9f2baa81aa992ec5157c091b15b4d715629f4762 100644 (file)
@@ -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.
  */
 #include <config.h>
 
 #include "BufferView.h"
-#include "Color.h"
+#include "ColorSet.h"
+#include "LyXRC.h"
 #include "MetricsInfo.h"
 
+#include "insets/Inset.h"
+
 #include "mathed/MathSupport.h"
 
 #include "frontends/Painter.h"
 
-#include <boost/assert.hpp>
-
+#include "support/docstring.h"
+#include "support/lassert.h"
+#include "support/RefChanger.h"
 
-namespace lyx {
+using namespace std;
 
-using std::string;
-
-
-MetricsBase::MetricsBase()
-       : bv(0), font(), style(LM_ST_TEXT), fontname("mathnormal"),
-         textwidth(0)
-{}
 
+namespace lyx {
 
-MetricsBase::MetricsBase(BufferView * b, FontInfo const & f, int w)
-       : bv(b), font(f), style(LM_ST_TEXT), fontname("mathnormal"),
-         textwidth(w)
-{}
+/////////////////////////////////////////////////////////////////////////
+//
+// MetricsBase
+//
+/////////////////////////////////////////////////////////////////////////
+
+MetricsBase::MetricsBase(BufferView * b, FontInfo f, int w)
+       : bv(b), font(move(f)), style(LM_ST_TEXT), fontname("mathnormal"),
+         textwidth(w), solid_line_thickness_(1), solid_line_offset_(1),
+         dotted_line_thickness_(1)
+{
+       if (lyxrc.zoom >= 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 + 50) / 200;
+               // adjust line_offset_ too
+               solid_line_offset_ = 1 + solid_line_thickness_ / 2;
+       }
+       if (lyxrc.zoom >= 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;
+       }
+}
 
 
+Changer MetricsBase::changeFontSet(string const & name, bool cond)
+{
+       RefChanger<MetricsBase> rc = make_save(*this);
+       if (!cond)
+               rc->keep();
+       else {
+               ColorCode oldcolor = font.color();
+               string const oldname = fontname;
+               fontname = name;
+               font = sane_font;
+               augmentFont(font, name);
+               font.setSize(rc->old.font.size());
+               if (name != "lyxtex"
+                   && ((isTextFont(oldname) && oldcolor != Color_foreground)
+                       || (isMathFont(oldname) && oldcolor != Color_math)))
+                       font.setColor(oldcolor);
+       }
+       return move(rc);
+}
 
-MetricsInfo::MetricsInfo()
-{}
 
+/////////////////////////////////////////////////////////////////////////
+//
+// MetricsInfo
+//
+/////////////////////////////////////////////////////////////////////////
 
-MetricsInfo::MetricsInfo(BufferView * bv, FontInfo const & font, int textwidth)
-       : base(bv, font, textwidth)
+MetricsInfo::MetricsInfo(BufferView * bv, FontInfo 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,151 +117,91 @@ void PainterInfo::draw(int x, int y, docstring const & str)
 }
 
 
-Styles smallerScriptStyle(Styles st)
+ColorCode PainterInfo::backgroundColor(Inset const * inset, bool sel) const
 {
-       switch (st) {
-               case LM_ST_DISPLAY:
-               case LM_ST_TEXT:
-                       return LM_ST_SCRIPT;
-               case LM_ST_SCRIPT:
-               case LM_ST_SCRIPTSCRIPT:
-               default: // shut up compiler
-                       return LM_ST_SCRIPTSCRIPT;
+       ColorCode const color_bg = inset->backgroundColor(*this);
+
+       if (selected && sel)
+               // This inset is in a selection
+               return Color_selection;
+       else {
+               if (color_bg != Color_none)
+                       // This inset has its own color
+                       return color_bg;
+               else {
+                       if (background_color == Color_none)
+                               // This inset has no own color and does not inherit a color
+                               return Color_background;
+                       else
+                               // This inset has no own color, but inherits a color
+                               return background_color;
+               }
        }
 }
 
-ScriptChanger::ScriptChanger(MetricsBase & mb)
-       : StyleChanger(mb, smallerScriptStyle(mb.style))
-{}
-
-
 
-Styles smallerFracStyle(Styles st)
+Color PainterInfo::textColor(Color const & color) const
 {
-       switch (st) {
-               case LM_ST_DISPLAY:
-                       return LM_ST_TEXT;
-               case LM_ST_TEXT:
-                       return LM_ST_SCRIPT;
-               case LM_ST_SCRIPT:
-               case LM_ST_SCRIPTSCRIPT:
-               default: // shut up compiler
-                       return LM_ST_SCRIPTSCRIPT;
-       }
+       if (change_.changed()) 
+               return change_.color();
+       if (selected)
+               return Color_selectiontext;
+       return color;
 }
 
 
-FracChanger::FracChanger(MetricsBase & mb)
-       : StyleChanger(mb, smallerFracStyle(mb.style))
-{}
-
-
-
-ArrayChanger::ArrayChanger(MetricsBase & mb)
-       : StyleChanger(mb, mb.style == LM_ST_DISPLAY ? LM_ST_TEXT : mb.style)
-{}
-
-
-
-ShapeChanger::ShapeChanger(FontInfo & font, FontShape shape)
-       : Changer<FontInfo, FontShape>(font)
+Changer MetricsBase::changeScript(bool cond)
 {
-       save_ = orig_.shape();
-       orig_.setShape(shape);
+       switch (style) {
+       case LM_ST_DISPLAY:
+       case LM_ST_TEXT:
+               return changeStyle(LM_ST_SCRIPT, cond);
+       case LM_ST_SCRIPT:
+       case LM_ST_SCRIPTSCRIPT:
+               return changeStyle(LM_ST_SCRIPTSCRIPT, cond);
+       }
+       //remove Warning
+       LASSERT(false, return Changer());
 }
 
 
-ShapeChanger::~ShapeChanger()
+Changer MetricsBase::changeFrac(bool cond)
 {
-       orig_.setShape(save_);
+       switch (style) {
+       case LM_ST_DISPLAY:
+               return changeStyle(LM_ST_TEXT, cond);
+       case LM_ST_TEXT:
+               return changeStyle(LM_ST_SCRIPT, cond);
+       case LM_ST_SCRIPT:
+       case LM_ST_SCRIPTSCRIPT:
+               return changeStyle(LM_ST_SCRIPTSCRIPT, cond);
+       }
+       //remove Warning
+       return Changer();
 }
 
 
-
-StyleChanger::StyleChanger(MetricsBase & mb, Styles style)
-       :       Changer<MetricsBase>(mb)
+Changer MetricsBase::changeStyle(Styles new_style, bool cond)
 {
        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--)
-                       mb.font.incSize();
-       else
-               while (t++)
-                       mb.font.decSize();
-       mb.style = style;
-}
-
-
-StyleChanger::~StyleChanger()
-{
-       orig_ = save_;
-}
-
-
-
-FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name)
-       :       Changer<MetricsBase>(mb)
-{
-       save_ = mb;
-       FontSize oldsize = save_.font.size();
-       mb.fontname = name;
-       mb.font = sane_font;
-       augmentFont(mb.font, from_ascii(name));
-       mb.font.setSize(oldsize);
-}
-
-
-FontSetChanger::FontSetChanger(MetricsBase & mb, docstring const & name)
-       :       Changer<MetricsBase>(mb)
-{
-       save_ = mb;
-       FontSize oldsize = save_.font.size();
-       mb.fontname = to_utf8(name);
-       mb.font = sane_font;
-       augmentFont(mb.font, name);
-       mb.font.setSize(oldsize);
-}
-
-
-FontSetChanger::~FontSetChanger()
-{
-       orig_ = save_;
-}
-
-
-WidthChanger::WidthChanger(MetricsBase & mb, int w)
-       :       Changer<MetricsBase>(mb)
-{
-       save_ = mb;
-       mb.textwidth = w;
-}
-
-
-WidthChanger::~WidthChanger()
-{
-       orig_ = save_;
-}
-
-
-
-
-ColorChanger::ColorChanger(FontInfo & font, string const & color)
-       : Changer<FontInfo, string>(font)
-{
-       save_ = lcolor.getFromLyXName(color);
-       font.setColor(lcolor.getFromLyXName(color));
-}
-
-
-ColorChanger::~ColorChanger()
-{
-       orig_.setColor(lcolor.getFromLyXName(save_));
+       int t = diff[style][new_style];
+       RefChanger<MetricsBase> rc = make_save(*this);
+       if (!cond)
+               rc->keep();
+       else {
+               if (t > 0)
+                       while (t--)
+                               font.incSize();
+               else
+                       while (t++)
+                               font.decSize();
+               style = new_style;
+       }
+       return move(rc);
 }