X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FMetricsInfo.h;h=05acbbbb045b9f73cbd1608b66686e23498e9a7c;hb=4db3e641ed6765e005343010cb90ee8af26f8f99;hp=c82914d8f20512a85b97fd030ffebb34b1d2afba;hpb=e4808961c94b22cfa90ffb1e038a59e77dbb087e;p=lyx.git diff --git a/src/MetricsInfo.h b/src/MetricsInfo.h index c82914d8f2..05acbbbb04 100644 --- a/src/MetricsInfo.h +++ b/src/MetricsInfo.h @@ -4,7 +4,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 * \author Stefan Schimanski * * Full author contact details are available in file CREDITS. @@ -13,11 +13,11 @@ #ifndef METRICSINFO_H #define METRICSINFO_H +#include "Changes.h" #include "ColorCode.h" #include "FontInfo.h" #include "support/strfwd.h" -#include "support/types.h" #include @@ -102,14 +102,19 @@ public: /// \param sel whether to take the selection state into account ColorCode backgroundColor(Inset const * inset, bool sel = true) const; + /// Determines the text color based on the intended color, the + /// change tracking state and the selection state. + /// \param color what the color should be by default + Color textColor(Color const & color) const; + /// MetricsBase base; /// frontend::Painter & pain; /// Whether the text at this point is right-to-left (for InsetNewline) bool ltr_pos; - /// Whether the parent is deleted (change tracking) - bool erased_; + /// The change the parent is part of (change tracking) + Change change_; /// Whether the parent is selected as a whole bool selected; /// @@ -152,10 +157,15 @@ public: class FontSetChanger : public Changer { public: /// - FontSetChanger(MetricsBase & mb, docstring const & font); - FontSetChanger(MetricsBase & mb, char const * const font); + FontSetChanger(MetricsBase & mb, docstring const & font, + bool really_change_font = true); + FontSetChanger(MetricsBase & mb, char const * const font, + bool really_change_font = true); /// ~FontSetChanger(); +private: + /// + bool change_; }; @@ -216,12 +226,16 @@ public: // temporarily change the used color -class ColorChanger : public Changer { +class ColorChanger : public Changer { public: /// - ColorChanger(FontInfo & font, std::string const & color); + ColorChanger(FontInfo & font, ColorCode color, + bool really_change_color = true); /// ~ColorChanger(); +private: + /// + bool change_; }; } // namespace lyx