simplify rectText and buttonText add separate metric methods for these

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@2314 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Lars Gullik Bjønnes 2001-07-24 09:12:20 +00:00
parent c06a45c6e4
commit 94c00c08a8
10 changed files with 195 additions and 12 deletions

View File

@ -9,7 +9,6 @@ src/converter.C
src/CutAndPaste.C src/CutAndPaste.C
src/debug.C src/debug.C
src/exporter.C src/exporter.C
src/ext_l10n.h
src/figure_form.C src/figure_form.C
src/figureForm.C src/figureForm.C
src/FontLoader.C src/FontLoader.C

View File

@ -1,3 +1,13 @@
2001-07-24 Lars Gullik Bjønnes <larsbj@birdstep.com>
* text.C (getVisibleRow): adjust
* font.[Ch] (rectText): new method, metrics
(buttonText): new method, metrics
* PainterBase.[hC]: make rectText and buttonText always draw and take
fewer paramteres.
2001-07-22 Jean-Marc Lasgouttes <lasgouttes@lyx.org> 2001-07-22 Jean-Marc Lasgouttes <lasgouttes@lyx.org>
* ToolbarDefaults.C (read): * ToolbarDefaults.C (read):

View File

@ -90,6 +90,7 @@ PainterBase & PainterBase::buttonFrame(int x, int y, int w, int h)
} }
#if 0
PainterBase & PainterBase::rectText(int x, int baseline, PainterBase & PainterBase::rectText(int x, int baseline,
string const & str, string const & str,
LyXFont const & font, LyXFont const & font,
@ -97,17 +98,24 @@ PainterBase & PainterBase::rectText(int x, int baseline,
LColor::color frame, bool draw, LColor::color frame, bool draw,
int & width, int & ascent, int & descent) int & width, int & ascent, int & descent)
{ {
#if 0
static int const d = 2; static int const d = 2;
width = lyxfont::width(str, font) + d * 2 + 2; width = lyxfont::width(str, font) + d * 2 + 2;
ascent = lyxfont::maxAscent(font) + d; ascent = lyxfont::maxAscent(font) + d;
descent = lyxfont::maxDescent(font) + d; descent = lyxfont::maxDescent(font) + d;
#else
lyxfont::rectText(str, font, width, axcent, descent);
#endif
if (!draw) return *this; if (!draw) return *this;
rectangle(x, baseline - ascent, width, ascent + descent, frame); rectangle(x, baseline - ascent, width, ascent + descent, frame);
fillRectangle(x + 1, baseline - ascent + 1, width - 1, fillRectangle(x + 1, baseline - ascent + 1, width - 1,
ascent + descent - 1, back); ascent + descent - 1, back);
#if 0
text(x + d, baseline, str, font); text(x + d, baseline, str, font);
#else
text(x + 2, baseline, str, font);
#endif
return *this; return *this;
} }
@ -117,13 +125,50 @@ PainterBase & PainterBase::buttonText(int x, int baseline,
LyXFont const & font, bool draw, LyXFont const & font, bool draw,
int & width, int & ascent, int & descent) int & width, int & ascent, int & descent)
{ {
#if 0
width = lyxfont::width(str, font) + 8; width = lyxfont::width(str, font) + 8;
ascent = lyxfont::maxAscent(font) + 3; ascent = lyxfont::maxAscent(font) + 3;
descent = lyxfont::maxDescent(font) + 3; descent = lyxfont::maxDescent(font) + 3;
#else
lyxfont::buttonText(str, font, width, ascent, descent);
#endif
if (!draw) return *this; if (!draw) return *this;
button(x, baseline - ascent, width, descent + ascent); button(x, baseline - ascent, width, descent + ascent);
text(x + 4, baseline, str, font); text(x + 4, baseline, str, font);
return *this; return *this;
} }
#else
PainterBase & PainterBase::rectText(int x, int baseline,
string const & str,
LyXFont const & font,
LColor::color back,
LColor::color frame)
{
int width;
int ascent;
int descent;
lyxfont::rectText(str, font, width, ascent, descent);
rectangle(x, baseline - ascent, width, ascent + descent, frame);
fillRectangle(x + 1, baseline - ascent + 1, width - 1,
ascent + descent - 1, back);
text(x + 2, baseline, str, font);
return *this;
}
PainterBase & PainterBase::buttonText(int x, int baseline,
string const & str,
LyXFont const & font)
{
int width;
int ascent;
int descent;
lyxfont::buttonText(str, font, width, ascent, descent);
button(x, baseline - ascent, width, descent + ascent);
text(x + 4, baseline, str, font);
return *this;
}
#endif

