Files
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

693 lines
20 KiB
C++

#include "CtrlCommon.h"
#include "../Common/Common.h"
#include <climits>
#include <iostream>
#include <ostream>
#include "CapParagraph.h"
#include "../Common/NodeNames.h"
namespace HWP
{
EVertAlign GetVertAlign(int nValue)
{
SWITCH(EVertAlign, nValue)
{
DEFAULT(EVertAlign::TOP);
CASE(EVertAlign::CENTER);
CASE(EVertAlign::BOTTOM);
CASE(EVertAlign::INSIDE);
CASE(EVertAlign::OUTSIDE);
}
}
EVertAlign GetVertAlign(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Top, eType) == sValue)
return EVertAlign::TOP;
if (GetValueName(EValue::Center, eType) == sValue)
return EVertAlign::CENTER;
if (GetValueName(EValue::Bottom, eType) == sValue)
return EVertAlign::BOTTOM;
if (GetValueName(EValue::Inside, eType) == sValue)
return EVertAlign::INSIDE;
if (GetValueName(EValue::Outside, eType) == sValue)
return EVertAlign::OUTSIDE;
return EVertAlign::TOP;
}
EVRelTo GetVRelTo(int nValue)
{
SWITCH(EVRelTo, nValue)
{
CASE(EVRelTo::PARA);
CASE(EVRelTo::PAGE);
DEFAULT(EVRelTo::PAPER);
}
}
EVRelTo GetVRelTo(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Para, eType) == sValue)
return EVRelTo::PARA;
if (GetValueName(EValue::Page, eType) == sValue)
return EVRelTo::PAGE;
if (GetValueName(EValue::Paper, eType) == sValue)
return EVRelTo::PAPER;
return EVRelTo::PARA;
}
EHRelTo GetHRelTo(int nValue)
{
SWITCH(EHRelTo, nValue)
{
CASE(EHRelTo::PAGE);
CASE(EHRelTo::PARA);
CASE(EHRelTo::COLUMN);
DEFAULT(EHRelTo::PAPER);
}
}
EHRelTo GetHRelTo(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Para, eType) == sValue)
return EHRelTo::PARA;
if (GetValueName(EValue::Page, eType) == sValue)
return EHRelTo::PAGE;
if (GetValueName(EValue::Column, eType) == sValue)
return EHRelTo::COLUMN;
if (GetValueName(EValue::Paper, eType) == sValue)
return EHRelTo::PAPER;
return EHRelTo::PARA;
}
EWidthRelTo GetWidthRelTo(int nValue)
{
SWITCH(EWidthRelTo, nValue)
{
CASE(EWidthRelTo::PAGE);
CASE(EWidthRelTo::PARA);
CASE(EWidthRelTo::COLUMN);
CASE(EWidthRelTo::ABSOLUTE);
DEFAULT(EWidthRelTo::PAPER);
}
}
EWidthRelTo GetWidthRelTo(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Para, eType) == sValue)
return EWidthRelTo::PARA;
if (GetValueName(EValue::Page, eType) == sValue)
return EWidthRelTo::PAGE;
if (GetValueName(EValue::Column, eType) == sValue)
return EWidthRelTo::COLUMN;
if (GetValueName(EValue::Paper, eType) == sValue)
return EWidthRelTo::PAPER;
if (GetValueName(EValue::Absolute, eType) == sValue)
return EWidthRelTo::ABSOLUTE;
return EWidthRelTo::PARA;
}
EHeightRelTo GetHeightRelTo(int nValue)
{
SWITCH(EHeightRelTo, nValue)
{
CASE(EHeightRelTo::PAGE);
CASE(EHeightRelTo::ABSOLUTE);
DEFAULT(EHeightRelTo::PAPER);
}
}
EHeightRelTo GetHeightRelTo(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Page, eType) == sValue)
return EHeightRelTo::PAGE;
if (GetValueName(EValue::Paper, eType) == sValue)
return EHeightRelTo::PAPER;
if (GetValueName(EValue::Absolute, eType) == sValue)
return EHeightRelTo::ABSOLUTE;
return EHeightRelTo::PAGE;
}
EHorzAlign GetHorzAlign(int nValue)
{
SWITCH(EHorzAlign, nValue)
{
CASE(EHorzAlign::CENTER);
CASE(EHorzAlign::RIGHT);
CASE(EHorzAlign::INSIDE);
CASE(EHorzAlign::OUTSIDE);
DEFAULT(EHorzAlign::LEFT);
}
}
EHorzAlign GetHorzAlign(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Left, eType) == sValue)
return EHorzAlign::LEFT;
if (GetValueName(EValue::Center, eType) == sValue)
return EHorzAlign::CENTER;
if (GetValueName(EValue::Right, eType) == sValue)
return EHorzAlign::RIGHT;
if (GetValueName(EValue::Inside, eType) == sValue)
return EHorzAlign::INSIDE;
if (GetValueName(EValue::Outside, eType) == sValue)
return EHorzAlign::OUTSIDE;
return EHorzAlign::LEFT;
}
ETextWrap GetTextWrap(int nValue)
{
SWITCH(ETextWrap, nValue)
{
CASE(ETextWrap::TOP_AND_BOTTOM);
CASE(ETextWrap::BEHIND_TEXT);
CASE(ETextWrap::IN_FRONT_OF_TEXT);
DEFAULT(ETextWrap::SQUARE);
}
}
ETextWrap GetTextWrap(const std::string& sValue, EHanType eType)
{
if (sValue.empty() || GetValueName(EValue::Square, eType) == sValue)
return ETextWrap::SQUARE;
if (GetValueName(EValue::TopAndBottom, eType) == sValue)
return ETextWrap::TOP_AND_BOTTOM;
if (GetValueName(EValue::InFrontOfText, eType) == sValue)
return ETextWrap::IN_FRONT_OF_TEXT;
return ETextWrap::SQUARE;
}
CCtrlCommon::CCtrlCommon()
: m_bTreatAsChar(false), m_eVertRelTo(EVRelTo::PARA), m_eHorzRelTo(EHRelTo::PARA), m_nVertOffset(0), m_nHorzOffset(0), m_nWidth(0), m_nHeight(0), m_arOutMargin{0, 0, 0, 0}, m_arInMargin{0, 0, 0, 0}
{}
CCtrlCommon::CCtrlCommon(const HWP_STRING& sCtrlID)
: CCtrl(sCtrlID), m_bTreatAsChar(false), m_eVertRelTo(EVRelTo::PARA), m_eHorzRelTo(EHRelTo::PARA), m_nVertOffset(0), m_nHorzOffset(0), m_nWidth(0), m_nHeight(0), m_arOutMargin{0, 0, 0, 0}, m_arInMargin{0, 0, 0, 0}, m_eTextVerAlign(EVertAlign::TOP)
{}
CCtrlCommon::CCtrlCommon(const CCtrlCommon& oCtrlCommon)
: CCtrl(oCtrlCommon.GetID()), m_nWidth(0), m_nHeight(0), m_arOutMargin{0, 0, 0, 0}, m_arInMargin{0, 0, 0, 0}
{
m_nObjAttr = oCtrlCommon.m_nObjAttr;
m_bTreatAsChar = oCtrlCommon.m_bTreatAsChar;
m_bAffectLSpacing = oCtrlCommon.m_bAffectLSpacing;
m_eVertRelTo = oCtrlCommon.m_eVertRelTo;
m_eVertAlign = oCtrlCommon.m_eVertAlign;
m_eHorzRelTo = oCtrlCommon.m_eHorzRelTo;
m_eHorzAlign = oCtrlCommon.m_eHorzAlign;
m_bFlowWithText = oCtrlCommon.m_bFlowWithText;
m_bAllowOverlap = oCtrlCommon.m_bAllowOverlap;
m_eWidthRelTo = oCtrlCommon.m_eWidthRelTo;
m_eHeightRelTo = oCtrlCommon.m_eHeightRelTo;
m_eTextWrap = oCtrlCommon.m_eTextWrap;
m_chTextFlow = oCtrlCommon.m_chTextFlow;
m_chNumeringType = oCtrlCommon.m_chNumeringType;
m_nVertOffset = oCtrlCommon.m_nVertOffset;
m_nHorzOffset = oCtrlCommon.m_nHorzOffset;
m_nWidth = oCtrlCommon.m_nWidth;
m_nHeight = oCtrlCommon.m_nHeight;
m_nZOrder = oCtrlCommon.m_nZOrder;
for (unsigned int unIndex = 0; unIndex < 4; ++unIndex)
m_arOutMargin[unIndex] = oCtrlCommon.m_arOutMargin[unIndex];
m_nObjInstanceID = oCtrlCommon.m_nObjInstanceID;
m_nBlockPageBreak = oCtrlCommon.m_nBlockPageBreak;
m_sObjDesc = oCtrlCommon.m_sObjDesc;
m_arParas.resize(oCtrlCommon.m_arParas.size());
for (unsigned int unIndex = 0; unIndex < oCtrlCommon.m_arParas.size(); ++unIndex)
{
oCtrlCommon.m_arParas[unIndex]->AddRef();
m_arParas[unIndex] = oCtrlCommon.m_arParas[unIndex];
}
m_nCaptionAttr = oCtrlCommon.m_nCaptionAttr;
m_nCaptionWidth = oCtrlCommon.m_nCaptionWidth;
m_nCaptionSpacing = oCtrlCommon.m_nCaptionSpacing;
m_nCaptionMaxW = oCtrlCommon.m_nCaptionMaxW;
m_arCaption.resize(oCtrlCommon.m_arCaption.size());
for (unsigned int unIndex = 0; unIndex < oCtrlCommon.m_arCaption.size(); ++unIndex)
{
oCtrlCommon.m_arCaption[unIndex]->AddRef();
m_arCaption[unIndex] = oCtrlCommon.m_arCaption[unIndex];
}
m_eTextVerAlign = oCtrlCommon.m_eTextVerAlign;
}
CCtrlCommon::CCtrlCommon(const HWP_STRING& sCtrlID, int nSize, CHWPStream& oBuffer, int nOff, int nVersion)
: CCtrl(sCtrlID), m_nWidth(0), m_nHeight(0), m_arOutMargin{0, 0, 0, 0}, m_arInMargin{0, 0, 0, 0}
{
oBuffer.SavePosition();
oBuffer.ReadInt(m_nObjAttr);
m_bTreatAsChar = CHECK_FLAG(m_nObjAttr, 0x01);
m_bAffectLSpacing = CHECK_FLAG(m_nObjAttr, 0x04);
m_eVertRelTo = GetVRelTo(m_nObjAttr >> 3 & 0x03);
m_eVertAlign = GetVertAlign(m_nObjAttr >> 5 & 0x07);
m_eHorzRelTo = GetHRelTo(m_nObjAttr >> 8 & 0x03);
m_eHorzAlign = GetHorzAlign(m_nObjAttr >> 10 & 0x07);
m_bFlowWithText = CHECK_FLAG(m_nObjAttr, 0x2000);
m_bAllowOverlap = CHECK_FLAG(m_nObjAttr, 0x4000);
m_eWidthRelTo = ::HWP::GetWidthRelTo(m_nObjAttr >> 15 & 0x07);
m_eHeightRelTo = ::HWP::GetHeightRelTo(m_nObjAttr >> 18 & 0x03);
m_eTextWrap = ::HWP::GetTextWrap(m_nObjAttr >> 21 & 0x07);
m_chTextFlow = (HWP_BYTE)(m_nObjAttr >> 24 & 0x03);
m_chNumeringType = (HWP_BYTE)(m_nObjAttr >> 26 & 0x07);
oBuffer.ReadInt(m_nVertOffset);
oBuffer.ReadInt(m_nHorzOffset);
oBuffer.ReadInt(m_nWidth);
oBuffer.ReadInt(m_nHeight);
oBuffer.ReadInt(m_nZOrder);
for (int nIndex = 0; nIndex < 4; ++nIndex)
oBuffer.ReadShort(m_arOutMargin[nIndex]);
oBuffer.ReadInt(m_nObjInstanceID);
oBuffer.ReadInt(m_nBlockPageBreak);
if (nSize > oBuffer.GetDistanceToLastPos())
oBuffer.ReadString(m_sObjDesc, EStringCharacter::UTF16);
if (nSize > oBuffer.GetDistanceToLastPos())
{
oBuffer.ReadInt(m_nCaptionAttr);
oBuffer.ReadInt(m_nCaptionWidth);
oBuffer.ReadInt(m_nCaptionSpacing);
oBuffer.ReadInt(m_nCaptionMaxW);
}
oBuffer.Skip(nSize - oBuffer.GetDistanceToLastPos(true));
}
CCtrlCommon::CCtrlCommon(const HWP_STRING& sCtrlID, CXMLReader& oReader, EHanType eType)
: CCtrl(sCtrlID), m_bTreatAsChar(false), m_eVertRelTo(EVRelTo::PARA), m_eHorzRelTo(EHRelTo::PARA),
m_nVertOffset(0), m_nHorzOffset(0), m_nWidth(0), m_nHeight(0), m_nZOrder(0),
m_arOutMargin{0, 0, 0, 0}, m_arInMargin{0, 0, 0, 0}, m_eTextVerAlign(EVertAlign::TOP)
{
if (EHanType::HWPX == eType)
ReadAttributes(oReader, eType);
}
CCtrlCommon::~CCtrlCommon()
{
for (CHWPPargraph* pParagraph : m_arParas)
{
if (0 == pParagraph->Release())
pParagraph = nullptr;
}
for (CCapParagraph* pCapParagraph : m_arCaption)
{
if (0 == pCapParagraph->Release())
pCapParagraph = nullptr;
}
}
void CCtrlCommon::ReadAttributes(CXMLReader &oReader, EHanType eType)
{
std::string sType;
START_READ_ATTRIBUTES(oReader)
{
if (GetAttributeName(EAttribute::InstId, eType) == sAttributeName)
m_nObjInstanceID = std::abs(oReader.GetInt());
else if (GetAttributeName(EAttribute::TextFlow, eType) == sAttributeName)
{
sType = oReader.GetTextA();
if (GetValueName(EValue::BothSides, eType) == sType)
m_chTextFlow = 0;
else if (GetValueName(EValue::LeftOnly, eType) == sType)
m_chTextFlow = 1;
else if (GetValueName(EValue::RightOnly, eType) == sType)
m_chTextFlow = 2;
else if (GetValueName(EValue::LargestOnly, eType) == sType)
m_chTextFlow = 3;
}
else if (GetAttributeName(EAttribute::TextWrap, eType) == sAttributeName)
m_eTextWrap = ::HWP::GetTextWrap(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::ZOrder, eType) == sAttributeName)
m_nZOrder = oReader.GetInt();
else if (GetAttributeName(EAttribute::NumberingType, eType) == sAttributeName)
{
sType = oReader.GetTextA();
if (GetValueName(EValue::None, eType) == sType)
m_chNumeringType = 0;
else if (GetValueName(EValue::Figure, eType) == sType)
m_chNumeringType = 1;
else if (GetValueName(EValue::Table, eType) == sType)
m_chNumeringType = 2;
else if (GetValueName(EValue::Equation, eType) == sType)
m_chNumeringType = 3;
}
}
END_READ_ATTRIBUTES(oReader)
}
ECtrlObjectType CCtrlCommon::GetCtrlType() const
{
return ECtrlObjectType::Common;
}
void CCtrlCommon::SetTextVerAlign(EVertAlign eVertAlign)
{
m_eTextVerAlign = eVertAlign;
}
void CCtrlCommon::ParseChildren(CXMLReader& oReader, EHanType eType)
{
const std::string sNodeName{oReader.GetName()};
if (EHanType::HWPML == eType && "SHAPEOBJECT" == sNodeName)
{
ReadAttributes(oReader, eType);
WHILE_READ_NEXT_NODE(oReader)
ParseChildren(oReader, EHanType::HWPML);
END_WHILE
return;
}
if (GetNodeName(ENode::Size, eType) == sNodeName)
{
START_READ_ATTRIBUTES(oReader)
{
if (GetAttributeName(EAttribute::Width, eType) == sAttributeName)
m_nWidth = oReader.GetInt();
else if (GetAttributeName(EAttribute::WidthRelTo, eType) == sAttributeName)
m_eWidthRelTo = ::HWP::GetWidthRelTo(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::Height, eType) == sAttributeName)
m_nHeight = oReader.GetInt();
else if (GetAttributeName(EAttribute::HeightRelTo, eType) == sAttributeName)
m_eHeightRelTo = ::HWP::GetHeightRelTo(oReader.GetTextA(), eType);
}
END_READ_ATTRIBUTES(oReader)
}
else if (GetNodeName(ENode::Posistion, eType) == sNodeName)
{
START_READ_ATTRIBUTES(oReader)
{
CHECK_IF_ATTRIBUTE(TreatAsChar)
m_bTreatAsChar = oReader.GetBool();
CHECK_ELSE_IF_ATTRIBUTE(AffectLSpacing)
m_bAffectLSpacing = oReader.GetBool();
else if (GetAttributeName(EAttribute::AllowOverlap, eType) == sAttributeName)
m_bAllowOverlap = oReader.GetBool();
else if (GetAttributeName(EAttribute::VertRelTo, eType) == sAttributeName)
m_eVertRelTo = GetVRelTo(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::HorzRelTo, eType) == sAttributeName)
m_eHorzRelTo = GetHRelTo(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::FlowWithText, eType) == sAttributeName)
m_bFlowWithText = oReader.GetBool();
else if (GetAttributeName(EAttribute::VertAlign, eType) == sAttributeName)
m_eVertAlign = GetVertAlign(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::HorzAlign, eType) == sAttributeName)
m_eHorzAlign = GetHorzAlign(oReader.GetTextA(), eType);
else if (GetAttributeName(EAttribute::VertOffset, eType) == sAttributeName)
m_nVertOffset = oReader.GetInt();
else if (GetAttributeName(EAttribute::HorzOffset, eType) == sAttributeName)
m_nHorzOffset = oReader.GetInt();
}
END_READ_ATTRIBUTES(oReader)
}
else if (GetNodeName(ENode::OutSideMargin, eType) == sNodeName)
{
START_READ_ATTRIBUTES(oReader)
{
if (GetAttributeName(EAttribute::Left, eType) == sAttributeName)
m_arOutMargin[0] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Right, eType) == sAttributeName)
m_arOutMargin[1] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Top, eType) == sAttributeName)
m_arOutMargin[2] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Bottom, eType) == sAttributeName)
m_arOutMargin[3] = oReader.GetInt();
}
END_READ_ATTRIBUTES(oReader)
}
else if (GetNodeName(ENode::InSideMargin, eType) == sNodeName)
{
START_READ_ATTRIBUTES(oReader)
{
if (GetAttributeName(EAttribute::Left, eType) == sAttributeName)
m_arInMargin[0] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Right, eType) == sAttributeName)
m_arInMargin[1] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Top, eType) == sAttributeName)
m_arInMargin[2] = oReader.GetInt();
else if (GetAttributeName(EAttribute::Bottom, eType) == sAttributeName)
m_arInMargin[3] = oReader.GetInt();
}
END_READ_ATTRIBUTES(oReader)
}
else if (GetNodeName(ENode::Caption, eType) == sNodeName)
{
START_READ_ATTRIBUTES(oReader)
{
if (GetAttributeName(EAttribute::Side, eType) == sAttributeName)
{
const std::string sType{oReader.GetTextA()};
if (GetValueName(EValue::Left, eType) == sType)
m_nCaptionAttr = 0b00;
else if (GetValueName(EValue::Right, eType) == sType)
m_nCaptionAttr = 0b01;
else if (GetValueName(EValue::Top, eType) == sType)
m_nCaptionAttr = 0b10;
else if (GetValueName(EValue::Bottom, eType) == sType)
m_nCaptionAttr = 0b11;
}
else if (GetAttributeName(EAttribute::FullSize, eType) == sAttributeName)
{
if (oReader.GetBool())
m_nCaptionAttr |= 0b100;
}
else if (GetAttributeName(EAttribute::Width, eType) == sAttributeName)
m_nCaptionWidth = oReader.GetInt();
else if (GetAttributeName(EAttribute::Gap, eType) == sAttributeName)
m_nCaptionSpacing = oReader.GetInt();
else if (GetAttributeName(EAttribute::LastWidth, eType) == sAttributeName)
m_nCaptionMaxW = oReader.GetInt();
}
END_READ_ATTRIBUTES(oReader)
if (EHanType::HWPX == eType)
{
WHILE_READ_NEXT_NODE_WITH_DEPTH_ONE_NAME(oReader, SubList, "hp:subList")
WHILE_READ_NEXT_NODE_WITH_DEPTH_ONE_NAME(oReader, Paragraph, "hp:p")
m_arCaption.push_back(new CCapParagraph(oReader, EHanType::HWPX));
END_WHILE
END_WHILE
}
}
}
void CCtrlCommon::AddParagraph(CHWPPargraph* pParagraph)
{
m_arParas.push_back(pParagraph);
}
void CCtrlCommon::AddCaption(CCapParagraph* pCapPara)
{
m_arCaption.push_back(pCapPara);
}
CHWPPargraph* CCtrlCommon::GetLastPara()
{
return (!m_arParas.empty()) ? m_arParas.back() : nullptr;
}
unsigned int CCtrlCommon::GetCountParagraphs() const
{
return (unsigned int)m_arParas.size();
}
const CHWPPargraph* CCtrlCommon::GetParagraphs(unsigned int unIndex) const
{
if (unIndex >= m_arParas.size())
return nullptr;
return m_arParas[unIndex];
}
short CCtrlCommon::GetLeftOutMargin() const
{
return m_arOutMargin[0];
}
short CCtrlCommon::GetTopOutMargin() const
{
return m_arOutMargin[2];
}
short CCtrlCommon::GetRightOutMargin() const
{
return m_arOutMargin[1];
}
short CCtrlCommon::GetBottomOutMargin() const
{
return m_arOutMargin[3];
}
short CCtrlCommon::GetLeftInMargin() const
{
return m_arInMargin[0];
}
short CCtrlCommon::GetTopInMargin() const
{
return m_arInMargin[2];
}
short CCtrlCommon::GetRightInMargin() const
{
return m_arInMargin[1];
}
short CCtrlCommon::GetBottomInMargin() const
{
return m_arInMargin[3];
}
bool CCtrlCommon::GetTreatAsChar() const
{
return m_bTreatAsChar;
}
bool CCtrlCommon::GetFlowWithText() const
{
return m_bFlowWithText;
}
int CCtrlCommon::GetHorzOffset() const
{
if (INT_MAX == m_nHorzOffset || INT_MIN == m_nHorzOffset)
return 0;
return m_nHorzOffset;
}
int CCtrlCommon::GetVertOffset() const
{
if (INT_MAX == m_nVertOffset || INT_MIN == m_nVertOffset)
return 0;
return m_nVertOffset;
}
EVRelTo CCtrlCommon::GetVertRelTo() const
{
return m_eVertRelTo;
}
EHRelTo CCtrlCommon::GetHorzRelTo() const
{
return m_eHorzRelTo;
}
int CCtrlCommon::GetCaptionWidth() const
{
return m_nCaptionWidth;
}
bool CCtrlCommon::CaptionsEmpty() const
{
return m_arCaption.empty();
}
HWP_STRING CCtrlCommon::GetDesc() const
{
return m_sObjDesc;
}
EWidthRelTo CCtrlCommon::GetWidthRelTo() const
{
return m_eWidthRelTo;
}
EHeightRelTo CCtrlCommon::GetHeightRelTo() const
{
return m_eHeightRelTo;
}
int CCtrlCommon::GetWidth() const
{
return m_nWidth;
}
int CCtrlCommon::GetHeight() const
{
return m_nHeight;
}
ETextWrap CCtrlCommon::GetTextWrap() const
{
return m_eTextWrap;
}
HWP_BYTE CCtrlCommon::GetTextFlow() const
{
return m_chTextFlow;
}
int CCtrlCommon::GetZOrder() const
{
return m_nZOrder;
}
bool CCtrlCommon::HaveCaption() const
{
return !m_arCaption.empty();
}
std::vector<const CCapParagraph*> CCtrlCommon::GetCaptionParas() const
{
RETURN_VECTOR_CONST_PTR(CCapParagraph, m_arCaption);
}
int CCtrlCommon::ParseCtrl(CCtrlCommon& oObj, int nSize, CHWPStream& oBuffer, int nOff, int nVersion)
{
HWP_STRING sCtrlId;
oBuffer.ReadString(sCtrlId, 4, EStringCharacter::ASCII);
if (L"nil$" == sCtrlId || L"loc$" == sCtrlId || L"cer$" == sCtrlId || L"lle$" == sCtrlId ||
L"cra$" == sCtrlId || L"lop$" == sCtrlId || L"ruc$" == sCtrlId || L"deqe" == sCtrlId ||
L"cip$" == sCtrlId || L"elo$" == sCtrlId || L"noc$" == sCtrlId || L"div$" == sCtrlId ||
L"tat$" == sCtrlId)
return 4;
oBuffer.Skip(-4);
return 0;
//TODO:: проверить данный метод
// в исходном коде есть дальнейшие действия
}
int CCtrlCommon::ParseCaption(CCtrlCommon& oObj, int nSize, CHWPStream& oBuffer, int nOff, int nVersion)
{
oBuffer.ReadInt(oObj.m_nCaptionAttr);
oBuffer.ReadInt(oObj.m_nCaptionWidth);
oBuffer.ReadInt(oObj.m_nCaptionSpacing);
oBuffer.ReadInt(oObj.m_nCaptionMaxW);
return 16;
}
}