Index: src/mathed/InsetMathHull.cpp

===================================================================
--- src/mathed/InsetMathHull.cpp	(revisione 34304)
+++ src/mathed/InsetMathHull.cpp	(copia locale)
@@ -328,6 +328,23 @@ docstring InsetMathHull::standardFont()
 }
 
 
+docstring InsetMathHull::standardColor() const
+{
+	docstring color;
+	switch (type_) {
+	case hullRegexp:
+		color = from_ascii("foreground");
+		break;
+	case hullNone:
+		color = from_ascii("foreground");
+		break;
+	default:
+		color = from_ascii("math");
+	}
+	return color;
+}
+
+
 bool InsetMathHull::previewState(BufferView * bv) const
 {
 	if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
@@ -417,8 +434,11 @@ void InsetMathHull::draw(PainterInfo & p
 		return;
 	}
 
+	bool const really_change_color = pi.base.font.color() == Color_none;
+	ColorChanger dummy0(pi.base.font, standardColor(), really_change_color);
 	FontSetChanger dummy1(pi.base, standardFont());
 	StyleChanger dummy2(pi.base, display() ? LM_ST_DISPLAY : LM_ST_TEXT);
+
 	InsetMathGrid::draw(pi, x + 1, y);
 
 	if (numberedType()) {
Index: src/mathed/MathSupport.cpp
===================================================================
--- src/mathed/MathSupport.cpp	(revisione 34311)
+++ src/mathed/MathSupport.cpp	(copia locale)
@@ -653,6 +653,13 @@ bool isMathFont(docstring const & name)
 }
 
 
+bool isTextFont(docstring const & name)
+{
+	fontinfo * f = lookupFont(name);
+	return f && f->color_ == Color_foreground;
+}
+
+
 FontInfo getFont(docstring const & name)
 {
 	FontInfo font;
Index: src/mathed/MathSupport.h
===================================================================
--- src/mathed/MathSupport.h	(revisione 34311)
+++ src/mathed/MathSupport.h	(copia locale)
@@ -51,6 +51,8 @@ bool isFontName(docstring const & name);
 
 bool isMathFont(docstring const & name);
 
+bool isTextFont(docstring const & name);
+
 // converts single cell to string
 docstring asString(MathData const & ar);
 // converts single inset to string
Index: src/mathed/InsetMathHull.h
===================================================================
--- src/mathed/InsetMathHull.h	(revisione 34304)
+++ src/mathed/InsetMathHull.h	(copia locale)
@@ -197,6 +197,8 @@ private:
 	void changeCols(col_type);
 	///
 	docstring standardFont() const;
+	///
+	docstring standardColor() const;
 	/// consistency check
 	void check() const;
 	/// can this change its number of rows?
Index: src/MetricsInfo.cpp
===================================================================
--- src/MetricsInfo.cpp	(revisione 34312)
+++ src/MetricsInfo.cpp	(copia locale)
@@ -235,11 +235,15 @@ FontSetChanger::FontSetChanger(MetricsBa
 		save_ = mb;
 		FontSize oldsize = save_.font.size();
 		ColorCode oldcolor = save_.font.color();
+		docstring const oldname = from_ascii(save_.fontname);
 		mb.fontname = name;
 		mb.font = sane_font;
 		augmentFont(mb.font, from_ascii(name));
 		mb.font.setSize(oldsize);
-		mb.font.setColor(oldcolor);
+		if (string(name) != "lyxtex"
+		    && ((isTextFont(oldname) && oldcolor != Color_foreground)
+			|| (isMathFont(oldname) && oldcolor != Color_math)))
+			mb.font.setColor(oldcolor);
 	}
 }
 
@@ -252,11 +256,15 @@ FontSetChanger::FontSetChanger(MetricsBa
 		save_ = mb;
 		FontSize oldsize = save_.font.size();
 		ColorCode oldcolor = save_.font.color();
+		docstring const oldname = from_ascii(save_.fontname);
 		mb.fontname = to_utf8(name);
 		mb.font = sane_font;
 		augmentFont(mb.font, name);
 		mb.font.setSize(oldsize);
-		mb.font.setColor(oldcolor);
+		if (name != "lyxtex"
+		    && ((isTextFont(oldname) && oldcolor != Color_foreground)
+			|| (isMathFont(oldname) && oldcolor != Color_math)))
+			mb.font.setColor(oldcolor);
 	}
 }
 