View File

@ -162,6 +162,7 @@ public:
/// Draw a char at position x, y (y is the baseline) /// Draw a char at position x, y (y is the baseline)
virtual PainterBase & text(int x, int y, char c, LyXFont const & f)=0; virtual PainterBase & text(int x, int y, char c, LyXFont const & f)=0;
#if 0
/** Draws a string and encloses it inside a rectangle. Returns /** Draws a string and encloses it inside a rectangle. Returns
the size of the rectangle. If draw is false, we only calculate the size of the rectangle. If draw is false, we only calculate
the size. */ the size. */
@ -182,6 +183,22 @@ public:
int & width = PainterBase::dummy1, int & width = PainterBase::dummy1,
int & ascent = PainterBase::dummy2, int & ascent = PainterBase::dummy2,
int & descent = PainterBase::dummy3); int & descent = PainterBase::dummy3);
#else
/** Draws a string and encloses it inside a rectangle. Returns
the size of the rectangle. If draw is false, we only calculate
the size. */
PainterBase & rectText(int x, int baseline,
string const & string,
LyXFont const & font,
LColor::color back,
LColor::color frame);
/** Draw a string and encloses it inside a button frame. Returns
the size of the frame. If draw is false, we only calculate
the size. */
PainterBase & buttonText(int x, int baseline, string const & s,
LyXFont const & font);
#endif
protected: protected:
/// ///
WorkArea & owner; WorkArea & owner;

View File

@ -209,5 +209,26 @@ void lyxfont::XSetFont(Display * display, GC gc, LyXFont const & f)
::XSetFont(display, gc, getFontID(f)); ::XSetFont(display, gc, getFontID(f));
} }
void lyxfont::rectText(string const & str, LyXFont const & font,
int & width, int & ascent, int & descent)
{
static int const d = 2;
width = lyxfont::width(str, font) + d * 2 + 2;
ascent = lyxfont::maxAscent(font) + d;
descent = lyxfont::maxDescent(font) + d;
}
void lyxfont::buttonText(string const & str, LyXFont const & font,
int & width, int & ascent, int & descent)
{
width = lyxfont::width(str, font) + 8;
ascent = lyxfont::maxAscent(font) + 3;
descent = lyxfont::maxDescent(font) + 3;
}
//} // end of namespace font //} // end of namespace font
//} // end of namespace lyx //} // end of namespace lyx

View File

@ -78,6 +78,15 @@ struct lyxfont {
/// ///
static static
void XSetFont(Display * display, GC gc, LyXFont const & f); void XSetFont(Display * display, GC gc, LyXFont const & f);
// A couple of more high-level metrics
///
static
void rectText(string const & str, LyXFont const & font,
int & width, int & ascent, int & descent);
///
static
void buttonText(string const & str, LyXFont const & font,
int & width, int & ascent, int & descent);
}; };
//} // end of namespace font //} // end of namespace font

View File

@ -1,3 +1,9 @@
2001-07-24 Lars Gullik Bjønnes <larsbj@birdstep.com>
* insetcollapsable.C: adjust
* insetbutton.C: adjust
2001-07-23 Juergen Vigna <jug@sad.it> 2001-07-23 Juergen Vigna <jug@sad.it>
* insetcollapsable.h: removed widthCollapsed variable, LyXFont * insetcollapsable.h: removed widthCollapsed variable, LyXFont

View File

