X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetcollapsable.C;h=3bc130945558ae3f71fca171c33886faac1d035e;hb=ee72ce87743857b4317da00e6e09cb6842095664;hp=5648e3c1ec06c43757fed2b1d295b94475e523c7;hpb=6661712fbce6fd1c2e67222d314503fa187248af;p=lyx.git diff --git a/src/insets/insetcollapsable.C b/src/insets/insetcollapsable.C index 5648e3c1ec..3bc1309455 100644 --- a/src/insets/insetcollapsable.C +++ b/src/insets/insetcollapsable.C @@ -19,6 +19,7 @@ #include "BufferView.h" #include "Painter.h" #include "support/LOstream.h" +#include "support/lstrings.h" using std::ostream; @@ -29,7 +30,7 @@ InsetCollapsable::InsetCollapsable() : InsetText() autocollapse = true; autoBreakRows = true; framecolor = LColor::footnoteframe; - widthOffset = 6; // 2+2 (behind+back), 1+1 (frame) + widthOffset = 2 * TEXT_TO_INSET_OFFSET + 2; // 1+1 (frame) button_length = button_top_y = button_bottom_y = 0; setInsetName("Collapsable"); } @@ -44,14 +45,11 @@ Inset * InsetCollapsable::Clone() const return result; } + void InsetCollapsable::Write(Buffer const * buf, ostream & os) const { - os << getInsetName() << "\n\ncollapsed "; - if (display()) - os << "false\n"; - else - os << "true\n"; - WriteParagraphData(buf, os); + os << "collapsed " << tostr(!display()) << "\n"; + WriteParagraphData(buf, os); } @@ -135,9 +133,11 @@ void InsetCollapsable::draw_collapsed(Painter & pain, LyXFont const & font, } -void InsetCollapsable::draw(Painter & pain, LyXFont const & f, - int baseline, float & x) const +void InsetCollapsable::draw(BufferView * bv, LyXFont const & f, + int baseline, float & x, bool cleared) const { + Painter & pain = bv->painter(); + button_length = width_collapsed(pain, labelfont) + 2; button_top_y = -ascent_collapsed(pain, f); button_bottom_y = descent_collapsed(pain, f); @@ -151,14 +151,12 @@ void InsetCollapsable::draw(Painter & pain, LyXFont const & f, draw_collapsed(pain, f, baseline, x); x -= TEXT_TO_INSET_OFFSET; - int w = InsetText::width(pain, f) + 2 * TEXT_TO_INSET_OFFSET; + int w = InsetText::width(pain, f) + (2 * TEXT_TO_INSET_OFFSET); int h = ascent(pain,f) + descent(pain, f); - - pain.rectangle(int(x), baseline - ascent(pain, f), w, h, framecolor); - + int save_x = static_cast(x); x += TEXT_TO_INSET_OFFSET; - drawTextXOffset = int(x) - top_x; - InsetText::draw(pain, f, baseline, x); + InsetText::draw(bv, f, baseline, x, cleared); + pain.rectangle(save_x, baseline - ascent(pain, f), w, h, framecolor); } @@ -166,7 +164,7 @@ void InsetCollapsable::Edit(BufferView * bv, int x, int y, unsigned int button) { if (collapsed && autocollapse) { collapsed = false; - UpdateLocal(bv, true); + UpdateLocal(bv, FULL, false); InsetText::Edit(bv, 0, 0, button); } else if (!collapsed) { InsetText::Edit(bv, x, y, button); @@ -188,13 +186,7 @@ void InsetCollapsable::InsetUnlock(BufferView * bv) collapsed = true; } InsetText::InsetUnlock(bv); - UpdateLocal(bv, false); -} - - -void InsetCollapsable::UpdateLocal(BufferView * bv, bool flag) -{ - InsetText::UpdateLocal(bv, flag); + UpdateLocal(bv, FULL, false); } @@ -214,10 +206,10 @@ void InsetCollapsable::InsetButtonRelease(BufferView * bv, if (collapsed) { collapsed = false; InsetText::InsetButtonRelease(bv, 0, 0, button); - UpdateLocal(bv, true); + UpdateLocal(bv, FULL, false); } else { collapsed = true; - UpdateLocal(bv, false); + UpdateLocal(bv, FULL, false); bv->unlockInset(this); } } else if (!collapsed && (x >= button_length) && (y >= button_top_y)) { @@ -256,3 +248,11 @@ int InsetCollapsable::getMaxTextWidth(Painter & pain, return getMaxWidth(pain, inset) - width_collapsed(pain, labelfont) - widthOffset; } + + +void InsetCollapsable::update(BufferView * bv, + LyXFont const & font, bool dodraw) +{ + drawTextXOffset = width_collapsed(bv->painter(), font); + InsetText::update(bv, font, dodraw); +}