X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetcommand.C;h=69322ae8905cc40caa50164553a0d2bf939f3760;hb=3c8aba3b556871fb1100a2f98cd93d5d4e3f70c9;hp=1b0566ff05a9863baf56ab6d816120fab3836833;hpb=cfdd73ea94c3cc0058459d67b1c62fabd31fbeb1;p=lyx.git diff --git a/src/insets/insetcommand.C b/src/insets/insetcommand.C index 1b0566ff05..69322ae890 100644 --- a/src/insets/insetcommand.C +++ b/src/insets/insetcommand.C @@ -4,7 +4,7 @@ * LyX, The Document Processor * * Copyright 1995 Matthias Ettrich - * Copyright 1995-1999 The LyX Team. + * Copyright 1995-2000 The LyX Team. * * ====================================================== */ @@ -15,10 +15,13 @@ #endif #include "insetcommand.h" -#include "lyxdraw.h" #include "debug.h" #include "Painter.h" +using std::ostream; +using std::endl; + + InsetCommand::InsetCommand() { } @@ -31,130 +34,90 @@ InsetCommand::InsetCommand(string const & cmd, string const & arg, } -#ifdef USE_PAINTER -int InsetCommand::ascent(Painter &, LyXFont const & font) const -{ - LyXFont f = font; - f.decSize(); - return f.maxAscent() + 3; -} -#else -int InsetCommand::Ascent(LyXFont const & font) const -{ - LyXFont f = font; - f.decSize(); - return f.maxAscent() + 3; -} -#endif - - -#ifdef USE_PAINTER -int InsetCommand::descent(Painter &, LyXFont const & font) const +int InsetCommand::ascent(Painter & pain, LyXFont const &) const { - LyXFont f = font; - f.decSize(); - return f.maxDescent() + 3; -} -#else -int InsetCommand::Descent(LyXFont const & font) const -{ - LyXFont f = font; - f.decSize(); - return f.maxDescent() + 3; + LyXFont font(LyXFont::ALL_SANE); + font.decSize(); + + int width, ascent, descent; + string s = getScreenLabel(); + + if (Editable()) { + pain.buttonText(0, 0, s, font, + false, width, ascent, descent); + } else { + pain.rectText(0, 0, s, font, + LColor::commandbg, LColor::commandframe, + false, width, ascent, descent); + } + return ascent; } -#endif -#ifdef USE_PAINTER -int InsetCommand::width(Painter &, LyXFont const & font) const +int InsetCommand::descent(Painter & pain, LyXFont const &) const { - LyXFont f = font; - f.decSize(); - string s = getScreenLabel(); - return 10 + f.stringWidth(s); -} -#else -int InsetCommand::Width(LyXFont const & font) const -{ - LyXFont f = font; - f.decSize(); - string s = getScreenLabel(); - return 10 + f.stringWidth(s); + LyXFont font(LyXFont::ALL_SANE); + font.decSize(); + + int width, ascent, descent; + string s = getScreenLabel(); + + if (Editable()) { + pain.buttonText(0, 0, s, font, + false, width, ascent, descent); + } else { + pain.rectText(0, 0, s, font, + LColor::commandbg, LColor::commandframe, + false, width, ascent, descent); + } + return descent; } -#endif -#ifdef USE_PAINTER -void InsetCommand::draw(Painter & pain, LyXFont const & font, - int baseline, float & x) const +int InsetCommand::width(Painter & pain, LyXFont const &) const { - // Draw it as a box with the LaTeX text - x += 3; - - pain.fillRectangle(int(x), baseline - ascent(pain, font) + 1, - width(pain, font) - 6, - ascent(pain, font) + descent(pain, font) - 2, - LColor::insetbg); - // Tell whether this slows down the drawing (ale) - // lets draw editable and non-editable insets differently + LyXFont font(LyXFont::ALL_SANE); + font.decSize(); + + int width, ascent, descent; + string s = getScreenLabel(); + if (Editable()) { - int y = baseline - ascent(pain, font) + 1; - int w = width(pain, font) - 6; - int h = ascent(pain, font) + descent(pain, font) - 2; - pain.rectangle(int(x), y, w, h, LColor::insetframe); + pain.buttonText(0, 0, s, font, + false, width, ascent, descent); } else { - - pain.rectangle(int(x), baseline - ascent(pain, font) + 1, - width(pain, font) - 6, - ascent(pain, font) + descent(pain, font) - 2, - LColor::insetframe); + pain.rectText(0, 0, s, font, + LColor::commandbg, LColor::commandframe, + false, width, ascent, descent); } - string s = getScreenLabel(); - LyXFont f(font); - f.decSize(); - f.setColor(LColor::none); - f.setLatex(LyXFont::OFF); - pain.text(int(x + 2), baseline, s, f); - - x += width(pain, font) - 3; + return width + 4; } -#else -void InsetCommand::Draw(LyXFont font, LyXScreen & scr, - int baseline, float & x) + + +void InsetCommand::draw(Painter & pain, LyXFont const &, + int baseline, float & x) const { // Draw it as a box with the LaTeX text - x += 3; - - scr.fillRectangle(gc_lighted, - int(x), baseline - Ascent(font) + 1, - Width(font) - 6, - Ascent(font) + Descent(font)-2); - // Tell whether this slows down the drawing (ale) - // lets draw editable and non-editable insets differently - if (Editable()) { - int y = baseline - Ascent(font)+1, w = Width(font)-6, - h = (Ascent(font)+Descent(font)-2); - scr.drawFrame(FL_UP_FRAME, int(x), y, w, h, FL_BLACK, -1); + LyXFont font(LyXFont::ALL_SANE); + font.setColor(LColor::command).decSize(); + + int width; + string s = getScreenLabel(); + + if (Editable()) { + pain.buttonText(int(x)+2, baseline, s, font, true, width); } else { - scr.drawRectangle(gc_note_frame, - int(x), baseline - Ascent(font)+1, - Width(font)-6, - Ascent(font)+Descent(font)-2); + pain.rectText(int(x)+2, baseline, s, font, + LColor::commandbg, LColor::commandframe, + true, width); } - string s = getScreenLabel(); - LyXFont f = font; - f.decSize(); - f.setColor(LyXFont::NONE); - f.setLatex(LyXFont::OFF); - scr.drawString(f, s, baseline, int(x+2)); - x += Width(font) - 3; + x += width + 4; } -#endif // In lyxf3 this will be just LaTeX -void InsetCommand::Write(ostream & os) +void InsetCommand::Write(ostream & os) const { os << "LatexCommand " << getCommand() << "\n"; } @@ -234,27 +197,26 @@ void InsetCommand::Read(LyXLex & lex) } -int InsetCommand::Latex(ostream & os, signed char /*fragile*/) +int InsetCommand::Latex(ostream & os, bool /*fragile*/, bool/*fs*/) const { os << getCommand(); return 0; } -int InsetCommand::Latex(string & file, signed char /*fragile*/) +int InsetCommand::Ascii(ostream &) const { - file += getCommand(); return 0; } -int InsetCommand::Linuxdoc(string &/*file*/) +int InsetCommand::Linuxdoc(ostream &) const { return 0; } -int InsetCommand::DocBook(string &/*file*/) +int InsetCommand::DocBook(ostream &) const { return 0; }