@ -20,6 +20,7 @@
#include "Painter.h" #include "Painter.h"
#include "support/LAssert.h" #include "support/LAssert.h"
#include "lyxfont.h" #include "lyxfont.h"
#include "font.h"
using std::ostream; using std::ostream;
using std::endl; using std::endl;
@ -37,6 +38,7 @@ int InsetButton::ascent(BufferView * bv, LyXFont const &) const
int descent; int descent;
string const s = getScreenLabel(); string const s = getScreenLabel();
#if 0
if (editable()) { if (editable()) {
bv->painter().buttonText(0, 0, s, font, bv->painter().buttonText(0, 0, s, font,
false, width, ascent, descent); false, width, ascent, descent);
@ -45,6 +47,13 @@ int InsetButton::ascent(BufferView * bv, LyXFont const &) const
LColor::commandbg, LColor::commandframe, LColor::commandbg, LColor::commandframe,
false, width, ascent, descent); false, width, ascent, descent);
} }
#else
if (editable()) {
lyxfont::buttonText(s, font, width, ascent, descent);
} else {
lyxfont::rectText(s, font, width, ascent, descent);
}
#endif
return ascent; return ascent;
} }
@ -61,6 +70,7 @@ int InsetButton::descent(BufferView * bv, LyXFont const &) const
int descent; int descent;
string const s = getScreenLabel(); string const s = getScreenLabel();
#if 0
if (editable()) { if (editable()) {
bv->painter().buttonText(0, 0, s, font, bv->painter().buttonText(0, 0, s, font,
false, width, ascent, descent); false, width, ascent, descent);
@ -69,6 +79,13 @@ int InsetButton::descent(BufferView * bv, LyXFont const &) const
LColor::commandbg, LColor::commandframe, LColor::commandbg, LColor::commandframe,
false, width, ascent, descent); false, width, ascent, descent);
} }
#else
if (editable()) {
lyxfont::buttonText(s, font, width, ascent, descent);
} else {
lyxfont::rectText(s, font, width, ascent, descent);
}
#endif
return descent; return descent;
} }
@ -85,6 +102,7 @@ int InsetButton::width(BufferView * bv, LyXFont const &) const
int descent; int descent;
string const s = getScreenLabel(); string const s = getScreenLabel();
#if 0
if (editable()) { if (editable()) {
bv->painter().buttonText(0, 0, s, font, bv->painter().buttonText(0, 0, s, font,
false, width, ascent, descent); false, width, ascent, descent);
@ -93,6 +111,13 @@ int InsetButton::width(BufferView * bv, LyXFont const &) const
LColor::commandbg, LColor::commandframe, LColor::commandbg, LColor::commandframe,
false, width, ascent, descent); false, width, ascent, descent);
} }
#else
if (editable()) {
lyxfont::buttonText(s, font, width, ascent, descent);
} else {
lyxfont::rectText(s, font, width, ascent, descent);
}
#endif
return width + 4; return width + 4;
} }
@ -107,9 +132,10 @@ void InsetButton::draw(BufferView * bv, LyXFont const &,
LyXFont font(LyXFont::ALL_SANE); LyXFont font(LyXFont::ALL_SANE);
font.setColor(LColor::command).decSize(); font.setColor(LColor::command).decSize();
int width;
string const s = getScreenLabel(); string const s = getScreenLabel();
#if 0
int width;
if (editable()) { if (editable()) {
pain.buttonText(int(x) + 2, baseline, s, font, true, width); pain.buttonText(int(x) + 2, baseline, s, font, true, width);
} else { } else {
@ -117,6 +143,18 @@ void InsetButton::draw(BufferView * bv, LyXFont const &,
LColor::commandbg, LColor::commandframe, LColor::commandbg, LColor::commandframe,
true, width); true, width);
} }
#else
if (editable()) {
pain.buttonText(int(x) + 2, baseline, s, font);
} else {
pain.rectText(int(x) + 2, baseline, s, font,
LColor::commandbg, LColor::commandframe);
}
#endif
#if 0
x += width + 4; x += width + 4;
#else
x += width(bv, font);
#endif
} }

View File