@@ -294,17 +302,21 @@ WidthChanger::~WidthChanger()
 //
 /////////////////////////////////////////////////////////////////////////
 
-ColorChanger::ColorChanger(FontInfo & font, string const & color)
-	: Changer<FontInfo, string>(font)
+ColorChanger::ColorChanger(FontInfo & font, docstring const & color,
+			   bool really_change_color)
+	: Changer<FontInfo, ColorCode>(font), change_(really_change_color)
 {
-	save_ = lcolor.getFromLyXName(color);
-	font.setColor(lcolor.getFromLyXName(color));
+	if (change_) {
+		save_ = font.color();
+		font.setColor(lcolor.getFromLyXName(to_utf8(color)));
+	}
 }
 
 
 ColorChanger::~ColorChanger()
 {
-	orig_.setColor(lcolor.getFromLyXName(save_));
+	if (change_)
+		orig_.setColor(save_);
 }
 
 
Index: src/MetricsInfo.h
===================================================================
--- src/MetricsInfo.h	(revisione 34312)
+++ src/MetricsInfo.h	(copia locale)
@@ -222,12 +222,16 @@ public:
 
 
 // temporarily change the used color
-class ColorChanger : public Changer<FontInfo, std::string> {
+class ColorChanger : public Changer<FontInfo, ColorCode> {
 public:
 	///
-	ColorChanger(FontInfo & font, std::string const & color);
+	ColorChanger(FontInfo & font, docstring const & color,
+		     bool really_change_color = true);
 	///
 	~ColorChanger();
+private:
+	///
+	bool change_;
 };
 
 } // namespace lyx


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@34320 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Enrico Forestieri 2010-04-28 01:40:11 +00:00
parent 7d834d2568
commit 6c33aa2e5b
6 changed files with 56 additions and 9 deletions

View File

@ -235,11 +235,15 @@ FontSetChanger::FontSetChanger(MetricsBase & mb, char const * name,
save_ = mb; save_ = mb;
FontSize oldsize = save_.font.size(); FontSize oldsize = save_.font.size();
ColorCode oldcolor = save_.font.color(); ColorCode oldcolor = save_.font.color();
docstring const oldname = from_ascii(save_.fontname);
mb.fontname = name; mb.fontname = name;
mb.font = sane_font; mb.font = sane_font;
augmentFont(mb.font, from_ascii(name)); augmentFont(mb.font, from_ascii(name));
mb.font.setSize(oldsize); mb.font.setSize(oldsize);
mb.font.setColor(oldcolor); if (string(name) != "lyxtex"
&& ((isTextFont(oldname) && oldcolor != Color_foreground)
|| (isMathFont(oldname) && oldcolor != Color_math)))
mb.font.setColor(oldcolor);
} }
} }
@ -252,11 +256,15 @@ FontSetChanger::FontSetChanger(MetricsBase & mb, docstring const & name,
save_ = mb; save_ = mb;
FontSize oldsize = save_.font.size(); FontSize oldsize = save_.font.size();
ColorCode oldcolor = save_.font.color(); ColorCode oldcolor = save_.font.color();
docstring const oldname = from_ascii(save_.fontname);
mb.fontname = to_utf8(name); mb.fontname = to_utf8(name);
mb.font = sane_font; mb.font = sane_font;
augmentFont(mb.font, name); augmentFont(mb.font, name);
mb.font.setSize(oldsize); mb.font.setSize(oldsize);
mb.font.setColor(oldcolor); if (name != "lyxtex"
&& ((isTextFont(oldname) && oldcolor != Color_foreground)
|| (isMathFont(oldname) && oldcolor != Color_math)))
mb.font.setColor(oldcolor);
} }
} }
@ -294,17 +302,21 @@ WidthChanger::~WidthChanger()
// //
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
ColorChanger::ColorChanger(FontInfo & font, string const & color) ColorChanger::ColorChanger(FontInfo & font, docstring const & color,
: Changer<FontInfo, string>(font) bool really_change_color)
: Changer<FontInfo, ColorCode>(font), change_(really_change_color)
{ {
save_ = lcolor.getFromLyXName(color); if (change_) {
font.setColor(lcolor.getFromLyXName(color)); save_ = font.color();
font.setColor(lcolor.getFromLyXName(to_utf8(color)));
}
} }
ColorChanger::~ColorChanger() ColorChanger::~ColorChanger()
{ {
orig_.setColor(lcolor.getFromLyXName(save_)); if (change_)
orig_.setColor(save_);
} }

