lyx_mirror/src/mathed/math_binaryopinset.C

63 lines
1.2 KiB
C++
Raw Normal View History

#include <config.h>
#ifdef __GNUG__
#pragma implementation
#endif
#include "math_binaryopinset.h"
#include "frontends/Painter.h"
#include "support/LOstream.h"
#include "math_support.h"
#include "math_mathmlstream.h"
using std::max;
MathBinaryOpInset::MathBinaryOpInset(char op)
: MathNestInset(2), op_(op)
{}
MathInset * MathBinaryOpInset::clone() const
{
return new MathBinaryOpInset(*this);
}
int MathBinaryOpInset::opwidth() const
{
return mathed_char_width(LM_TC_CONST, mi_, op_);
}
void MathBinaryOpInset::metrics(MathMetricsInfo const & mi) const
{
mi_ = mi;
xcell(0).metrics(mi);
xcell(1).metrics(mi);
width_ = xcell(0).width() + xcell(1).width() + opwidth();
ascent_ = max(xcell(0).ascent(), xcell(1).ascent());
descent_ = max(xcell(0).descent(), xcell(1).descent());
}
void MathBinaryOpInset::draw(Painter & pain, int x, int y) const
{
xcell(0).draw(pain, x, y);
drawChar(pain, LM_TC_CONST, mi_, x + xcell(0).width() , y, op_);
xcell(1).draw(pain, x + width() - xcell(1).width(), y);
}
void MathBinaryOpInset::write(WriteStream & os) const
{
os << '{' << cell(0) << op_ << cell(1) << '}';
}
void MathBinaryOpInset::normalize(NormalStream & os) const
{
os << "[binop " << op_ << ' ' << cell(0) << ' ' << cell(1) << ']';
}