@ -24,6 +24,7 @@
#include "support/lstrings.h" #include "support/lstrings.h"
#include "debug.h" #include "debug.h"
#include "lyxtext.h" #include "lyxtext.h"
#include "font.h"
class LyXText; class LyXText;
@ -90,35 +91,50 @@ void InsetCollapsable::read(Buffer const * buf, LyXLex & lex)
} }
int InsetCollapsable::ascent_collapsed(Painter & pain) const //int InsetCollapsable::ascent_collapsed(Painter & pain) const
int InsetCollapsable::ascent_collapsed(Painter & /*pain*/) const
{ {
int width = 0; int width = 0;
int ascent = 0; int ascent = 0;
int descent = 0; int descent = 0;
#if 0
pain.buttonText(0, 0, draw_label, labelfont, false, pain.buttonText(0, 0, draw_label, labelfont, false,
width, ascent, descent); width, ascent, descent);
#else
lyxfont::buttonText(draw_label, labelfont, width, ascent, descent);
#endif
return ascent; return ascent;
} }
int InsetCollapsable::descent_collapsed(Painter & pain) const //int InsetCollapsable::descent_collapsed(Painter & pain) const
int InsetCollapsable::descent_collapsed(Painter & /*pain*/) const
{ {
int width = 0; int width = 0;
int ascent = 0; int ascent = 0;
int descent = 0; int descent = 0;
#if 0
pain.buttonText(0, 0, draw_label, labelfont, false, pain.buttonText(0, 0, draw_label, labelfont, false,
width, ascent, descent); width, ascent, descent);
#else
lyxfont::buttonText(draw_label, labelfont, width, ascent, descent);
#endif
return descent; return descent;
} }
int InsetCollapsable::width_collapsed(Painter & pain) const //int InsetCollapsable::width_collapsed(Painter & pain) const
int InsetCollapsable::width_collapsed(Painter & /*pain*/) const
{ {
int width; int width;
int ascent; int ascent;
int descent; int descent;
#if 0
pain.buttonText(TEXT_TO_INSET_OFFSET, 0, draw_label, labelfont, false, pain.buttonText(TEXT_TO_INSET_OFFSET, 0, draw_label, labelfont, false,
width, ascent, descent); width, ascent, descent);
#else
lyxfont::buttonText(draw_label, labelfont, width, ascent, descent);
#endif
return width + (2*TEXT_TO_INSET_OFFSET); return width + (2*TEXT_TO_INSET_OFFSET);
} }
@ -155,10 +171,19 @@ int InsetCollapsable::width(BufferView * bv, LyXFont const & font) const
void InsetCollapsable::draw_collapsed(Painter & pain, int baseline, float & x) const void InsetCollapsable::draw_collapsed(Painter & pain, int baseline, float & x) const
{ {
#if 0
int width = 0; int width = 0;
pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET, pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET,
baseline, draw_label, labelfont, true, width); baseline, draw_label, labelfont, true, width);
#else
pain.buttonText(int(x) + TEXT_TO_INSET_OFFSET,
baseline, draw_label, labelfont);
#endif
#if 0
x += width + TEXT_TO_INSET_OFFSET; x += width + TEXT_TO_INSET_OFFSET;
#else
x += width_collapsed(pain) + TEXT_TO_INSET_OFFSET;
#endif
} }

View File

@ -37,6 +37,7 @@
#include "language.h" #include "language.h"
#include "ParagraphParameters.h" #include "ParagraphParameters.h"
#include "undo_funcs.h" #include "undo_funcs.h"
#include "font.h"
using std::max; using std::max;
using std::min; using std::min;
@ -3152,12 +3153,18 @@ void LyXText::getVisibleRow(BufferView * bview, int y_offset, int x_offset,
y_offset + y_top + 2 * defaultHeight(), y_offset + y_top + 2 * defaultHeight(),
LColor::pagebreak, LColor::pagebreak,
Painter::line_onoffdash) Painter::line_onoffdash)
#if 0
.rectText(0, .rectText(0,
0, 0,
_("Page Break (top)"), _("Page Break (top)"),
pb_font, pb_font,
LColor::background, LColor::background,
LColor::background, false, w, a, d); LColor::background, false, w, a, d);
#else
;
lyxfont::rectText(_("Page Break (top)"), pb_font,
w, a, d);
#endif
pain.rectText((ww - w)/2, pain.rectText((ww - w)/2,
y_offset + y_top + 2 * defaultHeight() + d, y_offset + y_top + 2 * defaultHeight() + d,
_("Page Break (top)"), _("Page Break (top)"),
@ -3343,11 +3350,17 @@ void LyXText::getVisibleRow(BufferView * bview, int y_offset, int x_offset,
.line(0, y_place, ww, y_place, .line(0, y_place, ww, y_place,
LColor::pagebreak, LColor::pagebreak,
Painter::line_onoffdash) Painter::line_onoffdash)
#if 0
.rectText(0, 0, .rectText(0, 0,
_("Page Break (bottom)"), _("Page Break (bottom)"),
pb_font, pb_font,
LColor::background, LColor::background,
LColor::background, false, w, a, d); LColor::background, false, w, a, d);
#else
;
lyxfont::rectText(_("Page Break (bottom)"), pb_font,
w, a, d);
#endif
pain.rectText((ww - w) / 2, y_place + d, pain.rectText((ww - w) / 2, y_place + d,
_("Page Break (bottom)"), _("Page Break (bottom)"),
pb_font, pb_font,