View File

@ -222,12 +222,16 @@ public:
// temporarily change the used color // temporarily change the used color
class ColorChanger : public Changer<FontInfo, std::string> { class ColorChanger : public Changer<FontInfo, ColorCode> {
public: public:
/// ///
ColorChanger(FontInfo & font, std::string const & color); ColorChanger(FontInfo & font, docstring const & color,
bool really_change_color = true);
/// ///
~ColorChanger(); ~ColorChanger();
private:
///
bool change_;
}; };
} // namespace lyx } // namespace lyx

View File

@ -328,6 +328,23 @@ docstring InsetMathHull::standardFont() const
} }
docstring InsetMathHull::standardColor() const
{
docstring color;
switch (type_) {
case hullRegexp:
color = from_ascii("foreground");
break;
case hullNone:
color = from_ascii("foreground");
break;
default:
color = from_ascii("math");
}
return color;
}
bool InsetMathHull::previewState(BufferView * bv) const bool InsetMathHull::previewState(BufferView * bv) const
{ {
if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) { if (!editing(bv) && RenderPreview::status() == LyXRC::PREVIEW_ON) {
@ -417,8 +434,11 @@ void InsetMathHull::draw(PainterInfo & pi, int x, int y) const
return; return;
} }
bool const really_change_color = pi.base.font.color() == Color_none;
ColorChanger dummy0(pi.base.font, standardColor(), really_change_color);
FontSetChanger dummy1(pi.base, standardFont()); FontSetChanger dummy1(pi.base, standardFont());
StyleChanger dummy2(pi.base, display() ? LM_ST_DISPLAY : LM_ST_TEXT); StyleChanger dummy2(pi.base, display() ? LM_ST_DISPLAY : LM_ST_TEXT);
InsetMathGrid::draw(pi, x + 1, y); InsetMathGrid::draw(pi, x + 1, y);
if (numberedType()) { if (numberedType()) {

View File

@ -197,6 +197,8 @@ private:
void changeCols(col_type); void changeCols(col_type);
/// ///
docstring standardFont() const; docstring standardFont() const;
///
docstring standardColor() const;
/// consistency check /// consistency check
void check() const; void check() const;
/// can this change its number of rows? /// can this change its number of rows?

View File

@ -653,6 +653,13 @@ bool isMathFont(docstring const & name)
} }
bool isTextFont(docstring const & name)
{
fontinfo * f = lookupFont(name);
return f && f->color_ == Color_foreground;
}
FontInfo getFont(docstring const & name) FontInfo getFont(docstring const & name)
{ {
FontInfo font; FontInfo font;

View File

@ -51,6 +51,8 @@ bool isFontName(docstring const & name);
bool isMathFont(docstring const & name); bool isMathFont(docstring const & name);
bool isTextFont(docstring const & name);
// converts single cell to string // converts single cell to string
docstring asString(MathData const & ar); docstring asString(MathData const & ar);
// converts single inset to string // converts single inset to string