///
/// Copyright (C) 2004-2007 Andrej Vodopivec <andrejv@users.sourceforge.net>
///
/// This program is free software; you can redistribute it and/or modify
/// it under the terms of the GNU General Public License as published by
/// the Free Software Foundation; either version 2 of the License, or
/// (at your option) any later version.
///
/// This program is distributed in the hope that it will be useful,
/// but WITHOUT ANY WARRANTY; without even the implied warranty of
/// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
/// GNU General Public License for more details.
///
///
/// You should have received a copy of the GNU General Public License
/// along with this program; if not, write to the Free Software
/// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
///
#include "ExptCell.h"
#include "TextCell.h"
ExptCell::ExptCell() : MathCell()
{
m_baseCell = NULL;
m_powCell = NULL;
m_isMatrix = false;
m_exp = new TextCell(wxT("^"));
m_open = new TextCell(wxT("("));
m_close = new TextCell(wxT(")"));
}
MathCell* ExptCell::Copy(bool all)
{
ExptCell* tmp = new ExptCell;
CopyData(this, tmp);
tmp->SetBase(m_baseCell->Copy(true));
tmp->SetPower(m_powCell->Copy(true));
if (all && m_next != NULL)
tmp->AppendCell(m_next->Copy(all));
return tmp;
}
ExptCell::~ExptCell()
{
if (m_baseCell != NULL)
delete m_baseCell;
if (m_powCell != NULL)
delete m_powCell;
if (m_next != NULL)
delete m_next;
delete m_exp;
delete m_open;
delete m_close;
}
void ExptCell::Destroy()
{
if (m_baseCell != NULL)
delete m_baseCell;
if (m_powCell != NULL)
delete m_powCell;
m_baseCell = NULL;
m_powCell = NULL;
m_next = NULL;
}
void ExptCell::SetPower(MathCell *power)
{
if (power == NULL)
return ;
if (m_powCell != NULL)
delete m_powCell;
m_powCell = power;
if (!m_powCell->IsCompound())
{
m_open->m_isHidden = true;
m_close->m_isHidden = true;
}
m_last2 = power;
while (m_last2->m_next != NULL)
m_last2 = m_last2->m_next;
}
void ExptCell::SetBase(MathCell *base)
{
if (base == NULL)
return ;
if (m_baseCell != NULL)
delete m_baseCell;
m_baseCell = base;
m_last1 = base;
while (m_last1->m_next != NULL)
m_last1 = m_last1->m_next;
}
void ExptCell::RecalculateWidths(CellParser& parser, int fontsize, bool all)
{
double scale = parser.GetScale();
m_baseCell->RecalculateWidths(parser, fontsize, true);
if (m_isBroken)
m_powCell->RecalculateWidths(parser, fontsize, true);
else
m_powCell->RecalculateWidths(parser, MAX(8, fontsize - 3), true);
m_width = m_baseCell->GetFullWidth(scale) + m_powCell->GetFullWidth(scale) -
SCALE_PX(MC_TEXT_PADDING, scale);
m_exp->RecalculateWidths(parser, fontsize, true);
m_open->RecalculateWidths(parser, fontsize, true);
m_close->RecalculateWidths(parser, fontsize, true);
MathCell::RecalculateWidths(parser, fontsize, all);
}
void ExptCell::RecalculateSize(CellParser& parser, int fontsize, bool all)
{
double scale = parser.GetScale();
m_baseCell->RecalculateSize(parser, fontsize, true);
if (m_isBroken)
m_powCell->RecalculateSize(parser, fontsize, true);
else
m_powCell->RecalculateSize(parser, MAX(8, fontsize - 3), true);
m_height = m_baseCell->GetMaxHeight() + m_powCell->GetMaxHeight() -
SCALE_PX((8 * fontsize) / 10 + MC_EXP_INDENT, scale);
m_center = m_powCell->GetMaxHeight() + m_baseCell->GetMaxCenter() -
SCALE_PX((8 * fontsize) / 10 + MC_EXP_INDENT, scale);
m_exp->RecalculateSize(parser, fontsize, true);
m_open->RecalculateSize(parser, fontsize, true);
m_close->RecalculateSize(parser, fontsize, true);
MathCell::RecalculateSize(parser, fontsize, all);
}
void ExptCell::Draw(CellParser& parser, wxPoint point, int fontsize, bool all)
{
if (DrawThisCell(parser, point))
{
double scale = parser.GetScale();
wxPoint bs, pw;
bs.x = point.x;
bs.y = point.y;
m_baseCell->Draw(parser, bs, fontsize, true);
pw.x = point.x + m_baseCell->GetFullWidth(scale) - SCALE_PX(MC_TEXT_PADDING, scale);
pw.y = point.y - m_baseCell->GetMaxCenter() - m_powCell->GetMaxHeight()
+ m_powCell->GetMaxCenter() +
SCALE_PX((8 * fontsize) / 10 + MC_EXP_INDENT, scale);
m_powCell->Draw(parser, pw, MAX(8, fontsize - 3), true);
}
MathCell::Draw(parser, point, fontsize, all);
}
wxString ExptCell::ToString(bool all)
{
if (m_isBroken)
return wxEmptyString;
wxString s = m_baseCell->ToString(true) + wxT("^");
if (m_isMatrix)
s += wxT("^");
if (m_powCell->IsCompound())
s += wxT("(") + m_powCell->ToString(true) + wxT(")");
else
s += m_powCell->ToString(true);
s += MathCell::ToString(all);
return s;
}
wxString ExptCell::ToTeX(bool all)
{
if (m_isBroken)
return wxEmptyString;
wxString s = wxT("{") + m_baseCell->ToTeX(true) + wxT("}^{") +
m_powCell->ToTeX(true) + wxT("}");
s += MathCell::ToTeX(all);
return s;
}
wxString ExptCell::GetDiffPart()
{
wxString s(wxT(","));
if (m_baseCell != NULL)
s += m_baseCell->ToString(true);
s += wxT(",");
if (m_powCell != NULL)
s += m_powCell->ToString(true);
return s;
}
void ExptCell::SelectInner(wxRect& rect, MathCell **first, MathCell **last)
{
*first = NULL;
*last = NULL;
if (m_powCell->ContainsRect(rect))
m_powCell->SelectRect(rect, first, last);
else if (m_baseCell->ContainsRect(rect))
m_baseCell->SelectRect(rect, first, last);
if (*first == NULL || *last == NULL)
{
*first = this;
*last = this;
}
}
bool ExptCell::BreakUp()
{
if (!m_isBroken)
{
m_isBroken = true;
m_baseCell->m_previousToDraw = this;
m_last1->m_nextToDraw = m_exp;
m_exp->m_previousToDraw = m_last1;
m_exp->m_nextToDraw = m_open;
m_open->m_previousToDraw = m_exp;
m_open->m_nextToDraw = m_powCell;
m_powCell->m_previousToDraw = m_open;
m_last2->m_nextToDraw = m_close;
m_close->m_previousToDraw = m_last2;
m_close->m_nextToDraw = m_nextToDraw;
if (m_nextToDraw != NULL)
m_nextToDraw->m_previousToDraw = m_close;
m_nextToDraw = m_baseCell;
return true;
}
return false;
}
void ExptCell::Unbreak(bool all)
{
if (m_isBroken)
{
m_baseCell->Unbreak(true);
m_powCell->Unbreak(true);
}
MathCell::Unbreak(all);
}
syntax highlighted by Code2HTML, v. 0.9.1