tdf#36709 editeng: Layout for font-relative first-line indent

This change extends layout for font-relative paragraph first-line
indentation into Edit Engine.

Change-Id: I5906f493b91fbcb87ded165709fb132b33ce1906
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/176487
Tested-by: Jenkins
Reviewed-by: Jonathan Clark <jonathan@libreoffice.org>
This commit is contained in:
Jonathan Clark 2024-11-08 01:12:48 -07:00
parent a095909899
commit 2cb039f570
71 changed files with 545 additions and 295 deletions

View File

@ -412,22 +412,21 @@ bool SvxStdParagraphTabPage::FillItemSet( SfxItemSet* rOutSet )
if (m_aFLineIndent.IsRelative())
{
item.SetTextFirstLineOffset(
rOldItem.GetTextFirstLineOffsetValue(), rOldItem.GetTextFirstLineOffsetUnit(),
rOldItem.GetTextFirstLineOffset(),
static_cast<sal_uInt16>(m_aFLineIndent.get_value(FieldUnit::NONE)));
}
else
{
// tdf#36709: TODO: Handle font-relative units from GUI
item.SetTextFirstLineOffset(
static_cast<sal_uInt16>(m_aFLineIndent.GetCoreValue(eUnit)),
SvxIndentValue::twips(m_aFLineIndent.GetCoreValue(eUnit)),
css::util::MeasureUnit::TWIP);
}
}
else
{
// tdf#36709: TODO: Handle font-relative units from GUI
item.SetTextFirstLineOffset(static_cast<sal_uInt16>(m_aFLineIndent.GetCoreValue(eUnit)),
css::util::MeasureUnit::TWIP);
item.SetTextFirstLineOffset(SvxIndentValue::twips(m_aFLineIndent.GetCoreValue(eUnit)));
}
item.SetAutoFirst(m_xAutoCB->get_active());
if (item.GetTextFirstLineOffsetValue() < 0)
@ -474,19 +473,26 @@ bool SvxStdParagraphTabPage::FillItemSet( SfxItemSet* rOutSet )
aMargin.SetRight(m_aRightIndent.GetCoreValue(eUnit));
if ( m_aFLineIndent.IsRelative() )
aMargin.SetTextFirstLineOffset( rOldItem.GetTextFirstLineOffset(),
static_cast<sal_uInt16>(m_aFLineIndent.get_value(FieldUnit::NONE)) );
aMargin.SetTextFirstLineOffset(
rOldItem.GetTextFirstLineOffset(),
static_cast<sal_uInt16>(m_aFLineIndent.get_value(FieldUnit::NONE)));
else
aMargin.SetTextFirstLineOffset(static_cast<sal_uInt16>(m_aFLineIndent.GetCoreValue(eUnit)));
{
// tdf#36709: TODO: Handle font-relative units from GUI
aMargin.SetTextFirstLineOffset(
SvxIndentValue::twips(m_aFLineIndent.GetCoreValue(eUnit)));
}
}
else
{
aMargin.SetTextLeft(m_aLeftIndent.GetCoreValue(eUnit));
aMargin.SetRight(m_aRightIndent.GetCoreValue(eUnit));
aMargin.SetTextFirstLineOffset(static_cast<sal_uInt16>(m_aFLineIndent.GetCoreValue(eUnit)));
// tdf#36709: TODO: Handle font-relative units from GUI
aMargin.SetTextFirstLineOffset(
SvxIndentValue::twips(m_aFLineIndent.GetCoreValue(eUnit)));
}
aMargin.SetAutoFirst(m_xAutoCB->get_active());
if ( aMargin.GetTextFirstLineOffset() < 0 )
if ( aMargin.GetTextFirstLineOffsetValue() < 0.0 )
bNullTab = true;
if ( !pOld || *static_cast<const SvxLRSpaceItem*>(pOld) != aMargin ||
@ -733,7 +739,8 @@ void SvxStdParagraphTabPage::Reset( const SfxItemSet* rSet )
m_aFLineIndent.SetRelative(false);
m_aFLineIndent.set_min(-9999, FieldUnit::NONE);
m_aFLineIndent.SetFieldUnit(eFUnit);
m_aFLineIndent.SetMetricValue(rOldItem.GetTextFirstLineOffset(), eUnit);
// tdf#36709: TODO: Populate GUI with font-relative unit
m_aFLineIndent.SetMetricValue(rOldItem.GetTextFirstLineOffsetValue(), eUnit);
}
m_xAutoCB->set_active(rOldItem.IsAutoFirst());
}
@ -744,7 +751,8 @@ void SvxStdParagraphTabPage::Reset( const SfxItemSet* rSet )
m_aLeftIndent.SetMetricValue(rSpace.GetTextLeft(), eUnit);
m_aRightIndent.SetMetricValue(rSpace.GetRight(), eUnit);
m_aFLineIndent.SetMetricValue(rSpace.GetTextFirstLineOffset(), eUnit);
// tdf#36709: TODO: Populate GUI with font-relative units
m_aFLineIndent.SetMetricValue(rSpace.GetTextFirstLineOffsetValue(), eUnit);
m_xAutoCB->set_active(rSpace.IsAutoFirst());
}
AutoHdl_Impl(*m_xAutoCB);

View File

@ -176,7 +176,8 @@ bool SvxTabulatorTabPage::FillItemSet(SfxItemSet* rSet)
if (SfxItemState::SET != rSet->GetItemState(GetWhich(SID_ATTR_LRSPACE), true, &pLRSpace))
pLRSpace = GetOldItem(*rSet, SID_ATTR_LRSPACE);
if (pLRSpace && static_cast<const SvxLRSpaceItem*>(pLRSpace)->GetTextFirstLineOffset() < 0)
if (pLRSpace
&& static_cast<const SvxLRSpaceItem*>(pLRSpace)->GetTextFirstLineOffsetValue() < 0.0)
{
SvxTabStop aNull(0, SvxTabAdjust::Default);
aNewTabs->Insert(aNull);

View File

@ -69,7 +69,8 @@ struct DebOutBuffer
}
void append(std::string_view descr, const SvxLRSpaceItem& rItem)
{
str.append(OString::Concat(descr) + "FI=" + OString::number(rItem.GetTextFirstLineOffset())
str.append(OString::Concat(descr)
+ "FI=" + OString::number(rItem.ResolveTextFirstLineOffset({}))
+ ", LI=" + OString::number(rItem.GetTextLeft())
+ ", RI=" + OString::number(rItem.GetRight()));
}

View File

@ -574,7 +574,12 @@ void ConvertItem( std::unique_ptr<SfxPoolItem>& rPoolItem, MapUnit eSourceUnit,
{
assert(dynamic_cast<const SvxLRSpaceItem *>(rPoolItem.get()) != nullptr);
SvxLRSpaceItem& rItem = static_cast<SvxLRSpaceItem&>(*rPoolItem);
rItem.SetTextFirstLineOffset( sal::static_int_cast< short >( OutputDevice::LogicToLogic( rItem.GetTextFirstLineOffset(), eSourceUnit, eDestUnit ) ) );
if (rItem.GetTextFirstLineOffsetUnit() == css::util::MeasureUnit::TWIP)
{
rItem.SetTextFirstLineOffset(
SvxIndentValue::twips(sal::static_int_cast<short>(OutputDevice::LogicToLogic(
rItem.ResolveTextFirstLineOffset({}), eSourceUnit, eDestUnit))));
}
rItem.SetTextLeft( OutputDevice::LogicToLogic( rItem.GetTextLeft(), eSourceUnit, eDestUnit ) );
rItem.SetRight( OutputDevice::LogicToLogic( rItem.GetRight(), eSourceUnit, eDestUnit ) );
}

View File

@ -570,7 +570,7 @@ void EditView::HideCursor(bool bDeactivate)
bool EditView::IsCursorVisible() const { return getImpl().GetCursor()->IsVisible(); }
Pair EditView::Scroll( tools::Long ndX, tools::Long ndY, ScrollRangeCheck nRangeCheck )
::Pair EditView::Scroll( tools::Long ndX, tools::Long ndY, ScrollRangeCheck nRangeCheck )
{
return getImpl().Scroll( ndX, ndY, nRangeCheck );
}

View File

@ -67,6 +67,7 @@ class OutlinerSearchable;
class SvxSearchItem;
class SvxLRSpaceItem;
struct SvxFontUnitMetrics;
class TextRanger;
class SvKeyValueIterator;
class SvxForbiddenCharactersTable;
@ -1270,6 +1271,7 @@ public:
SvxAdjust GetJustification( sal_Int32 nPara ) const;
SvxCellJustifyMethod GetJustifyMethod( sal_Int32 nPara ) const;
SvxCellVerJustify GetVerJustification( sal_Int32 nPara ) const;
SvxFontUnitMetrics GetFontUnitMetrics(ContentNode* pNode);
void setScalingParameters(ScalingParameters const& rScalingParameters);

View File

@ -2130,6 +2130,21 @@ SvxCellVerJustify ImpEditEngine::GetVerJustification( sal_Int32 nPara ) const
return static_cast<SvxCellVerJustify>(rItem.GetEnumValue());
}
SvxFontUnitMetrics ImpEditEngine::GetFontUnitMetrics(ContentNode* pNode)
{
SvxFont aTmpFont{ pNode->GetCharAttribs().GetDefFont() };
SeekCursor(pNode, /*index*/ 1, aTmpFont);
aTmpFont.SetPhysFont(*GetRefDevice());
// tdf#36709: Metrics conversion should use em and ic values from the bound fonts.
// Unfortunately, this currently poses a problem due to font substitution: tests
// abort when a missing font is set on a device.
// In the interim, use height for all metrics. This is technically not correct, but
// should be close enough for common fonts.
auto dTextLineHeight = static_cast<double>(aTmpFont.GetPhysTxtSize(GetRefDevice()).Height());
return SvxFontUnitMetrics{ /*em*/ dTextLineHeight, /*ic*/ dTextLineHeight };
}
// Text changes
void ImpEditEngine::ImpRemoveChars( const EditPaM& rPaM, sal_Int32 nChars )
{
@ -3452,6 +3467,7 @@ sal_uInt32 ImpEditEngine::CalcParaWidth( sal_Int32 nPara, bool bIgnoreExtraSpace
const SvxLRSpaceItem& rLRItem = GetLRSpaceItem( pPortion->GetNode() );
sal_Int32 nSpaceBeforeAndMinLabelWidth = GetSpaceBeforeAndMinLabelWidth( pPortion->GetNode() );
auto stMetrics = GetFontUnitMetrics(pPortion->GetNode());
// On the lines of the paragraph ...
@ -3467,7 +3483,7 @@ sal_uInt32 ImpEditEngine::CalcParaWidth( sal_Int32 nPara, bool bIgnoreExtraSpace
tools::Long nCurWidth = scaleXSpacingValue(rLRItem.GetTextLeft() + nSpaceBeforeAndMinLabelWidth);
if ( nLine == 0 )
{
tools::Long nFI = scaleXSpacingValue(rLRItem.GetTextFirstLineOffset());
tools::Long nFI = scaleXSpacingValue(rLRItem.ResolveTextFirstLineOffset(stMetrics));
nCurWidth -= nFI;
if ( pPortion->GetBulletX() > nCurWidth )
{
@ -3770,6 +3786,9 @@ Point ImpEditEngine::GetDocPosTopLeft( sal_Int32 nParagraph )
{
const ParaPortion* pPPortion = maParaPortionList.SafeGetObject(nParagraph);
DBG_ASSERT( pPPortion, "Paragraph not found: GetWindowPosTopLeft" );
auto stMetrics = GetFontUnitMetrics(pPPortion->GetNode());
Point aPoint;
if ( pPPortion )
{
@ -3789,8 +3808,8 @@ Point ImpEditEngine::GetDocPosTopLeft( sal_Int32 nParagraph )
sal_Int32 nSpaceBefore = 0;
GetSpaceBeforeAndMinLabelWidth(pPPortion->GetNode(), &nSpaceBefore);
short nX = static_cast<short>(rLRItem.GetTextLeft()
+ rLRItem.GetTextFirstLineOffset()
+ nSpaceBefore);
+ rLRItem.ResolveTextFirstLineOffset(stMetrics)
+ nSpaceBefore);
aPoint.setX(scaleXSpacingValue(nX));
}

View File

@ -815,7 +815,8 @@ bool ImpEditEngine::CreateLines( sal_Int32 nPara, sal_uInt32 nStartPosY )
tools::Long nStartXNextLine = nStartX;
if ( nIndex == 0 )
{
tools::Long nFI = scaleXSpacingValue(rLRItem.GetTextFirstLineOffset());
auto stMetrics = GetFontUnitMetrics(pNode);
tools::Long nFI = scaleXSpacingValue(rLRItem.ResolveTextFirstLineOffset(stMetrics));
nStartX += nFI;
if (!nLine && rParaPortion.GetBulletX() > nStartX)
@ -1791,17 +1792,22 @@ void ImpEditEngine::CreateAndInsertEmptyLine(ParaPortion& rParaPortion)
pTmpLine->SetEnd(rParaPortion.GetNode()->Len());
rParaPortion.GetLines().Append(std::unique_ptr<EditLine>(pTmpLine));
auto stMetrics = GetFontUnitMetrics(rParaPortion.GetNode());
bool bLineBreak = rParaPortion.GetNode()->Len() > 0;
sal_Int32 nSpaceBefore = 0;
sal_Int32 nSpaceBeforeAndMinLabelWidth = GetSpaceBeforeAndMinLabelWidth(rParaPortion.GetNode(), &nSpaceBefore);
const SvxLRSpaceItem& rLRItem = GetLRSpaceItem(rParaPortion.GetNode());
const SvxLineSpacingItem& rLSItem = rParaPortion.GetNode()->GetContentAttribs().GetItem( EE_PARA_SBL );
tools::Long nStartX = scaleXSpacingValue(rLRItem.GetTextLeft() + rLRItem.GetTextFirstLineOffset() + nSpaceBefore);
tools::Long nStartX = scaleXSpacingValue(
rLRItem.GetTextLeft() + rLRItem.ResolveTextFirstLineOffset(stMetrics) + nSpaceBefore);
tools::Rectangle aBulletArea { Point(), Point() };
if ( bLineBreak )
{
nStartX = scaleXSpacingValue(rLRItem.GetTextLeft() + rLRItem.GetTextFirstLineOffset() + nSpaceBeforeAndMinLabelWidth);
nStartX = scaleXSpacingValue(rLRItem.GetTextLeft()
+ rLRItem.ResolveTextFirstLineOffset(stMetrics)
+ nSpaceBeforeAndMinLabelWidth);
}
else
{
@ -1812,7 +1818,9 @@ void ImpEditEngine::CreateAndInsertEmptyLine(ParaPortion& rParaPortion)
rParaPortion.SetBulletX( 0 ); // If Bullet set incorrectly.
if (rParaPortion.GetBulletX() > nStartX)
{
nStartX = scaleXSpacingValue(rLRItem.GetTextLeft() + rLRItem.GetTextFirstLineOffset() + nSpaceBeforeAndMinLabelWidth);
nStartX = scaleXSpacingValue(rLRItem.GetTextLeft()
+ rLRItem.ResolveTextFirstLineOffset(stMetrics)
+ nSpaceBeforeAndMinLabelWidth);
if (rParaPortion.GetBulletX() > nStartX)
nStartX = rParaPortion.GetBulletX();
}

View File

@ -770,7 +770,8 @@ void ImpEditEngine::WriteItemAsRTF( const SfxPoolItem& rItem, SvStream& rOutput,
case EE_PARA_LRSPACE:
{
rOutput.WriteOString( OOO_STRING_SVTOOLS_RTF_FI );
sal_Int32 nTxtFirst = static_cast<const SvxLRSpaceItem&>(rItem).GetTextFirstLineOffset();
sal_Int32 nTxtFirst
= static_cast<const SvxLRSpaceItem&>(rItem).ResolveTextFirstLineOffset({});
nTxtFirst = LogicToTwips( nTxtFirst );
rOutput.WriteNumberAsString( nTxtFirst );
rOutput.WriteOString( OOO_STRING_SVTOOLS_RTF_LI );

View File

@ -291,7 +291,6 @@ bool SvxSizeItem::HasMetrics() const
SvxLRSpaceItem::SvxLRSpaceItem(const sal_uInt16 nId)
: SfxPoolItem(nId, SfxItemType::SvxLRSpaceItemType)
, nFirstLineOffset(0)
, nLeftMargin(0)
, nRightMargin(0)
, m_nGutterMargin(0)
@ -305,23 +304,21 @@ SvxLRSpaceItem::SvxLRSpaceItem(const sal_uInt16 nId)
{
}
SvxLRSpaceItem::SvxLRSpaceItem( const tools::Long nLeft, const tools::Long nRight,
const short nOfset,
const sal_uInt16 nId )
SvxLRSpaceItem::SvxLRSpaceItem(const tools::Long nLeft, const tools::Long nRight,
SvxIndentValue stOffset, const sal_uInt16 nId)
: SfxPoolItem(nId, SfxItemType::SvxLRSpaceItemType)
, nFirstLineOffset(nOfset)
, nLeftMargin(nLeft)
, nRightMargin(nRight)
, m_nGutterMargin(0)
, m_nRightGutterMargin(0),
nPropFirstLineOffset( 100 ),
nPropLeftMargin( 100 ),
nPropRightMargin( 100 ),
bAutoFirst ( false ),
bExplicitZeroMarginValRight(false),
bExplicitZeroMarginValLeft(false)
, m_nRightGutterMargin(0)
, nPropFirstLineOffset(100)
, nPropLeftMargin(100)
, nPropRightMargin(100)
, bAutoFirst(false)
, bExplicitZeroMarginValRight(false)
, bExplicitZeroMarginValLeft(false)
{
SetTextFirstLineOffset(stOffset);
}
@ -341,7 +338,10 @@ bool SvxLRSpaceItem::QueryValue( uno::Any& rVal, sal_uInt8 nMemberId ) const
aLRSpace.Right = static_cast<sal_Int32>(bConvert ? convertTwipToMm100(nRightMargin) : nRightMargin);
aLRSpace.ScaleLeft = static_cast<sal_Int16>(nPropLeftMargin);
aLRSpace.ScaleRight = static_cast<sal_Int16>(nPropRightMargin);
aLRSpace.FirstLine = static_cast<sal_Int32>(bConvert ? convertTwipToMm100(nFirstLineOffset) : nFirstLineOffset);
auto nFirstLineOffsetTwips = ResolveTextFirstLineOffset({});
aLRSpace.FirstLine = static_cast<sal_Int32>(bConvert ? convertTwipToMm100(nFirstLineOffsetTwips) : nFirstLineOffsetTwips);
aLRSpace.ScaleFirstLine = static_cast<sal_Int16>(nPropFirstLineOffset);
aLRSpace.AutoFirstLine = IsAutoFirst();
rVal <<= aLRSpace;
@ -365,13 +365,39 @@ bool SvxLRSpaceItem::QueryValue( uno::Any& rVal, sal_uInt8 nMemberId ) const
break;
case MID_FIRST_LINE_INDENT:
rVal <<= static_cast<sal_Int32>(bConvert ? convertTwipToMm100(nFirstLineOffset) : nFirstLineOffset);
break;
// MID_FIRST_LINE_INDENT only supports statically-convertible measures.
// In practice, these are always stored here in twips.
if (m_nFirstLineUnit == css::util::MeasureUnit::TWIP)
{
auto nConvOffset
= (bConvert ? convertTwipToMm100(m_dFirstLineOffset) : m_dFirstLineOffset);
rVal <<= static_cast<sal_Int32>(std::llround(nConvOffset));
}
else
{
bRet = false;
}
break;
case MID_FIRST_LINE_REL_INDENT:
rVal <<= static_cast<sal_Int16>(nPropFirstLineOffset);
break;
case MID_FIRST_LINE_UNIT_INDENT:
// MID_FIRST_LINE_UNIT_INDENT is used for any values that must be serialized
// as a unit-value pair. In practice, this will be limited to font-relative
// units (e.g. em, ic), and all other units will be pre-converted to twips.
if (m_nFirstLineUnit != css::util::MeasureUnit::TWIP)
{
rVal
<<= css::beans::Pair<double, sal_Int16>{ m_dFirstLineOffset, m_nFirstLineUnit };
}
else
{
bRet = false;
}
break;
case MID_FIRST_AUTO:
rVal <<= IsAutoFirst();
break;
@ -395,8 +421,8 @@ bool SvxLRSpaceItem::PutValue( const uno::Any& rVal, sal_uInt8 nMemberId )
bool bConvert = 0 != (nMemberId&CONVERT_TWIPS);
nMemberId &= ~CONVERT_TWIPS;
sal_Int32 nVal = 0;
if( nMemberId != 0 && nMemberId != MID_FIRST_AUTO &&
nMemberId != MID_L_REL_MARGIN && nMemberId != MID_R_REL_MARGIN)
if (nMemberId != 0 && nMemberId != MID_FIRST_AUTO && nMemberId != MID_L_REL_MARGIN
&& nMemberId != MID_R_REL_MARGIN && nMemberId != MID_FIRST_LINE_UNIT_INDENT)
if(!(rVal >>= nVal))
return false;
@ -413,7 +439,9 @@ bool SvxLRSpaceItem::PutValue( const uno::Any& rVal, sal_uInt8 nMemberId )
SetRight(bConvert ? o3tl::toTwips(aLRSpace.Right, o3tl::Length::mm100) : aLRSpace.Right);
nPropLeftMargin = aLRSpace.ScaleLeft;
nPropRightMargin = aLRSpace.ScaleRight;
SetTextFirstLineOffset(bConvert ? o3tl::toTwips(aLRSpace.FirstLine, o3tl::Length::mm100) : aLRSpace.FirstLine);
SetTextFirstLineOffset(SvxIndentValue::twips(
bConvert ? o3tl::toTwips(aLRSpace.FirstLine, o3tl::Length::mm100)
: aLRSpace.FirstLine));
SetPropTextFirstLineOffset ( aLRSpace.ScaleFirstLine );
SetAutoFirst( aLRSpace.AutoFirstLine );
break;
@ -445,13 +473,26 @@ bool SvxLRSpaceItem::PutValue( const uno::Any& rVal, sal_uInt8 nMemberId )
}
break;
case MID_FIRST_LINE_INDENT :
SetTextFirstLineOffset(bConvert ? o3tl::toTwips(nVal, o3tl::Length::mm100) : nVal);
SetTextFirstLineOffset(
SvxIndentValue::twips(bConvert ? o3tl::toTwips(nVal, o3tl::Length::mm100) : nVal));
break;
case MID_FIRST_LINE_REL_INDENT:
SetPropTextFirstLineOffset ( nVal );
break;
case MID_FIRST_LINE_UNIT_INDENT:
{
css::beans::Pair<double, sal_Int16> stVal;
if (!(rVal >>= stVal))
{
return false;
}
SetTextFirstLineOffset(SvxIndentValue{ stVal.First, stVal.Second });
break;
}
case MID_FIRST_AUTO:
SetAutoFirst( Any2Bool(rVal) );
break;
@ -476,7 +517,8 @@ void SvxLeftMarginItem::SetLeft(const tools::Long nL, const sal_uInt16 nProp)
void SvxLRSpaceItem::SetLeft(const tools::Long nL, const sal_uInt16 nProp)
{
nLeftMargin = (nL * nProp) / 100;
SAL_WARN_IF(nFirstLineOffset != 0, "editeng", "probably call SetTextLeft instead? looks inconsistent otherwise");
SAL_WARN_IF(m_dFirstLineOffset != 0.0, "editeng",
"probably call SetTextLeft instead? looks inconsistent otherwise");
nPropLeftMargin = nProp;
}
@ -497,18 +539,26 @@ void SvxLRSpaceItem::SetRight(const tools::Long nR, const sal_uInt16 nProp)
nPropRightMargin = nProp;
}
void SvxLRSpaceItem::SetTextFirstLineOffset(const short nF, const sal_uInt16 nProp)
void SvxLRSpaceItem::SetTextFirstLineOffset(SvxIndentValue stValue, sal_uInt16 nProp)
{
// note: left margin contains any negative first line offset - preserve it!
if (nFirstLineOffset < 0)
if (m_dFirstLineOffset < 0.0)
{
nLeftMargin -= nFirstLineOffset;
nLeftMargin -= ResolveTextFirstLineOffset({});
}
nFirstLineOffset = short((tools::Long(nF) * nProp ) / 100);
m_dFirstLineOffset = stValue.m_dValue;
m_nFirstLineUnit = stValue.m_nUnit;
nPropFirstLineOffset = nProp;
if (nFirstLineOffset < 0)
if (nProp != 100)
{
nLeftMargin += nFirstLineOffset;
m_dFirstLineOffset = (stValue.m_dValue * static_cast<double>(nProp)) / 100.0;
}
if (m_dFirstLineOffset < 0.0)
{
nLeftMargin += ResolveTextFirstLineOffset({});
}
}
@ -542,12 +592,47 @@ void SvxLRSpaceItem::SetTextLeft(const tools::Long nL, const sal_uInt16 nProp)
auto const nTxtLeft = (nL * nProp) / 100;
nPropLeftMargin = nProp;
// note: left margin contains any negative first line offset
if ( 0 > nFirstLineOffset )
nLeftMargin = nTxtLeft + nFirstLineOffset;
if (0.0 > m_dFirstLineOffset)
nLeftMargin = nTxtLeft + ResolveTextFirstLineOffset({});
else
nLeftMargin = nTxtLeft;
}
SvxIndentValue SvxLRSpaceItem::GetTextFirstLineOffset() const
{
return { m_dFirstLineOffset, m_nFirstLineUnit };
}
double SvxLRSpaceItem::GetTextFirstLineOffsetValue() const { return m_dFirstLineOffset; }
sal_Int16 SvxLRSpaceItem::GetTextFirstLineOffsetUnit() const { return m_nFirstLineUnit; }
double SvxLRSpaceItem::ResolveTextFirstLineOffsetDouble(const SvxFontUnitMetrics& rMetrics) const
{
if (m_nFirstLineUnit == css::util::MeasureUnit::TWIP)
return m_dFirstLineOffset;
SAL_WARN_IF(!rMetrics.m_bInitialized, "editeng", "font-relative indentation lost");
switch (m_nFirstLineUnit)
{
case css::util::MeasureUnit::FONT_EM:
return m_dFirstLineOffset * rMetrics.m_dEmTwips;
case css::util::MeasureUnit::FONT_CJK_ADVANCE:
return m_dFirstLineOffset * rMetrics.m_dIcTwips;
default:
SAL_WARN("editeng", "unhandled type conversion");
return 0.0;
}
}
sal_Int32 SvxLRSpaceItem::ResolveTextFirstLineOffset(const SvxFontUnitMetrics& rMetrics) const
{
return static_cast<sal_Int32>(std::llround(ResolveTextFirstLineOffsetDouble(rMetrics)));
}
tools::Long SvxTextLeftMarginItem::GetTextLeft() const
{
return m_nTextLeftMargin;
@ -569,9 +654,7 @@ tools::Long SvxTextLeftMarginItem::GetLeft(const SvxFirstLineIndentItem& rFirstL
tools::Long SvxLRSpaceItem::GetTextLeft() const
{
// remove any negative first line offset from left margin to get text-left
return (nFirstLineOffset < 0)
? nLeftMargin - nFirstLineOffset
: nLeftMargin;
return (m_dFirstLineOffset < 0) ? nLeftMargin - ResolveTextFirstLineOffset({}) : nLeftMargin;
}
SvxLeftMarginItem::SvxLeftMarginItem(const sal_uInt16 nId)
@ -935,11 +1018,10 @@ SvxFirstLineIndentItem::SvxFirstLineIndentItem(const sal_uInt16 nId)
{
}
SvxFirstLineIndentItem::SvxFirstLineIndentItem(double dValue, sal_uInt16 nUnit,
const sal_uInt16 nId)
SvxFirstLineIndentItem::SvxFirstLineIndentItem(SvxIndentValue stValue, const sal_uInt16 nId)
: SvxFirstLineIndentItem(nId)
{
SetTextFirstLineOffset(dValue, nUnit);
SetTextFirstLineOffset(stValue);
}
bool SvxFirstLineIndentItem::IsAutoFirst() const { return m_bAutoFirst; }
@ -961,20 +1043,24 @@ sal_uInt16 SvxFirstLineIndentItem::GetPropTextFirstLineOffset() const
return m_nPropFirstLineOffset;
}
void SvxFirstLineIndentItem::SetTextFirstLineOffset(double dValue, sal_Int16 nUnit,
sal_uInt16 nProp)
void SvxFirstLineIndentItem::SetTextFirstLineOffset(SvxIndentValue stValue, sal_uInt16 nProp)
{
ASSERT_CHANGE_REFCOUNTED_ITEM;
m_dFirstLineOffset = dValue;
m_nUnit = nUnit;
m_dFirstLineOffset = stValue.m_dValue;
m_nUnit = stValue.m_nUnit;
m_nPropFirstLineOffset = nProp;
if (nProp != 100)
{
m_dFirstLineOffset = (dValue * static_cast<double>(nProp)) / 100.0;
m_dFirstLineOffset = (stValue.m_dValue * static_cast<double>(nProp)) / 100.0;
}
}
SvxIndentValue SvxFirstLineIndentItem::GetTextFirstLineOffset() const
{
return { m_dFirstLineOffset, m_nUnit };
}
double SvxFirstLineIndentItem::GetTextFirstLineOffsetValue() const { return m_dFirstLineOffset; }
sal_Int16 SvxFirstLineIndentItem::GetTextFirstLineOffsetUnit() const { return m_nUnit; }
@ -1098,9 +1184,7 @@ bool SvxFirstLineIndentItem::PutValue(const uno::Any& rVal, sal_uInt8 nMemberId)
return false;
}
m_dFirstLineOffset = stVal.First;
m_nUnit = stVal.Second;
m_nPropFirstLineOffset = 100;
SetTextFirstLineOffset(SvxIndentValue{ stVal.First, stVal.Second });
break;
}
case MID_FIRST_AUTO:
@ -1669,18 +1753,15 @@ bool SvxLRSpaceItem::operator==( const SfxPoolItem& rAttr ) const
const SvxLRSpaceItem& rOther = static_cast<const SvxLRSpaceItem&>(rAttr);
return (
nFirstLineOffset == rOther.GetTextFirstLineOffset() &&
m_nGutterMargin == rOther.GetGutterMargin() &&
m_nRightGutterMargin == rOther.GetRightGutterMargin() &&
nLeftMargin == rOther.GetLeft() &&
nRightMargin == rOther.GetRight() &&
nPropFirstLineOffset == rOther.GetPropTextFirstLineOffset() &&
nPropLeftMargin == rOther.GetPropLeft() &&
nPropRightMargin == rOther.GetPropRight() &&
bAutoFirst == rOther.IsAutoFirst() &&
bExplicitZeroMarginValRight == rOther.IsExplicitZeroMarginValRight() &&
bExplicitZeroMarginValLeft == rOther.IsExplicitZeroMarginValLeft() );
return std::tie(m_dFirstLineOffset, m_nFirstLineUnit, m_nGutterMargin, m_nRightGutterMargin,
nLeftMargin, nRightMargin, nPropFirstLineOffset, nPropLeftMargin,
nPropRightMargin, bAutoFirst, bExplicitZeroMarginValRight,
bExplicitZeroMarginValLeft)
== std::tie(rOther.m_dFirstLineOffset, rOther.m_nFirstLineUnit, rOther.m_nGutterMargin,
rOther.m_nRightGutterMargin, rOther.nLeftMargin, rOther.nRightMargin,
rOther.nPropFirstLineOffset, rOther.nPropLeftMargin, rOther.nPropRightMargin,
rOther.bAutoFirst, rOther.bExplicitZeroMarginValRight,
rOther.bExplicitZeroMarginValLeft);
}
SvxLRSpaceItem* SvxLRSpaceItem::Clone( SfxItemPool* ) const
@ -1714,9 +1795,15 @@ bool SvxLRSpaceItem::GetPresentation
rText += unicode::formatPercent(nPropFirstLineOffset,
Application::GetSettings().GetUILanguageTag());
}
else if (m_nFirstLineUnit != css::util::MeasureUnit::TWIP)
{
OUStringBuffer stBuf;
sax::Converter::convertMeasureUnit(stBuf, m_dFirstLineOffset, m_nFirstLineUnit);
rText += stBuf.makeStringAndClear();
}
else
rText += GetMetricText( static_cast<tools::Long>(nFirstLineOffset),
eCoreUnit, ePresUnit, &rIntl );
rText += GetMetricText(static_cast<tools::Long>(m_dFirstLineOffset), eCoreUnit,
ePresUnit, &rIntl);
rText += cpDelim;
if ( 100 != nRightMargin )
{
@ -1740,17 +1827,23 @@ bool SvxLRSpaceItem::GetPresentation
" " + EditResId(GetMetricId(ePresUnit));
}
rText += cpDelim;
if ( 100 != nPropFirstLineOffset || nFirstLineOffset )
if (100 != nPropFirstLineOffset || m_dFirstLineOffset != 0.0)
{
rText += EditResId(RID_SVXITEMS_LRSPACE_FLINE);
if ( 100 != nPropFirstLineOffset )
rText += unicode::formatPercent(nPropFirstLineOffset,
Application::GetSettings().GetUILanguageTag());
else if (m_nFirstLineUnit != css::util::MeasureUnit::TWIP)
{
OUStringBuffer stBuf;
sax::Converter::convertMeasureUnit(stBuf, m_dFirstLineOffset, m_nFirstLineUnit);
rText += stBuf.makeStringAndClear();
}
else
{
rText += GetMetricText( static_cast<tools::Long>(nFirstLineOffset),
eCoreUnit, ePresUnit, &rIntl ) +
" " + EditResId(GetMetricId(ePresUnit));
rText += GetMetricText(static_cast<tools::Long>(m_dFirstLineOffset), eCoreUnit,
ePresUnit, &rIntl)
+ " " + EditResId(GetMetricId(ePresUnit));
}
rText += cpDelim;
}
@ -1774,7 +1867,8 @@ bool SvxLRSpaceItem::GetPresentation
void SvxLRSpaceItem::ScaleMetrics( tools::Long nMult, tools::Long nDiv )
{
nFirstLineOffset = static_cast<short>(BigInt::Scale( nFirstLineOffset, nMult, nDiv ));
m_dFirstLineOffset
= (m_dFirstLineOffset * static_cast<double>(nMult)) / static_cast<double>(nDiv);
nLeftMargin = BigInt::Scale( nLeftMargin, nMult, nDiv );
nRightMargin = BigInt::Scale( nRightMargin, nMult, nDiv );
}
@ -1790,7 +1884,10 @@ void SvxLRSpaceItem::dumpAsXml(xmlTextWriterPtr pWriter) const
{
(void)xmlTextWriterStartElement(pWriter, BAD_CAST("SvxLRSpaceItem"));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("whichId"), BAD_CAST(OString::number(Which()).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("nFirstLineOffset"), BAD_CAST(OString::number(nFirstLineOffset).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("m_dFirstLineOffset"),
BAD_CAST(OString::number(m_dFirstLineOffset).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("m_nFirstLineUnit"),
BAD_CAST(OString::number(m_nFirstLineUnit).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("nLeftMargin"), BAD_CAST(OString::number(nLeftMargin).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("nRightMargin"), BAD_CAST(OString::number(nRightMargin).getStr()));
(void)xmlTextWriterWriteAttribute(pWriter, BAD_CAST("m_nGutterMargin"),
@ -1821,8 +1918,8 @@ boost::property_tree::ptree SvxLRSpaceItem::dumpAsJSON() const
OUString sRight = GetMetricText(GetRight(),
MapUnit::MapTwip, eTargetUnit, nullptr);
OUString sFirstline = GetMetricText(GetTextFirstLineOffset(),
MapUnit::MapTwip, eTargetUnit, nullptr);
OUString sFirstline
= GetMetricText(ResolveTextFirstLineOffset({}), MapUnit::MapTwip, eTargetUnit, nullptr);
aState.put("left", sLeft);
aState.put("right", sRight);

View File

@ -1492,9 +1492,11 @@ tools::Rectangle Outliner::ImpCalcBulletArea( sal_Int32 nPara, bool bAdjust, boo
const auto nSpaceBefore = pFmt->GetAbsLSpace() + pFmt->GetFirstLineOffset();
const SvxLRSpaceItem& rLR = pEditEngine->GetParaAttrib( nPara, bOutlineMode ? EE_PARA_OUTLLRSPACE : EE_PARA_LRSPACE );
aTopLeft.setX( rLR.GetTextLeft() + rLR.GetTextFirstLineOffset() + nSpaceBefore );
aTopLeft.setX(rLR.GetTextLeft() + rLR.ResolveTextFirstLineOffset({}) + nSpaceBefore);
tools::Long nBulletWidth = std::max( static_cast<tools::Long>(-rLR.GetTextFirstLineOffset()), static_cast<tools::Long>((-pFmt->GetFirstLineOffset()) + pFmt->GetCharTextDistance()) );
tools::Long nBulletWidth = std::max(
static_cast<tools::Long>(-rLR.ResolveTextFirstLineOffset({})),
static_cast<tools::Long>((-pFmt->GetFirstLineOffset()) + pFmt->GetCharTextDistance()));
if ( nBulletWidth < aBulletSize.Width() ) // The Bullet creates its space
nBulletWidth = aBulletSize.Width();

View File

@ -325,7 +325,7 @@ void SvxRTFParser::ReadAttr( int nToken, SfxItemSet* pSet )
CalcValue();
nSz = sal_uInt16(nTokenValue);
}
aLR.SetTextFirstLineOffset( nSz );
aLR.SetTextFirstLineOffset(SvxIndentValue::twips(nSz));
pSet->Put( aLR );
}
break;

View File

@ -6189,7 +6189,7 @@ void PPTParagraphObj::ApplyTo( SfxItemSet& rSet, std::optional< sal_Int16 >& rS
{
auto const nAbsLSpace = convertMasterUnitToMm100(_nTextOfs);
auto const nFirstLineOffset = nAbsLSpace - convertMasterUnitToMm100(_nBulletOfs);
aLRSpaceItem.SetTextFirstLineOffsetValue( -nFirstLineOffset );
aLRSpaceItem.SetTextFirstLineOffset(SvxIndentValue::twips(-nFirstLineOffset));
aLRSpaceItem.SetTextLeft( nAbsLSpace );
}
rSet.Put( aLRSpaceItem );

View File

@ -63,6 +63,24 @@ struct SvxFontUnitMetrics
}
};
/// helper struct for passing indentation along with units
struct SvxIndentValue
{
double m_dValue;
sal_Int16 m_nUnit;
SvxIndentValue() = delete;
SvxIndentValue(double dValue, sal_Int16 nUnit)
: m_dValue(dValue)
, m_nUnit(nUnit)
{
}
static SvxIndentValue twips(double dValue) { return { dValue, css::util::MeasureUnit::TWIP }; }
static SvxIndentValue zero() { return twips(0.0); }
};
/// GetLeft() - for everything that's not applied to a paragraph
class EDITENG_DLLPUBLIC SvxLeftMarginItem final : public SfxPoolItem
{
@ -166,14 +184,15 @@ public:
void SetPropTextFirstLineOffset(sal_uInt16 nProp);
sal_uInt16 GetPropTextFirstLineOffset() const;
void SetTextFirstLineOffset(double dValue, sal_Int16 nUnit, sal_uInt16 nProp = 100);
void SetTextFirstLineOffset(SvxIndentValue stValue, sal_uInt16 nProp = 100);
SvxIndentValue GetTextFirstLineOffset() const;
double GetTextFirstLineOffsetValue() const;
sal_Int16 GetTextFirstLineOffsetUnit() const;
double ResolveTextFirstLineOffsetDouble(const SvxFontUnitMetrics& rMetrics) const;
sal_Int32 ResolveTextFirstLineOffset(const SvxFontUnitMetrics& rMetrics) const;
explicit SvxFirstLineIndentItem(const sal_uInt16 nId);
SvxFirstLineIndentItem(double dValue, sal_uInt16 nUnit, const sal_uInt16 nId);
SvxFirstLineIndentItem(SvxIndentValue stValue, const sal_uInt16 nId);
SvxFirstLineIndentItem(SvxFirstLineIndentItem const &) = default; // SfxPoolItem copy function dichotomy
// "pure virtual Methods" from SfxPoolItem
@ -306,7 +325,8 @@ public:
class EDITENG_DLLPUBLIC SvxLRSpaceItem final : public SfxPoolItem
{
/// First-line indent always relative to GetTextLeft()
short nFirstLineOffset;
double m_dFirstLineOffset = 0.0;
sal_Int16 m_nFirstLineUnit = css::util::MeasureUnit::TWIP;
tools::Long nLeftMargin; // nLeft or the negative first-line indent
tools::Long nRightMargin; // The unproblematic right edge
/// The amount of extra space added to the left margin.
@ -324,9 +344,8 @@ public:
static SfxPoolItem* CreateDefault();
explicit SvxLRSpaceItem( const sal_uInt16 nId );
SvxLRSpaceItem( const tools::Long nLeft, const tools::Long nRight,
const short nOfset /*= 0*/,
const sal_uInt16 nId );
SvxLRSpaceItem(const tools::Long nLeft, const tools::Long nRight, SvxIndentValue stValue,
const sal_uInt16 nId);
SvxLRSpaceItem(SvxLRSpaceItem const &) = default; // SfxPoolItem copy function dichotomy
// "pure virtual Methods" from SfxPoolItem
@ -351,7 +370,11 @@ public:
// Query/direct setting of the absolute values
tools::Long GetLeft() const { return nLeftMargin; }
tools::Long GetRight() const { return nRightMargin;}
void SetLeftValue( const tools::Long nL ) { assert(nFirstLineOffset == 0); nLeftMargin = nL; }
void SetLeftValue(const tools::Long nL)
{
assert(m_dFirstLineOffset == 0.0);
nLeftMargin = nL;
}
void SetRightValue( const tools::Long nR ) { nRightMargin = nR; }
bool IsAutoFirst() const { return bAutoFirst; }
void SetAutoFirst( const bool bNew ) { bAutoFirst = bNew; }
@ -367,14 +390,17 @@ public:
void SetTextLeft(const tools::Long nL, const sal_uInt16 nProp = 100);
tools::Long GetTextLeft() const;
void SetTextFirstLineOffset(const short nF, const sal_uInt16 nProp = 100);
short GetTextFirstLineOffset() const { return nFirstLineOffset; }
void SetTextFirstLineOffset(SvxIndentValue stValue, sal_uInt16 nProp = 100);
SvxIndentValue GetTextFirstLineOffset() const;
double GetTextFirstLineOffsetValue() const;
sal_Int16 GetTextFirstLineOffsetUnit() const;
double ResolveTextFirstLineOffsetDouble(const SvxFontUnitMetrics& rMetrics) const;
sal_Int32 ResolveTextFirstLineOffset(const SvxFontUnitMetrics& rMetrics) const;
void SetPropTextFirstLineOffset( const sal_uInt16 nProp )
{ nPropFirstLineOffset = nProp; }
sal_uInt16 GetPropTextFirstLineOffset() const
{ return nPropFirstLineOffset; }
void SetTextFirstLineOffsetValue( const short nValue )
{ nFirstLineOffset = nValue; }
void SetGutterMargin(const tools::Long nGutterMargin) { m_nGutterMargin = nGutterMargin; }
tools::Long GetGutterMargin() const { return m_nGutterMargin; }
void SetRightGutterMargin(const tools::Long nRightGutterMargin) { m_nRightGutterMargin = nRightGutterMargin; }

View File

@ -305,6 +305,8 @@ inline constexpr OUString UNO_NAME_EDIT_PARA_IS_HANGING_PUNCTUATION = u"ParaIsHa
inline constexpr OUString UNO_NAME_EDIT_PARA_IS_CHARACTER_DISTANCE = u"ParaIsCharacterDistance"_ustr;
inline constexpr OUString UNO_NAME_EDIT_PARA_IS_FORBIDDEN_RULES = u"ParaIsForbiddenRules"_ustr;
inline constexpr OUString UNO_NAME_EDIT_PARA_FIRST_LINE_INDENT = u"ParaFirstLineIndent"_ustr;
inline constexpr OUString UNO_NAME_EDIT_PARA_FIRST_LINE_INDENT_UNIT
= u"ParaFirstLineIndentUnit"_ustr;
inline constexpr OUString UNO_NAME_EDIT_CHAR_HEIGHT = u"CharHeight"_ustr;
inline constexpr OUString UNO_NAME_EDIT_CHAR_FONTNAME = u"CharFontName"_ustr;

View File

@ -29,6 +29,7 @@
#include <com/sun/star/text/XTextCursor.hpp>
#include <com/sun/star/lang/XTypeProvider.hpp>
#include <com/sun/star/lang/XServiceInfo.hpp>
#include <com/sun/star/beans/Pair.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/beans/XPropertyState.hpp>
#include <com/sun/star/beans/XMultiPropertySet.hpp>
@ -153,6 +154,7 @@ struct SfxItemPropertyMapEntry;
{ UNO_NAME_EDIT_PARA_TABSTOP_DEFAULT_DISTANCE, EE_PARA_TABS, ::cppu::UnoType<sal_Int32>::get(), 0, MID_TABSTOP_DEFAULT_DISTANCE }, \
{ UNO_NAME_EDIT_PARA_TMARGIN, EE_PARA_ULSPACE, ::cppu::UnoType<sal_Int32>::get(), 0, MID_UP_MARGIN, PropertyMoreFlags::METRIC_ITEM },\
{ UNO_NAME_EDIT_PARA_FIRST_LINE_INDENT, EE_PARA_LRSPACE, ::cppu::UnoType<sal_Int32>::get(), 0, MID_FIRST_LINE_INDENT, PropertyMoreFlags::METRIC_ITEM}, \
{ UNO_NAME_EDIT_PARA_FIRST_LINE_INDENT_UNIT, EE_PARA_LRSPACE, ::cppu::UnoType<css::beans::Pair<double, sal_Int16>>::get(), 0, MID_FIRST_LINE_UNIT_INDENT }, \
{ UNO_NAME_EDIT_PARA_IS_HANGING_PUNCTUATION,EE_PARA_HANGINGPUNCTUATION, cppu::UnoType<bool>::get(), 0 ,0 }, \
{ UNO_NAME_EDIT_PARA_IS_CHARACTER_DISTANCE, EE_PARA_ASIANCJKSPACING, cppu::UnoType<bool>::get(), 0 ,0 }, \
{ UNO_NAME_EDIT_PARA_IS_FORBIDDEN_RULES, EE_PARA_FORBIDDENRULES, cppu::UnoType<bool>::get(), 0 ,0 },\

View File

@ -2415,8 +2415,10 @@ void OReportController::openPageDialog(const uno::Reference<report::XSection>& _
{
aDescriptor.Put(SvxSizeItem(RPTUI_ID_SIZE,
VCLUnoHelper::ConvertToVCLSize(getStyleProperty<awt::Size>(m_xReportDefinition,PROPERTY_PAPERSIZE))));
aDescriptor.Put(SvxLRSpaceItem(getStyleProperty<sal_Int32>(m_xReportDefinition,PROPERTY_LEFTMARGIN)
,getStyleProperty<sal_Int32>(m_xReportDefinition,PROPERTY_RIGHTMARGIN),0,RPTUI_ID_LRSPACE));
aDescriptor.Put(SvxLRSpaceItem(
getStyleProperty<sal_Int32>(m_xReportDefinition, PROPERTY_LEFTMARGIN),
getStyleProperty<sal_Int32>(m_xReportDefinition, PROPERTY_RIGHTMARGIN),
SvxIndentValue::zero(), RPTUI_ID_LRSPACE));
aDescriptor.Put(SvxULSpaceItem(static_cast<sal_uInt16>(getStyleProperty<sal_Int32>(m_xReportDefinition,PROPERTY_TOPMARGIN))
,static_cast<sal_uInt16>(getStyleProperty<sal_Int32>(m_xReportDefinition,PROPERTY_BOTTOMMARGIN)),RPTUI_ID_ULSPACE));
aDescriptor.Put(SfxUInt16Item(SID_ATTR_METRIC,static_cast<sal_uInt16>(eUserMetric)));

View File

@ -175,10 +175,10 @@ SfxItemSet& ScStyleSheet::GetItemSet()
HFDIST_CM,// nLow
ATTR_ULSPACE );
SvxLRSpaceItem aLRSpaceItem( TWO_CM, // nLeft
TWO_CM, // nRight
0, // nFirstLineOffset
ATTR_LRSPACE );
SvxLRSpaceItem aLRSpaceItem(TWO_CM, // nLeft
TWO_CM, // nRight
SvxIndentValue::zero(), // nFirstLineOffset
ATTR_LRSPACE);
SvxULSpaceItem aULSpaceItem( TWO_CM, // nUp
TWO_CM, // nLow
ATTR_ULSPACE );
@ -193,7 +193,8 @@ SfxItemSet& ScStyleSheet::GetItemSet()
rHFSet.Put( aBoxInfoItem );
rHFSet.Put( aHFSizeItem );
rHFSet.Put( aHFDistItem );
rHFSet.Put( SvxLRSpaceItem(0, 0, 0, ATTR_LRSPACE) ); // Set border to Null
rHFSet.Put(SvxLRSpaceItem(0, 0, SvxIndentValue::zero(),
ATTR_LRSPACE)); // Set border to Null
aHFSetItem.SetWhich(ATTR_PAGE_HEADERSET);
pSet->Put( aHFSetItem );

View File

@ -970,8 +970,8 @@ void ScDrawTextObjectBar::ExecuteAttr( SfxRequest &rReq )
pArgs->Get( nId ));
SfxItemSetFixed<EE_PARA_LRSPACE, EE_PARA_LRSPACE> aAttr( GetPool() );
nId = EE_PARA_LRSPACE;
SvxLRSpaceItem aLRSpaceItem( rItem.GetLeft(),
rItem.GetRight(), rItem.GetTextFirstLineOffset(), nId );
SvxLRSpaceItem aLRSpaceItem(rItem.GetLeft(), rItem.GetRight(),
rItem.GetTextFirstLineOffset(), nId);
aAttr.Put( aLRSpaceItem );
pView->SetAttributes( aAttr );
}

View File

@ -439,7 +439,7 @@ void SdStyleSheetPool::CreateLayoutStyleSheets(std::u16string_view rLayoutName,
rNotesSet.Put( SvxCharReliefItem(FontRelief::NONE, EE_CHAR_RELIEF) );
rNotesSet.Put( SvxColorItem( COL_AUTO, EE_CHAR_COLOR ) );
rNotesSet.Put( SvxColorItem( COL_AUTO, EE_CHAR_BKGCOLOR ) );
rNotesSet.Put( SvxLRSpaceItem( 0, 0, -600, EE_PARA_LRSPACE ) );
rNotesSet.Put(SvxLRSpaceItem(0, 0, SvxIndentValue::twips(-600.0), EE_PARA_LRSPACE));
// #i16874# enable kerning by default but only for new documents
rNotesSet.Put( SvxAutoKernItem( true, EE_CHAR_PAIRKERNING ) );

View File

@ -582,8 +582,9 @@ void SdStyleSheet::AdjustToFontHeight(SfxItemSet& rSet, bool bOnlyMissingItems)
double fIndentFraction = double(rLRItem.GetTextLeft()) / nOldHeight;
SvxLRSpaceItem aNewLRItem(rLRItem);
aNewLRItem.SetTextLeft(fIndentFraction * nNewHeight);
double fFirstIndentFraction = double(rLRItem.GetTextFirstLineOffset()) / nOldHeight;
aNewLRItem.SetTextFirstLineOffset(static_cast<short>(fFirstIndentFraction * nNewHeight));
double fFirstIndentFraction = rLRItem.GetTextFirstLineOffsetValue() / nOldHeight;
aNewLRItem.SetTextFirstLineOffset(SvxIndentValue{ fFirstIndentFraction * nNewHeight,
rLRItem.GetTextFirstLineOffsetUnit() });
rSet.Put(aNewLRItem);
}

View File

@ -294,10 +294,10 @@ bool SdTransformOOo2xDocument::transformItemSet( SfxItemSet& rSet, bool bNumberi
if (pItem)
{
SvxLRSpaceItem aItem(*pItem);
if( (aItem.GetLeft() != 0) || (aItem.GetTextFirstLineOffset() != 0) )
if ((aItem.GetLeft() != 0) || (aItem.GetTextFirstLineOffsetValue() != 0.0))
{
aItem.SetLeftValue( 0 );
aItem.SetTextFirstLineOffset( 0 );
aItem.SetTextFirstLineOffset(SvxIndentValue::zero());
rSet.Put( aItem );
bRet = true;
}

View File

@ -244,7 +244,10 @@ void FuPage::ExecuteAsyncDialog(weld::Window* pParent, const SfxRequest& rReq)
SvxPaperBinItem aPaperBinItem( SID_ATTR_PAGE_PAPERBIN, static_cast<sal_uInt8>(mpPage->GetPaperBin()) );
aNewAttr->Put( aPaperBinItem );
SvxLRSpaceItem aLRSpaceItem( static_cast<sal_uInt16>(mpPage->GetLeftBorder()), static_cast<sal_uInt16>(mpPage->GetRightBorder()), 0, mpDoc->GetPool().GetWhichIDFromSlotID(SID_ATTR_LRSPACE));
SvxLRSpaceItem aLRSpaceItem(static_cast<sal_uInt16>(mpPage->GetLeftBorder()),
static_cast<sal_uInt16>(mpPage->GetRightBorder()),
SvxIndentValue::zero(),
mpDoc->GetPool().GetWhichIDFromSlotID(SID_ATTR_LRSPACE));
aNewAttr->Put( aLRSpaceItem );
SvxULSpaceItem aULSpaceItem( static_cast<sal_uInt16>(mpPage->GetUpperBorder()), static_cast<sal_uInt16>(mpPage->GetLowerBorder()), mpDoc->GetPool().GetWhichIDFromSlotID(SID_ATTR_ULSPACE));

View File

@ -347,14 +347,14 @@ void TextObjectBar::ExecuteImpl(ViewShell* mpViewShell, ::sd::View* mpView, SfxR
SvxLRSpaceItem aNewMargin( EE_PARA_LRSPACE );
::tools::Long nIndentDist = aParaMargin.GetTextFirstLineOffset();
auto nIndentDist = aParaMargin.ResolveTextFirstLineOffset({});
if (nIndentDist == 0)
if (nIndentDist == 0.0)
nIndentDist = nIndentDefaultDist;
aNewMargin.SetTextLeft(aParaMargin.GetTextLeft() + nIndentDist);
aNewMargin.SetRight(aParaMargin.GetRight());
aNewMargin.SetTextFirstLineOffset(nIndentDist * -1);
aNewMargin.SetTextFirstLineOffset(SvxIndentValue::twips(nIndentDist * -1));
aLRSpaceSet.Put( aNewMargin );
mpView->SetAttributes( aLRSpaceSet );

View File

@ -815,9 +815,8 @@ void DrawViewShell::ExecRuler(SfxRequest& rReq)
mpDrawView->GetAttributes( aEditAttr );
nId = EE_PARA_LRSPACE;
SvxLRSpaceItem aLRSpaceItem( rItem.GetLeft(),
rItem.GetRight(),
rItem.GetTextFirstLineOffset(), nId );
SvxLRSpaceItem aLRSpaceItem(rItem.GetLeft(), rItem.GetRight(),
rItem.GetTextFirstLineOffset(), nId);
const sal_Int16 nOutlineLevel = aEditAttr.Get( EE_PARA_OUTLLEVEL ).GetValue();
const SvxLRSpaceItem& rOrigLRSpaceItem = aEditAttr.Get( EE_PARA_LRSPACE );
@ -843,21 +842,19 @@ void DrawViewShell::ExecRuler(SfxRequest& rReq)
// negative first line indent goes to the number
// format, positive to the lrSpace item
if( rItem.GetTextFirstLineOffset() < 0 )
if (rItem.GetTextFirstLineOffsetValue() < 0.0)
{
aFormat.SetFirstLineOffset(
rItem.GetTextFirstLineOffset()
- rOrigLRSpaceItem.GetTextFirstLineOffset()
+ aFormat.GetCharTextDistance());
aLRSpaceItem.SetTextFirstLineOffset(0);
aFormat.SetFirstLineOffset(rItem.ResolveTextFirstLineOffset({})
- rOrigLRSpaceItem.ResolveTextFirstLineOffset({})
+ aFormat.GetCharTextDistance());
aLRSpaceItem.SetTextFirstLineOffset(SvxIndentValue::zero());
}
else
{
aFormat.SetFirstLineOffset(0);
aLRSpaceItem.SetTextFirstLineOffset(
rItem.GetTextFirstLineOffset()
- aFormat.GetFirstLineOffset() //TODO: overflow
+ aFormat.GetCharTextDistance());
aLRSpaceItem.SetTextFirstLineOffset(SvxIndentValue::twips(
rItem.ResolveTextFirstLineOffset({}) - aFormat.GetFirstLineOffset()
+ aFormat.GetCharTextDistance()));
}
if( rFormat != aFormat )
@ -945,9 +942,9 @@ void DrawViewShell::GetRulerState(SfxItemSet& rSet)
rSet.Put( rItem );
const SvxLRSpaceItem& rLRSpaceItem = aEditAttr.Get( EE_PARA_LRSPACE );
SvxLRSpaceItem aLRSpaceItem( rLRSpaceItem.GetLeft(),
rLRSpaceItem.GetRight(),
rLRSpaceItem.GetTextFirstLineOffset(), SID_ATTR_PARA_LRSPACE );
SvxLRSpaceItem aLRSpaceItem(rLRSpaceItem.GetLeft(), rLRSpaceItem.GetRight(),
rLRSpaceItem.GetTextFirstLineOffset(),
SID_ATTR_PARA_LRSPACE);
const sal_Int16 nOutlineLevel = aEditAttr.Get( EE_PARA_OUTLLEVEL ).GetValue();
const SvxNumBulletItem& rNumBulletItem = aEditAttr.Get( EE_PARA_NUMBULLET );
@ -956,10 +953,9 @@ void DrawViewShell::GetRulerState(SfxItemSet& rSet)
{
const SvxNumberFormat& rFormat = rNumBulletItem.GetNumRule().GetLevel(nOutlineLevel);
aLRSpaceItem.SetTextLeft(rFormat.GetAbsLSpace() + rLRSpaceItem.GetTextLeft());
aLRSpaceItem.SetTextFirstLineOffset(
rLRSpaceItem.GetTextFirstLineOffset() + rFormat.GetFirstLineOffset()
//TODO: overflow
- rFormat.GetCharTextDistance());
aLRSpaceItem.SetTextFirstLineOffset(SvxIndentValue::twips(
rLRSpaceItem.ResolveTextFirstLineOffset({})
+ rFormat.GetFirstLineOffset() - rFormat.GetCharTextDistance()));
}
rSet.Put( aLRSpaceItem );

View File

@ -78,7 +78,7 @@ OutlineView::OutlineView( DrawDocShell& rDocSh, vcl::Window* pWindow, OutlineVie
, mnPagesProcessed(0)
, mbFirstPaint(true)
, maDocColor( COL_WHITE )
, maLRSpaceItem(2000, 0, 0, EE_PARA_OUTLLRSPACE)
, maLRSpaceItem(2000, 0, SvxIndentValue::zero(), EE_PARA_OUTLLRSPACE)
{
bool bInitOutliner = false;

View File

@ -567,7 +567,7 @@ void SvxRuler::MouseMove( const MouseEvent& rMEvt )
if (nIndex == INDENT_LEFT_MARGIN)
nIndentValue = mxParaItem->GetTextLeft();
else if (nIndex == INDENT_FIRST_LINE)
nIndentValue = mxParaItem->GetTextFirstLineOffset();
nIndentValue = mxParaItem->ResolveTextFirstLineOffset({});
else if (nIndex == INDENT_RIGHT_MARGIN)
nIndentValue = mxParaItem->GetRight();
@ -846,13 +846,13 @@ void SvxRuler::UpdatePara()
if(bRTLText)
{
leftMargin = nRightFrameMargin - mxParaItem->GetTextLeft() + lAppNullOffset;
leftFirstLine = leftMargin - mxParaItem->GetTextFirstLineOffset();
leftFirstLine = leftMargin - mxParaItem->ResolveTextFirstLineOffset({});
rightMargin = nLeftFrameMargin + mxParaItem->GetRight() + lAppNullOffset;
}
else
{
leftMargin = nLeftFrameMargin + mxParaItem->GetTextLeft() + lAppNullOffset;
leftFirstLine = leftMargin + mxParaItem->GetTextFirstLineOffset();
leftFirstLine = leftMargin + mxParaItem->ResolveTextFirstLineOffset({});
rightMargin = nRightFrameMargin - mxParaItem->GetRight() + lAppNullOffset;
}
@ -2194,7 +2194,7 @@ void SvxRuler::ApplyIndents()
nNewRight = RoundToCurrentMapMode(nNewRight);
}
mxParaItem->SetTextFirstLineOffset(sal::static_int_cast<short>(nNewFirstLineOffset));
mxParaItem->SetTextFirstLineOffset(SvxIndentValue::twips(nNewFirstLineOffset));
mxParaItem->SetTextLeft(nNewTxtLeft);
mxParaItem->SetRight(nNewRight);

View File

@ -221,7 +221,9 @@ IMPL_LINK_NOARG( ParaPropertyPanel, ModifyIndentHdl_Impl, weld::MetricSpinButton
SvxLRSpaceItem aMargin( SID_ATTR_PARA_LRSPACE );
aMargin.SetTextLeft(mxLeftIndent->GetCoreValue(m_eLRSpaceUnit));
aMargin.SetRight(mxRightIndent->GetCoreValue(m_eLRSpaceUnit));
aMargin.SetTextFirstLineOffset(static_cast<short>(mxFLineIndent->GetCoreValue(m_eLRSpaceUnit)));
// tdf#36709: TODO: Handle font-relative units from GUI
aMargin.SetTextFirstLineOffset(
SvxIndentValue::twips(mxFLineIndent->GetCoreValue(m_eLRSpaceUnit)));
GetBindings()->GetDispatcher()->ExecuteList(
SID_ATTR_PARA_LRSPACE, SfxCallMode::RECORD, { &aMargin });
@ -401,7 +403,8 @@ void ParaPropertyPanel::StateChangedIndentImpl( SfxItemState eState, const SfxPo
tools::Long aTxtRight = pSpace->GetRight();
aTxtRight = OutputDevice::LogicToLogic(aTxtRight, m_eLRSpaceUnit, MapUnit::MapTwip);
tools::Long aTxtFirstLineOfst = pSpace->GetTextFirstLineOffset();
// tdf#36709: TODO: Handle font-relative units
tools::Long aTxtFirstLineOfst = pSpace->ResolveTextFirstLineOffset({});
aTxtFirstLineOfst = OutputDevice::LogicToLogic( aTxtFirstLineOfst, m_eLRSpaceUnit, MapUnit::MapTwip );
tools::Long nVal = o3tl::convert(maTxtLeft, o3tl::Length::twip, o3tl::Length::mm100);

View File

@ -215,7 +215,8 @@ void ParaLRSpacingWindow::SetValue(SfxItemState eState, const SfxPoolItem* pStat
const SvxLRSpaceItem* pSpace = static_cast<const SvxLRSpaceItem*>(pState);
tools::Long aTxtLeft = pSpace->GetTextLeft();
tools::Long aTxtRight = pSpace->GetRight();
tools::Long aTxtFirstLineOfst = pSpace->GetTextFirstLineOffset();
// tdf#36709: TODO: Handle font-relative units
tools::Long aTxtFirstLineOfst = pSpace->ResolveTextFirstLineOffset({});
aTxtLeft = m_xBeforeSpacing->normalize(aTxtLeft);
@ -294,7 +295,8 @@ IMPL_LINK_NOARG(ParaLRSpacingWindow, ModifySpacingHdl, weld::MetricSpinButton&,
SvxLRSpaceItem aMargin(SID_ATTR_PARA_LRSPACE);
aMargin.SetTextLeft(m_xBeforeSpacing->GetCoreValue(m_eUnit));
aMargin.SetRight(m_xAfterSpacing->GetCoreValue(m_eUnit));
aMargin.SetTextFirstLineOffset(m_xFLSpacing->GetCoreValue(m_eUnit));
// tdf#36709: TODO: Handle font-relative units from GUI
aMargin.SetTextFirstLineOffset(SvxIndentValue::twips(m_xFLSpacing->GetCoreValue(m_eUnit)));
pDisp->ExecuteList(SID_ATTR_PARA_LRSPACE, SfxCallMode::RECORD, {&aMargin});
}

View File

@ -674,7 +674,7 @@ void SwFormat::DelDiffs( const SfxItemSet& rSet )
void SwFormat::SetPageFormatToDefault()
{
const sal_Int32 nSize = o3tl::convert(2, o3tl::Length::cm, o3tl::Length::twip);
SetFormatAttr(SvxLRSpaceItem(nSize, nSize, 0, RES_LR_SPACE));
SetFormatAttr(SvxLRSpaceItem(nSize, nSize, SvxIndentValue::zero(), RES_LR_SPACE));
SetFormatAttr(SvxULSpaceItem(nSize, nSize, RES_UL_SPACE));
}

View File

@ -2438,7 +2438,7 @@ bool SwCursorShell::SetShadowCursorPos( const Point& rPt, SwFillMode eFillMode )
RES_MARGIN_FIRSTLINE, RES_MARGIN_TEXTLEFT> aSet(GetDoc()->GetAttrPool());
SvxFirstLineIndentItem firstLine(pCNd->GetAttr(RES_MARGIN_FIRSTLINE));
SvxTextLeftMarginItem leftMargin(pCNd->GetAttr(RES_MARGIN_TEXTLEFT));
firstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
leftMargin.SetTextLeft(aFPos.nTabCnt);
aSet.Put(firstLine);
aSet.Put(leftMargin);

View File

@ -212,8 +212,9 @@ namespace
{
SvxFirstLineIndentItem firstLine(pColl->GetFormatAttr(RES_MARGIN_FIRSTLINE));
SvxTextLeftMarginItem leftMargin(pColl->GetFormatAttr(RES_MARGIN_TEXTLEFT));
firstLine.SetTextFirstLineOffset(rNFormat.GetFirstLineOffset(),
rNFormat.GetFirstLineOffsetUnit());
firstLine.SetTextFirstLineOffset(
SvxIndentValue{ static_cast<double>(rNFormat.GetFirstLineOffset()),
rNFormat.GetFirstLineOffsetUnit() });
leftMargin.SetTextLeft(rNFormat.GetAbsLSpace());
pColl->SetFormatAttr(firstLine);
pColl->SetFormatAttr(leftMargin);
@ -257,7 +258,7 @@ namespace
sal_uInt16 nNxt, SwTwips nEZ, SwTwips nLeft,
SwTwips nUpper, SwTwips nLower )
{
SvxFirstLineIndentItem firstLine(nEZ, css::util::MeasureUnit::TWIP, RES_MARGIN_FIRSTLINE);
SvxFirstLineIndentItem firstLine(SvxIndentValue::twips(nEZ), RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(sal_uInt16(nLeft), RES_MARGIN_TEXTLEFT);
rSet.Put(firstLine);
@ -711,7 +712,7 @@ SwTextFormatColl* DocumentStylePoolManager::GetTextCollFromPool( sal_uInt16 nId,
case RES_POOLCOLL_TEXT_IDENT: // Text body indentation
{
auto const first(o3tl::convert(5, o3tl::Length::mm, o3tl::Length::twip));
SvxFirstLineIndentItem const firstLine(first, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(first),
RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(0, RES_MARGIN_TEXTLEFT);
aSet.Put(firstLine);
@ -722,7 +723,7 @@ SwTextFormatColl* DocumentStylePoolManager::GetTextCollFromPool( sal_uInt16 nId,
{
auto const first(-o3tl::convert(5, o3tl::Length::mm, o3tl::Length::twip));
auto const left(o3tl::convert(1, o3tl::Length::cm, o3tl::Length::twip));
SvxFirstLineIndentItem const firstLine(first, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(first),
RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(left, RES_MARGIN_TEXTLEFT);
aSet.Put(firstLine);
@ -747,7 +748,7 @@ SwTextFormatColl* DocumentStylePoolManager::GetTextCollFromPool( sal_uInt16 nId,
{
auto const first(-o3tl::convert(45, o3tl::Length::mm, o3tl::Length::twip));
auto const left(o3tl::convert(5, o3tl::Length::cm, o3tl::Length::twip));
SvxFirstLineIndentItem const firstLine(first, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(first),
RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(left, RES_MARGIN_TEXTLEFT);
aSet.Put(firstLine);
@ -956,7 +957,7 @@ SwTextFormatColl* DocumentStylePoolManager::GetTextCollFromPool( sal_uInt16 nId,
{
auto const first(-o3tl::convert(6, o3tl::Length::mm, o3tl::Length::twip));
auto const left(o3tl::convert(6, o3tl::Length::mm, o3tl::Length::twip));
SvxFirstLineIndentItem const firstLine(first, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(first),
RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(left, RES_MARGIN_TEXTLEFT);
aSet.Put(firstLine);
@ -1683,7 +1684,7 @@ SwFormat* DocumentStylePoolManager::GetFormatFromPool( sal_uInt16 nId )
aBox.SetLine( &aLine, SvxBoxItemLine::RIGHT );
aBox.SetAllDistances( 85 );
aSet.Put( aBox );
aSet.Put( SvxLRSpaceItem( 114, 114, 0, RES_LR_SPACE ) );
aSet.Put(SvxLRSpaceItem(114, 114, SvxIndentValue::zero(), RES_LR_SPACE));
aSet.Put( SvxULSpaceItem( 114, 114, RES_UL_SPACE ) );
}
@ -1705,7 +1706,7 @@ SwFormat* DocumentStylePoolManager::GetFormatFromPool( sal_uInt16 nId )
{
aSet.Put( SwFormatAnchor( RndStdIds::FLY_AS_CHAR ) );
aSet.Put( SwFormatVertOrient( 0, text::VertOrientation::CHAR_CENTER, text::RelOrientation::FRAME ) );
aSet.Put( SvxLRSpaceItem( 0, 0, 0, RES_LR_SPACE ) );
aSet.Put(SvxLRSpaceItem(0, 0, SvxIndentValue::zero(), RES_LR_SPACE));
if ( RES_POOLFRM_INLINE_HEADING == nId )
{
@ -1746,7 +1747,7 @@ SwFormat* DocumentStylePoolManager::GetFormatFromPool( sal_uInt16 nId )
{
aSet.Put( SwFormatAnchor( RndStdIds::FLY_AS_CHAR ) );
aSet.Put( SwFormatVertOrient( 0, text::VertOrientation::TOP, text::RelOrientation::FRAME ) );
aSet.Put( SvxLRSpaceItem( 114, 114, 0, RES_LR_SPACE ) );
aSet.Put(SvxLRSpaceItem(114, 114, SvxIndentValue::zero(), RES_LR_SPACE));
SvxProtectItem aProtect( RES_PROTECT );
aProtect.SetSizeProtect( true );

View File

@ -1706,8 +1706,9 @@ void SwDoc::MoveLeftMargin(const SwPaM& rPam, bool bRight, bool bModulus,
}
if (indents & ::sw::ListLevelIndents::FirstLine)
{
firstLine.SetTextFirstLineOffset(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit());
firstLine.SetTextFirstLineOffset(SvxIndentValue{
static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() });
}
}
}

View File

@ -252,8 +252,7 @@ void SwTextFormatColl::SwClientNotify(const SwModify& rModify, const SfxHint& rH
if (100 != pOldFirstLineIndent->GetPropTextFirstLineOffset())
{
const double dOld = pOldFirstLineIndent->GetTextFirstLineOffsetValue();
aNew.SetTextFirstLineOffset(pNewFirstLineIndent->GetTextFirstLineOffsetValue(),
pNewFirstLineIndent->GetTextFirstLineOffsetUnit(),
aNew.SetTextFirstLineOffset(pNewFirstLineIndent->GetTextFirstLineOffset(),
pOldFirstLineIndent->GetPropTextFirstLineOffset());
bChg = dOld != aNew.GetTextFirstLineOffsetValue();
}

View File

@ -431,7 +431,8 @@ const SwTable* SwDoc::InsertTable( const SwInsertTableOptions& rInsTableOpts,
{
sal_uInt16 nFrameWidth = nLastPos;
nLastPos = (*pColArr)[ pColArr->size()-2 ];
pTableFormat->SetFormatAttr( SvxLRSpaceItem( nSttPos, nFrameWidth - nLastPos, 0, RES_LR_SPACE ) );
pTableFormat->SetFormatAttr(SvxLRSpaceItem(nSttPos, nFrameWidth - nLastPos,
SvxIndentValue::zero(), RES_LR_SPACE));
}
nWidth = nLastPos - nSttPos;
}

View File

@ -3021,7 +3021,6 @@ static SwTwips lcl_CalcAutoWidth( const SwLayoutFrame& rFrame )
SvxRightMarginItem const& rRightMargin(rParaSet.GetRightMargin());
if (!static_cast<const SwTextFrame*>(pFrame)->IsLocked())
{
// tdf#36709: TODO: Handle font-relative first-line indent
nMin += rRightMargin.GetRight() + rLeftMargin.GetTextLeft()
+ rFirstLine.ResolveTextFirstLineOffset({});
}

View File

@ -2353,7 +2353,6 @@ tools::Long SwBorderAttrs::CalcRight( const SwFrame* pCaller ) const
{
if (pCaller->IsRightToLeft())
{
// tdf#36709: TODO: Handle font-relative units
nRight += m_pTextLeftMargin->GetLeft(*m_pFirstLineIndent, /*metrics*/ {});
}
else
@ -2409,7 +2408,6 @@ tools::Long SwBorderAttrs::CalcLeft( const SwFrame *pCaller ) const
{
if (pCaller->IsTextFrame())
{
// tdf#36709: TODO: Handle font-relative units
nLeft += m_pTextLeftMargin->GetLeft(*m_pFirstLineIndent, /*metrics*/ {});
}
else

View File

@ -216,7 +216,6 @@ bool SwTextFrame::GetCharRect( SwRect& rOrig, const SwPosition &rPos,
Point aPnt1 = pFrame->getFrameArea().Pos() + pFrame->getFramePrintArea().Pos();
SwTextNode const*const pTextNd(GetTextNodeForParaProps());
short nFirstOffset;
// tdf#36709: TODO: Handle font-relative units
pTextNd->GetFirstLineOfsWithNum(nFirstOffset, {});
Point aPnt2;
@ -1484,7 +1483,6 @@ void SwTextFrame::FillCursorPos( SwFillData& rFill ) const
rRect.Top( rRect.Top() + nFirst );
rRect.Height( nLineHeight );
// tdf#36709: TODO: Handle font-relative units
SwTwips nLeft = rFill.Left() + rTextLeftMargin.GetLeft(rFirstLine, /*metrics*/ {})
+ GetTextNodeForParaProps()->GetLeftMarginWithNum();
SwTwips nRight = rFill.Right() - rRightMargin.GetRight();

View File

@ -575,7 +575,6 @@ bool SwTextFrame::PaintEmpty( const SwRect &rRect, bool bCheck ) const
const SvxFirstLineIndentItem& rFirstLine(
GetTextNodeForParaProps()->GetSwAttrSet().GetFirstLineIndent());
// tdf#36709: TODO: Handle font-relative first-line indentation
if (0.0 < rFirstLine.GetTextFirstLineOffsetValue())
{
aPos.AdjustX(rFirstLine.ResolveTextFirstLineOffset({}));

View File

@ -1085,7 +1085,6 @@ void SwTextNode::GetMinMaxSize( SwNodeOffset nIndex, sal_uLong& rMin, sal_uLong
tools::Long nLROffset = rTextLeftMargin.GetTextLeft() + GetLeftMarginWithNum( true );
short nFLOffs;
// For enumerations a negative first line indentation is probably filled already
// tdf#36709: TODO: Handle font-relative units
if (!GetFirstLineOfsWithNum(nFLOffs, {}) || nFLOffs > nLROffset)
nLROffset = nFLOffs;

View File

@ -604,7 +604,6 @@ bool SwNumberPortion::Format( SwTextFormatInfo &rInf )
(IsFootnoteNumPortion() &&
rInf.GetTextFrame()->GetDoc().getIDocumentSettingAccess().get(DocumentSettingId::NO_GAP_AFTER_NOTE_NUMBER)))
{
// tdf#36709: TODO: Handle font-relative first line indentation
nDiff = rInf.Left()
+ rInf.GetTextFrame()
->GetTextNodeForParaProps()

View File

@ -115,7 +115,6 @@ auto DefaultToxTabStopTokenHandler::CalcEndStop(SwTextNode const& rNode,
SvxTextLeftMarginItem const& rTextLeftMargin(
rNode.GetTextColl()->GetTextLeftMargin());
// tdf#36709: TODO: Handle font-relative units
nRightMargin -= rTextLeftMargin.GetLeft(rFirstLine, /*metrics*/ {});
nRightMargin -= rFirstLine.ResolveTextFirstLineOffset(/*metrics*/ {});
}

View File

@ -3311,7 +3311,6 @@ tools::Long SwTextNode::GetLeftMarginWithNum( bool bTextLeft ) const
if( pRule->IsAbsSpaces() )
{
SvxFirstLineIndentItem const& rFirst(GetSwAttrSet().GetFirstLineIndent());
// tdf#36709: TODO: Handle font-relative units
nRet = nRet - GetSwAttrSet().GetTextLeftMargin().GetLeft(rFirst, /*metrics*/ {});
}
}
@ -3325,7 +3324,6 @@ tools::Long SwTextNode::GetLeftMarginWithNum( bool bTextLeft ) const
// list/paragraph items. (this is rather inelegant)
SvxFirstLineIndentItem firstLine(GetSwAttrSet().GetFirstLineIndent());
SvxTextLeftMarginItem leftMargin(GetSwAttrSet().GetTextLeftMargin());
// tdf#36709: TODO: Handle font-relative units
nRet = bTextLeft ? -leftMargin.GetTextLeft()
: -leftMargin.GetLeft(firstLine, /*metrics*/ {});
if (indents & ::sw::ListLevelIndents::LeftMargin)
@ -3334,10 +3332,10 @@ tools::Long SwTextNode::GetLeftMarginWithNum( bool bTextLeft ) const
}
if (indents & ::sw::ListLevelIndents::FirstLine)
{
firstLine.SetTextFirstLineOffset(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit());
firstLine.SetTextFirstLineOffset(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() });
}
// tdf#36709: TODO: Handle font-relative units
nRet += bTextLeft ? leftMargin.GetTextLeft()
: leftMargin.GetLeft(firstLine, /*metrics*/ {});
}
@ -3402,12 +3400,10 @@ SwTwips SwTextNode::GetAdditionalIndentForStartingNewList() const
{
SvxFirstLineIndentItem const& rFirst(GetSwAttrSet().GetFirstLineIndent());
// tdf#36709: TODO: Handle font-relative indentation
nAdditionalIndent = GetSwAttrSet().GetTextLeftMargin().GetLeft(rFirst, /*metrics*/ {});
if (getIDocumentSettingAccess()->get(DocumentSettingId::IGNORE_FIRST_LINE_INDENT_IN_NUMBERING))
{
// tdf#36709: TODO: Handle font-relative indentation
nAdditionalIndent
= nAdditionalIndent
- GetSwAttrSet().GetFirstLineIndent().ResolveTextFirstLineOffset({});
@ -3420,21 +3416,21 @@ SwTwips SwTextNode::GetAdditionalIndentForStartingNewList() const
// other use of it.
::sw::ListLevelIndents const indents(AreListLevelIndentsApplicable());
SvxFirstLineIndentItem const aFirst(
indents & ::sw::ListLevelIndents::FirstLine
? SvxFirstLineIndentItem(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit(), RES_MARGIN_FIRSTLINE)
indents & ::sw::ListLevelIndents::FirstLine
? SvxFirstLineIndentItem(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() },
RES_MARGIN_FIRSTLINE)
: GetSwAttrSet().GetFirstLineIndent());
SvxTextLeftMarginItem const aLeft(
indents & ::sw::ListLevelIndents::LeftMargin
? SvxTextLeftMarginItem(rFormat.GetIndentAt(), RES_MARGIN_TEXTLEFT)
: GetSwAttrSet().GetTextLeftMargin());
// tdf#36709: TODO: Handle font-relative indentation
nAdditionalIndent = aLeft.GetLeft(aFirst, /*metrics*/ {});
if (!(indents & ::sw::ListLevelIndents::FirstLine))
{
if (getIDocumentSettingAccess()->get(DocumentSettingId::IGNORE_FIRST_LINE_INDENT_IN_NUMBERING))
{
// tdf#36709: TODO: Handle font-relative first line indentation
nAdditionalIndent = nAdditionalIndent - aFirst.ResolveTextFirstLineOffset({});
}
}
@ -3442,7 +3438,6 @@ SwTwips SwTextNode::GetAdditionalIndentForStartingNewList() const
}
else
{
// tdf#36709: TODO: Handle font-relative first line indentation
SvxFirstLineIndentItem const& rFirst(GetSwAttrSet().GetFirstLineIndent());
nAdditionalIndent = GetSwAttrSet().GetTextLeftMargin().GetLeft(rFirst, /*metrics*/ {});
}

View File

@ -2135,9 +2135,10 @@ static void lcl_MergeListLevelIndentAsLRSpaceItem( const SwTextNode& rTextNode,
{
if (indents & ::sw::ListLevelIndents::FirstLine)
{
SvxFirstLineIndentItem const firstLine(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit(),
RES_MARGIN_FIRSTLINE);
SvxFirstLineIndentItem const firstLine(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() },
RES_MARGIN_FIRSTLINE);
rSet.Put(firstLine);
}
if (indents & ::sw::ListLevelIndents::LeftMargin)

View File

@ -2867,8 +2867,8 @@ static SwHTMLWriter& OutCSS1_SvxLRSpace( SwHTMLWriter& rWrt, const SfxPoolItem&
}
// The LineIndent of the first line might contain the room for numbering
tools::Long nFirstLineIndent = static_cast<tools::Long>(rLRItem.GetTextFirstLineOffset()) -
rWrt.m_nFirstLineIndent;
tools::Long nFirstLineIndent = static_cast<tools::Long>(rLRItem.ResolveTextFirstLineOffset({}))
- rWrt.m_nFirstLineIndent;
if( rWrt.m_nDfltFirstLineIndent != nFirstLineIndent )
{
rWrt.OutCSS1_UnitProperty( sCSS1_P_text_indent,

View File

@ -644,7 +644,7 @@ void SwHTMLParser::InsertAttrs( SfxItemSet &rItemSet,
pContext->SetMargins( nLeft, nRight, nIndent );
// Set the attribute on the current paragraph
SvxFirstLineIndentItem firstLine(nIndent, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem firstLine(SvxIndentValue::twips(nIndent),
RES_MARGIN_FIRSTLINE);
NewAttr(m_xAttrTab, &m_xAttrTab->pFirstLineIndent, firstLine);
EndAttr(m_xAttrTab->pFirstLineIndent, false);

View File

@ -3459,7 +3459,8 @@ void SwHTMLParser::BuildTableCell( HTMLTable *pCurTable, bool bReadOptions,
sal_uInt16 nSpace = pCurTable->GetHSpace();
if( nSpace )
aFrameSet.Put( SvxLRSpaceItem(nSpace, nSpace, 0, RES_LR_SPACE) );
aFrameSet.Put(
SvxLRSpaceItem(nSpace, nSpace, SvxIndentValue::zero(), RES_LR_SPACE));
nSpace = pCurTable->GetVSpace();
if( nSpace )
aFrameSet.Put( SvxULSpaceItem(nSpace,nSpace, RES_UL_SPACE) );

View File

@ -1987,8 +1987,7 @@ static void ParseCSS1_text_indent( const CSS1Expression *pExpr,
if( !bSet )
return;
SvxFirstLineIndentItem const firstLine(nIndent, css::util::MeasureUnit::TWIP,
RES_MARGIN_FIRSTLINE);
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(nIndent), RES_MARGIN_FIRSTLINE);
rItemSet.Put(firstLine);
rPropInfo.m_bTextIndent = true;
}

View File

@ -4846,7 +4846,7 @@ void SwHTMLParser::SetTextCollAttrs( HTMLAttrContext *pContext )
SvxFirstLineIndentItem firstLine(rFirstLine);
SvxTextLeftMarginItem leftMargin(rTextLeftMargin);
SvxRightMarginItem rightMargin(rRightMargin);
firstLine.SetTextFirstLineOffset(nFirstLineIndent, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::twips(nFirstLineIndent));
leftMargin.SetTextLeft(nLeftMargin);
rightMargin.SetRight(nRightMargin);
if( pItemSet )
@ -5081,7 +5081,7 @@ void SwHTMLParser::InsertSpacer()
GetMarginsFromContextWithNumberBullet( nLeft, nRight, nIndent );
nIndent = nIndent + static_cast<short>(nSize);
SvxFirstLineIndentItem const firstLine(nIndent, css::util::MeasureUnit::TWIP,
SvxFirstLineIndentItem const firstLine(SvxIndentValue::twips(nIndent),
RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem const leftMargin(nLeft, RES_MARGIN_TEXTLEFT);
SvxRightMarginItem const rightMargin(nRight, RES_MARGIN_RIGHT);

View File

@ -9397,7 +9397,8 @@ void DocxAttributeOutput::FormatLRSpace( const SvxLRSpaceItem& rLRSpace )
{
pLRSpaceAttrList->add( FSNS(XML_w, (bEcma ? XML_right : XML_end)), OString::number(pLRSpace->GetRight()) );
}
sal_Int32 const nFirstLineAdjustment = pLRSpace->GetTextFirstLineOffset();
// tdf#83844: TODO: export FONT_CJK_ADVANCE first line indent as HangingChars/FirstLineChars
sal_Int32 const nFirstLineAdjustment = pLRSpace->ResolveTextFirstLineOffset({});
if (nFirstLineAdjustment > 0)
pLRSpaceAttrList->add( FSNS( XML_w, XML_firstLine ), OString::number( nFirstLineAdjustment ) );
else

View File

@ -3254,8 +3254,8 @@ void RtfAttributeOutput::ParaNumRule_Impl(const SwTextNode* pTextNd, sal_Int32 n
SvxTextLeftMarginItem leftMargin(rNdSet.Get(RES_MARGIN_TEXTLEFT));
leftMargin.SetTextLeft(leftMargin.GetTextLeft() + pFormat->GetIndentAt());
firstLine.SetTextFirstLineOffset(pFormat->GetFirstLineOffset(),
pFormat->GetFirstLineOffsetUnit());
firstLine.SetTextFirstLineOffset(SvxIndentValue{
static_cast<double>(pFormat->GetFirstLineOffset()), pFormat->GetFirstLineOffsetUnit() });
sal_uInt16 nStyle = m_rExport.GetId(pFormat->GetCharFormat());
OString* pString = m_rExport.GetStyle(nStyle);
@ -3459,7 +3459,7 @@ void RtfAttributeOutput::FormatLRSpace(const SvxLRSpaceItem& rLRSpace)
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_RIN);
m_aStyles.append(static_cast<sal_Int32>(rLRSpace.GetRight()));
m_aStyles.append(OOO_STRING_SVTOOLS_RTF_FI);
m_aStyles.append(static_cast<sal_Int32>(rLRSpace.GetTextFirstLineOffset()));
m_aStyles.append(rLRSpace.ResolveTextFirstLineOffset({}));
}
}
else if (m_rExport.GetRTFFlySyntax())

View File

@ -3062,17 +3062,15 @@ void MSWordExportBase::OutputTextNode( SwTextNode& rNode )
{
if (bParaRTL)
{
firstLine.SetTextFirstLineOffset(
firstLine.SetTextFirstLineOffset(SvxIndentValue::twips(
firstLine.ResolveTextFirstLineOffset({}) + pFormat->GetAbsLSpace()
- pFormat->GetFirstLineOffset(),
css::util::MeasureUnit::TWIP);
- pFormat->GetFirstLineOffset()));
}
else
{
firstLine.SetTextFirstLineOffset(
firstLine.ResolveTextFirstLineOffset({})
+ GetWordFirstLineOffset(*pFormat),
css::util::MeasureUnit::TWIP);
SvxIndentValue::twips(firstLine.ResolveTextFirstLineOffset({})
+ GetWordFirstLineOffset(*pFormat)));
}
}
@ -3205,7 +3203,7 @@ void MSWordExportBase::OutputTextNode( SwTextNode& rNode )
// (first line indent is ignored)
if (!bParaRTL)
{
firstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
}
// put back the new item

View File

@ -1729,9 +1729,9 @@ void MSWordExportBase::SectionProperties( const WW8_SepInfo& rSepInfo, WW8_PdAtt
const SvxLRSpaceItem &rPageLR =
pPdFormat->GetFormatAttr( RES_LR_SPACE );
SvxLRSpaceItem aResultLR( rPageLR.GetLeft() +
rSectionLR.GetLeft(), rPageLR.GetRight() +
rSectionLR.GetRight(), 0, RES_LR_SPACE );
SvxLRSpaceItem aResultLR(rPageLR.GetLeft() + rSectionLR.GetLeft(),
rPageLR.GetRight() + rSectionLR.GetRight(),
SvxIndentValue::zero(), RES_LR_SPACE);
//i120133: The Section width should consider section indent value.
if (rSectionLR.GetLeft()+rSectionLR.GetRight()!=0)
{

View File

@ -927,8 +927,8 @@ void MSWordExportBase::OutputFormat( const SwFormat& rFormat, bool bPapFormat, b
SvxTextLeftMarginItem leftMargin(aSet.Get(RES_MARGIN_TEXTLEFT));
leftMargin.SetTextLeft(leftMargin.GetTextLeft() + rNFormat.GetAbsLSpace());
firstLine.SetTextFirstLineOffset(GetWordFirstLineOffset(rNFormat),
css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(
SvxIndentValue::twips(GetWordFirstLineOffset(rNFormat)));
aSet.Put(firstLine);
aSet.Put(leftMargin);
@ -4427,8 +4427,9 @@ void WW8AttributeOutput::FormatLRSpace( const SvxLRSpaceItem& rLR )
m_rWW8Export.InsUInt16( o3tl::narrowing<sal_uInt16>(rLR.GetRight()) );
// sprmPDxaLeft1
// tdf#80596: TODO export sprmPDxcLeft1 for first line indents in ICs
m_rWW8Export.InsUInt16( 0x8460 ); //asian version ?
m_rWW8Export.InsUInt16( rLR.GetTextFirstLineOffset() );
m_rWW8Export.InsUInt16(rLR.ResolveTextFirstLineOffset({}));
}
}

View File

@ -525,8 +525,8 @@ void SwWW8ImplReader::InsertTxbxStyAttrs(SfxItemSet& rS, sal_uInt16 nColl, ManTy
&& "unnecessary when EditEng learns about the separate pieces");
SvxLRSpaceItem aLR(rS.Get(EE_PARA_LRSPACE));
aLR.SetTextFirstLineOffset(
pStyInf->m_pFormat->GetFirstLineIndent().ResolveTextFirstLineOffset({}));
const auto& rFirstLine = pStyInf->m_pFormat->GetFirstLineIndent();
aLR.SetTextFirstLineOffset(rFirstLine.GetTextFirstLineOffset());
aLR.SetTextLeft(pStyInf->m_pFormat->GetTextLeftMargin().GetTextLeft());
aLR.SetRight(pStyInf->m_pFormat->GetRightMargin().GetRight());
rS.Put(aLR);
@ -771,9 +771,9 @@ void SwWW8ImplReader::InsertAttrsAsDrawingAttrs(WW8_CP nStartCp, WW8_CP nEndCp,
SvxLRSpaceItem aLR(pS->Get(EE_PARA_LRSPACE));
if (nWhich == RES_MARGIN_FIRSTLINE)
{
aLR.SetTextFirstLineOffset(
static_cast<const SvxFirstLineIndentItem*>(pItem)
->ResolveTextFirstLineOffset({}));
const auto* pFirstLine
= static_cast<const SvxFirstLineIndentItem*>(pItem);
aLR.SetTextFirstLineOffset(pFirstLine->GetTextFirstLineOffset());
}
else if (nWhich == RES_MARGIN_TEXTLEFT)
{
@ -2052,7 +2052,8 @@ void SwWW8ImplReader::MapWrapIntoFlyFormat(const SvxMSDffImportRec& rRecord,
if (rRecord.nDxWrapDistLeft || rRecord.nDxWrapDistRight)
{
SvxLRSpaceItem aLR(writer_cast<sal_uInt16>(rRecord.nDxWrapDistLeft),
writer_cast<sal_uInt16>(rRecord.nDxWrapDistRight), 0, RES_LR_SPACE);
writer_cast<sal_uInt16>(rRecord.nDxWrapDistRight),
SvxIndentValue::zero(), RES_LR_SPACE);
AdjustLRWrapForWordMargins(rRecord, aLR);
rFlyFormat.SetFormatAttr(aLR);
}

View File

@ -1249,15 +1249,16 @@ void SyncIndentWithList( SvxFirstLineIndentItem & rFirstLine,
tools::Long nWantedFirstLinePos;
tools::Long nExtraListIndent = lcl_GetTrueMargin(rFirstLine, rLeftMargin, rFormat, nWantedFirstLinePos);
rLeftMargin.SetTextLeft(nWantedFirstLinePos - nExtraListIndent);
rFirstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
rFirstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
}
else if ( rFormat.GetPositionAndSpaceMode() == SvxNumberFormat::LABEL_ALIGNMENT )
{
if ( !bFirstLineOfstSet && bLeftIndentSet &&
rFormat.GetFirstLineIndent() != 0 )
{
rFirstLine.SetTextFirstLineOffset(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit());
rFirstLine.SetTextFirstLineOffset(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() });
}
else if ( bFirstLineOfstSet && !bLeftIndentSet &&
rFormat.GetIndentAt() != 0 )
@ -1268,8 +1269,9 @@ void SyncIndentWithList( SvxFirstLineIndentItem & rFirstLine,
{
if ( rFormat.GetFirstLineIndent() != 0 )
{
rFirstLine.SetTextFirstLineOffset(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit());
rFirstLine.SetTextFirstLineOffset(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() });
}
if ( rFormat.GetIndentAt() != 0 )
{
@ -1358,8 +1360,7 @@ void SwWW8FltControlStack::SetAttrInDoc(const SwPosition& rTmpPos,
{
SvxFirstLineIndentItem const firstLineEntry(*static_cast<SvxFirstLineIndentItem*>(rEntry.m_pAttr.get()));
firstLineNew.SetTextFirstLineOffset(
firstLineEntry.GetTextFirstLineOffsetValue(),
firstLineEntry.GetTextFirstLineOffsetUnit(),
firstLineEntry.GetTextFirstLineOffset(),
firstLineEntry.GetPropTextFirstLineOffset());
firstLineNew.SetAutoFirst(firstLineEntry.IsAutoFirst());
}
@ -1386,8 +1387,7 @@ void SwWW8FltControlStack::SetAttrInDoc(const SwPosition& rTmpPos,
else
{
firstLineNew.SetTextFirstLineOffset(
firstLineOld.GetTextFirstLineOffsetValue(),
firstLineOld.GetTextFirstLineOffsetUnit(),
firstLineOld.GetTextFirstLineOffset(),
firstLineOld.GetPropTextFirstLineOffset());
firstLineNew.SetAutoFirst(firstLineOld.IsAutoFirst());
}

View File

@ -1680,8 +1680,7 @@ void UseListIndent(SwWW8StyInf &rStyle, const SwNumFormat &rFormat)
SvxFirstLineIndentItem firstLine(rStyle.m_pFormat->GetFormatAttr(RES_MARGIN_FIRSTLINE));
SvxTextLeftMarginItem leftMargin(rStyle.m_pFormat->GetFormatAttr(RES_MARGIN_TEXTLEFT));
leftMargin.SetTextLeft(nAbsLSpace);
firstLine.SetTextFirstLineOffset(writer_cast<short>(nListFirstLineIndent),
css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::twips(nListFirstLineIndent));
rStyle.m_pFormat->SetFormatAttr(firstLine);
rStyle.m_pFormat->SetFormatAttr(leftMargin);
rStyle.m_bListRelevantIndentSet = true;
@ -1703,7 +1702,7 @@ void SetStyleIndent(SwWW8StyInf &rStyle, const SwNumFormat &rFormat)
else
{
leftMargin.SetTextLeft(0);
firstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
}
rStyle.m_pFormat->SetFormatAttr(firstLine);
rStyle.m_pFormat->SetFormatAttr(leftMargin);
@ -2021,7 +2020,7 @@ void SwWW8ImplReader::Read_LFOPosition(sal_uInt16, const sal_uInt8* pData,
pFirstLine.reset(pItem->Clone());
// reset/blank the left indent (and only the left)
pFirstLine->SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
pFirstLine->SetTextFirstLineOffset(SvxIndentValue::zero());
SvxTextLeftMarginItem leftMargin(0, RES_MARGIN_TEXTLEFT);
// apply the modified SvxLRSpaceItem to the current paragraph

View File

@ -523,7 +523,8 @@ void wwSectionManager::SetPage(SwPageDesc &rInPageDesc, SwFrameFormat &rFormat,
aSz.SetHeight(SvxPaperInfo::GetSloppyPaperDimension(rSection.GetPageHeight()));
rFormat.SetFormatAttr(aSz);
SvxLRSpaceItem aLR(rSection.GetPageLeft(), rSection.GetPageRight(), 0, RES_LR_SPACE);
SvxLRSpaceItem aLR(rSection.GetPageLeft(), rSection.GetPageRight(), SvxIndentValue::zero(),
RES_LR_SPACE);
aLR.SetGutterMargin(rSection.m_nPgGutter);
rFormat.SetFormatAttr(aLR);
@ -761,7 +762,7 @@ SwSectionFormat *wwSectionManager::InsertSection(
tools::Long nSectionRight = rSection.GetPageRight() - nPageRight;
if ((nSectionLeft != 0) || (nSectionRight != 0))
{
SvxLRSpaceItem aLR(nSectionLeft, nSectionRight, 0, RES_LR_SPACE);
SvxLRSpaceItem aLR(nSectionLeft, nSectionRight, SvxIndentValue::zero(), RES_LR_SPACE);
pFormat->SetFormatAttr(aLR);
}
@ -2198,7 +2199,8 @@ WW8FlySet::WW8FlySet(SwWW8ImplReader& rReader, const WW8FlyPara* pFW,
Put( SwFormatVertOrient( pFS->nYPos, pFS->eVAlign, pFS->eVRel ) );
if (pFS->nLeftMargin || pFS->nRightMargin) // set borders
Put(SvxLRSpaceItem(pFS->nLeftMargin, pFS->nRightMargin, 0, RES_LR_SPACE));
Put(SvxLRSpaceItem(pFS->nLeftMargin, pFS->nRightMargin, SvxIndentValue::zero(),
RES_LR_SPACE));
if (pFS->nUpperMargin || pFS->nLowerMargin)
Put(SvxULSpaceItem(pFS->nUpperMargin, pFS->nLowerMargin, RES_UL_SPACE));
@ -2259,7 +2261,7 @@ WW8FlySet::WW8FlySet( SwWW8ImplReader& rReader, const SwPaM* pPaM,
brcVer9[i] = WW8_BRCVer9(rPic.rgbrc[i]);
if (SwWW8ImplReader::SetFlyBordersShadow( *this, brcVer9, &aSizeArray[0]))
{
Put(SvxLRSpaceItem( aSizeArray[WW8_LEFT], 0, 0, RES_LR_SPACE ) );
Put(SvxLRSpaceItem(aSizeArray[WW8_LEFT], 0, SvxIndentValue::zero(), RES_LR_SPACE));
Put(SvxULSpaceItem( aSizeArray[WW8_TOP], 0, RES_UL_SPACE ));
aSizeArray[WW8_RIGHT]*=2;
aSizeArray[WW8_BOT]*=2;
@ -4306,8 +4308,9 @@ void SwWW8ImplReader::Read_LR( sal_uInt16 nId, const sal_uInt8* pData, short nLe
if ( pFormat && pFormat->GetPositionAndSpaceMode() == SvxNumberFormat::LABEL_ALIGNMENT )
{
pLeftMargin->SetTextLeft(pFormat->GetIndentAt());
pFirstLine->SetTextFirstLineOffset(pFormat->GetFirstLineIndent(),
pFormat->GetFirstLineIndentUnit());
pFirstLine->SetTextFirstLineOffset(
SvxIndentValue{ static_cast<double>(pFormat->GetFirstLineIndent()),
pFormat->GetFirstLineIndentUnit() });
// make paragraph have hard-set indent attributes
pTextNode->SetAttr(*pLeftMargin);
pTextNode->SetAttr(*pFirstLine);
@ -4385,7 +4388,7 @@ void SwWW8ImplReader::Read_LR( sal_uInt16 nId, const sal_uInt8* pData, short nLe
}
// tdf#80596: TODO handle sprmPDxcLeft1
pFirstLine->SetTextFirstLineOffset(nPara, css::util::MeasureUnit::TWIP);
pFirstLine->SetTextFirstLineOffset(SvxIndentValue::twips(nPara));
if (!m_pCurrentColl)
{

View File

@ -425,10 +425,17 @@ bool SvXMLExportItemMapper::QueryXMLValue(
::sax::Converter::convertPercent(
aOut, rLRSpace.GetPropTextFirstLineOffset() );
}
else if (rLRSpace.GetTextFirstLineOffsetUnit()
!= css::util::MeasureUnit::TWIP)
{
::sax::Converter::convertMeasureUnit(
aOut, rLRSpace.GetTextFirstLineOffsetValue(),
rLRSpace.GetTextFirstLineOffsetUnit());
}
else
{
rUnitConverter.convertMeasureToXML(
aOut, rLRSpace.GetTextFirstLineOffset() );
aOut, rLRSpace.GetTextFirstLineOffsetValue());
}
}
else

View File

@ -367,7 +367,8 @@ bool SvXMLImportItemMapper::PutXMLValue(
bOk = rUnitConverter.convertMeasureToCore(nAbs, rValue,
-0x7fff, 0x7fff );
rLRSpace.SetTextFirstLineOffset( static_cast<short>(nAbs), o3tl::narrowing<sal_uInt16>(nProp) );
rLRSpace.SetTextFirstLineOffset(SvxIndentValue::twips(nAbs),
o3tl::narrowing<sal_uInt16>(nProp));
}
break;

View File

@ -2091,9 +2091,9 @@ bool SwSectionIndentTabPage::FillItemSet(SfxItemSet* rSet)
{
if (m_xBeforeMF->get_value_changed_from_saved() || m_xAfterMF->get_value_changed_from_saved())
{
SvxLRSpaceItem aLRSpace(
m_xBeforeMF->denormalize(m_xBeforeMF->get_value(FieldUnit::TWIP)) ,
m_xAfterMF->denormalize(m_xAfterMF->get_value(FieldUnit::TWIP)), 0, RES_LR_SPACE);
SvxLRSpaceItem aLRSpace(m_xBeforeMF->denormalize(m_xBeforeMF->get_value(FieldUnit::TWIP)),
m_xAfterMF->denormalize(m_xAfterMF->get_value(FieldUnit::TWIP)),
SvxIndentValue::zero(), RES_LR_SPACE);
rSet->Put(aLRSpace);
}
return true;

View File

@ -282,7 +282,7 @@ void SwModule::InsertLab(SfxRequest& rReq, bool bLabel)
//frame represents label itself, no border space
SvxULSpaceItem aFrameNoULSpace( 0, 0, RES_UL_SPACE );
SvxLRSpaceItem aFrameNoLRSpace( 0, 0, 0, RES_LR_SPACE );
SvxLRSpaceItem aFrameNoLRSpace(0, 0, SvxIndentValue::zero(), RES_LR_SPACE);
pFormat->SetFormatAttr( aFrameNoULSpace );
pFormat->SetFormatAttr( aFrameNoLRSpace );

View File

@ -215,9 +215,7 @@ public:
if (!oLRSpaceItem)
oLRSpaceItem.emplace(EE_PARA_LRSPACE);
auto pFirstLineItem = static_cast<const SvxFirstLineIndentItem*>(pItem);
// tdf#36709: TODO: Handle font-relative first-line indentation
(*oLRSpaceItem)
.SetTextFirstLineOffsetValue(pFirstLineItem->ResolveTextFirstLineOffset({}));
(*oLRSpaceItem).SetTextFirstLineOffset(pFirstLineItem->GetTextFirstLineOffset());
(*oLRSpaceItem).SetAutoFirst(pFirstLineItem->IsAutoFirst());
}
else if (nWhich == RES_MARGIN_TEXTLEFT)
@ -1605,9 +1603,10 @@ void SwDocStyleSheet::MergeIndentAttrsOfListStyle( SfxItemSet& rSet )
{
if (indents & ::sw::ListLevelIndents::FirstLine)
{
SvxFirstLineIndentItem const firstLine(rFormat.GetFirstLineIndent(),
rFormat.GetFirstLineIndentUnit(),
RES_MARGIN_FIRSTLINE);
SvxFirstLineIndentItem const firstLine(
SvxIndentValue{ static_cast<double>(rFormat.GetFirstLineIndent()),
rFormat.GetFirstLineIndentUnit() },
RES_MARGIN_FIRSTLINE);
rSet.Put(firstLine);
}
if (indents & ::sw::ListLevelIndents::LeftMargin)

View File

@ -242,7 +242,7 @@ void SwDrawTextShell::Execute( SfxRequest &rReq )
SvxLRSpaceItem aParaMargin = aEditAttr.Get( EE_PARA_LRSPACE );
aParaMargin.SetWhich( EE_PARA_LRSPACE );
tools::Long nIndentDist = aParaMargin.GetTextFirstLineOffset();
tools::Long nIndentDist = aParaMargin.ResolveTextFirstLineOffset({});
if (nIndentDist == 0)
{
@ -252,7 +252,7 @@ void SwDrawTextShell::Execute( SfxRequest &rReq )
aParaMargin.SetTextLeft(aParaMargin.GetTextLeft() + nIndentDist);
aParaMargin.SetRight(aParaMargin.GetRight());
aParaMargin.SetTextFirstLineOffset(nIndentDist * -1);
aParaMargin.SetTextFirstLineOffset(SvxIndentValue::twips(nIndentDist * -1));
aNewAttr.Put(aParaMargin);
rReq.Done();

View File

@ -1746,7 +1746,8 @@ void SwTextShell::Execute(SfxRequest &rReq)
SvxFirstLineIndentItem firstLine(RES_MARGIN_FIRSTLINE);
SvxTextLeftMarginItem leftMargin(RES_MARGIN_TEXTLEFT);
SvxRightMarginItem rightMargin(RES_MARGIN_RIGHT);
firstLine.SetTextFirstLineOffset(aParaMargin.GetTextFirstLineOffset(), aParaMargin.GetPropTextFirstLineOffset());
firstLine.SetTextFirstLineOffset(aParaMargin.GetTextFirstLineOffset(),
aParaMargin.GetPropTextFirstLineOffset());
firstLine.SetAutoFirst(aParaMargin.IsAutoFirst());
leftMargin.SetTextLeft(aParaMargin.GetTextLeft(), aParaMargin.GetPropLeft());
rightMargin.SetRight(aParaMargin.GetRight(), aParaMargin.GetPropRight());

View File

@ -772,8 +772,7 @@ void SwTextShell::GetAttrState(SfxItemSet &rSet)
SvxTextLeftMarginItem const& rLeftMargin(aCoreSet.Get(RES_MARGIN_TEXTLEFT));
SvxRightMarginItem const& rRightMargin(aCoreSet.Get(RES_MARGIN_RIGHT));
// tdf#36709: TODO: Handle font-relative units
aLR.SetTextFirstLineOffset(rFirstLine.ResolveTextFirstLineOffset({}),
aLR.SetTextFirstLineOffset(rFirstLine.GetTextFirstLineOffset(),
rFirstLine.GetPropTextFirstLineOffset());
aLR.SetAutoFirst(rFirstLine.IsAutoFirst());
aLR.SetTextLeft(rLeftMargin.GetTextLeft(), rLeftMargin.GetPropLeft());

View File

@ -120,7 +120,7 @@ IMPL_LINK(WrapPropertyPanel, SpacingLBHdl, weld::ComboBox&, rBox, void)
{
sal_uInt16 nVal = rBox.get_active_id().toUInt32();
SvxLRSpaceItem aLRItem(nVal, nVal, 0, RES_LR_SPACE);
SvxLRSpaceItem aLRItem(nVal, nVal, SvxIndentValue::zero(), RES_LR_SPACE);
SvxULSpaceItem aULItem(nVal, nVal, RES_UL_SPACE);
m_nTop = m_nBottom = m_nLeft = m_nRight = nVal;

View File

@ -705,8 +705,8 @@ void SwView::ExecTabWin( SfxRequest const & rReq )
{
SvxFirstLineIndentItem firstLine(aLRSpaceSet.Get(RES_MARGIN_FIRSTLINE));
const OUString ratio = fLineIndent->GetValue();
firstLine.SetTextFirstLineOffset(nPageWidth * ratio.toFloat(),
css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(
SvxIndentValue::twips(nPageWidth * ratio.toFloat()));
rSh.SetAttrItem(firstLine);
}
else if (const SfxStringItem *pLeftIndent = pReqArgs->GetItemIfSet(SID_PARAGRAPH_LEFT_INDENT))
@ -744,7 +744,7 @@ void SwView::ExecTabWin( SfxRequest const & rReq )
}
leftMargin.SetTextLeft(leftMargin.GetTextLeft() + nIndentDist);
firstLine.SetTextFirstLineOffset(nIndentDist * -1, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::twips(nIndentDist * -1));
firstLine.SetAutoFirst(false); // old code would do this, is it wanted?
rSh.SetAttrItem(firstLine);
@ -765,7 +765,8 @@ void SwView::ExecTabWin( SfxRequest const & rReq )
SwTextFormatColl* pColl = rSh.GetCurTextFormatColl();
SvxFirstLineIndentItem firstLine(RES_MARGIN_FIRSTLINE);
firstLine.SetTextFirstLineOffset(aParaMargin.GetTextFirstLineOffset(), aParaMargin.GetPropTextFirstLineOffset());
firstLine.SetTextFirstLineOffset(aParaMargin.GetTextFirstLineOffset(),
aParaMargin.GetPropTextFirstLineOffset());
firstLine.SetAutoFirst(aParaMargin.IsAutoFirst());
SvxTextLeftMarginItem const leftMargin(aParaMargin.GetTextLeft(), RES_MARGIN_TEXTLEFT);
SvxRightMarginItem const rightMargin(aParaMargin.GetRight(), RES_MARGIN_RIGHT);
@ -801,7 +802,7 @@ void SwView::ExecTabWin( SfxRequest const & rReq )
rSh.SetAttrItem(rightMargin);
}
if ( aParaMargin.GetTextFirstLineOffset() < 0 )
if (aParaMargin.GetTextFirstLineOffsetValue() < 0.0)
{
SfxItemSetFixed<RES_PARATR_TABSTOP, RES_PARATR_TABSTOP> aSet( GetPool() );
@ -1673,8 +1674,7 @@ void SwView::StateTabWin(SfxItemSet& rSet)
SvxTextLeftMarginItem const& rLeftMargin(aCoreSet.Get(RES_MARGIN_TEXTLEFT));
SvxRightMarginItem const& rRightMargin(aCoreSet.Get(RES_MARGIN_RIGHT));
// tdf#36709: TODO: Handle font-relative first-line indentation
aLR->SetTextFirstLineOffset(rFirstLine.ResolveTextFirstLineOffset({}),
aLR->SetTextFirstLineOffset(rFirstLine.GetTextFirstLineOffset(),
rFirstLine.GetPropTextFirstLineOffset());
aLR->SetAutoFirst(rFirstLine.IsAutoFirst());
aLR->SetTextLeft(rLeftMargin.GetTextLeft(), rLeftMargin.GetPropLeft());

View File

@ -74,13 +74,13 @@ bool SwWrtShell::TryRemoveIndent()
if (aOldFirstLineOfst > 0)
{
firstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
bResult = true;
}
else if (aOldFirstLineOfst < 0)
{
// this used to call SetLeft() but this should be the same result
firstLine.SetTextFirstLineOffset(0.0, css::util::MeasureUnit::TWIP);
firstLine.SetTextFirstLineOffset(SvxIndentValue::zero());
leftMargin.SetTextLeft(leftMargin.GetTextLeft() + aOldFirstLineOfst);
bResult = true;
}

View File

@ -1,6 +1,6 @@
<?xml version='1.0' encoding='UTF-8'?>
<office:document xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:formx="urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" office:version="1.4" office:mimetype="application/vnd.oasis.opendocument.text">
<office:meta><meta:creation-date>2024-10-31T13:46:50.189497642</meta:creation-date><meta:generator>LibreOfficeDev/25.2.0.0.alpha0$Linux_X86_64 LibreOffice_project/5f12ad737bbb930b76299df0433c8635ae27a7bd</meta:generator><dc:date>2024-10-31T13:49:19.200988598</dc:date><meta:editing-duration>PT2M30S</meta:editing-duration><meta:editing-cycles>1</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="8" meta:word-count="32" meta:character-count="144" meta:non-whitespace-character-count="120"/></office:meta>
<office:meta><meta:creation-date>2024-10-31T13:46:50.189497642</meta:creation-date><meta:generator>LibreOfficeDev/25.2.0.0.alpha0$Linux_X86_64 LibreOffice_project/372a9f642e1268a1888f6a85d42da0499e1f8516</meta:generator><dc:date>2024-11-08T04:00:30.046342730</dc:date><meta:editing-duration>PT4M32S</meta:editing-duration><meta:editing-cycles>3</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="8" meta:word-count="32" meta:character-count="144" meta:non-whitespace-character-count="120"/></office:meta>
<office:font-face-decls>
<style:font-face style:name="Liberation Serif" svg:font-family="'Liberation Serif'" style:font-family-generic="roman" style:font-pitch="variable"/>
<style:font-face style:name="Noto Sans1" svg:font-family="'Noto Sans'" style:font-family-generic="system" style:font-pitch="variable"/>
@ -8,8 +8,8 @@
</office:font-face-decls>
<office:styles>
<style:default-style style:family="graphic">
<style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:flow-with-text="false"/>
<style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" loext:tab-stop-distance="0in" style:writing-mode="lr-tb" style:font-independent-line-spacing="false">
<style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:writing-mode="lr-tb" style:flow-with-text="false"/>
<style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" loext:tab-stop-distance="0in" style:font-independent-line-spacing="false">
<style:tab-stops/>
</style:paragraph-properties>
<style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Noto Serif CJK SC" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Noto Sans1" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN"/>
@ -26,52 +26,52 @@
</style:default-style>
<style:style style:name="Standard" style:family="paragraph" style:class="text"/>
<text:outline-style style:name="Outline">
<text:outline-level-style text:level="1" style:num-format="">
<text:outline-level-style text:level="1" loext:num-list-format="%1%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="2" style:num-format="">
<text:outline-level-style text:level="2" loext:num-list-format="%2%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="3" style:num-format="">
<text:outline-level-style text:level="3" loext:num-list-format="%3%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="4" style:num-format="">
<text:outline-level-style text:level="4" loext:num-list-format="%4%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="5" style:num-format="">
<text:outline-level-style text:level="5" loext:num-list-format="%5%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="6" style:num-format="">
<text:outline-level-style text:level="6" loext:num-list-format="%6%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="7" style:num-format="">
<text:outline-level-style text:level="7" loext:num-list-format="%7%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="8" style:num-format="">
<text:outline-level-style text:level="8" loext:num-list-format="%8%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="9" style:num-format="">
<text:outline-level-style text:level="9" loext:num-list-format="%9%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
</text:outline-level-style>
<text:outline-level-style text:level="10" style:num-format="">
<text:outline-level-style text:level="10" loext:num-list-format="%10%" style:num-format="">
<style:list-level-properties text:list-level-position-and-space-mode="label-alignment">
<style:list-level-label-alignment text:label-followed-by="listtab"/>
</style:list-level-properties>
@ -103,30 +103,67 @@
</style:style>
<style:style style:name="P6" style:family="paragraph" style:parent-style-name="Standard">
<style:paragraph-properties loext:text-indent="2em" style:auto-text-indent="false"/>
<style:text-properties/>
<style:text-properties fo:font-size="16pt" style:font-size-asian="16pt" style:font-size-complex="16pt"/>
</style:style>
<style:style style:name="P7" style:family="paragraph" style:parent-style-name="Standard">
<style:paragraph-properties loext:text-indent="2em" style:auto-text-indent="false"/>
<style:text-properties fo:font-size="16pt" style:font-size-asian="16pt" style:font-size-complex="16pt"/>
<style:text-properties fo:font-size="20pt" style:font-size-asian="20pt" style:font-size-complex="20pt"/>
</style:style>
<style:style style:name="P8" style:family="paragraph" style:parent-style-name="Standard">
<style:paragraph-properties loext:text-indent="2em" style:auto-text-indent="false"/>
<style:text-properties fo:font-size="20pt" style:font-size-asian="20pt" style:font-size-complex="20pt"/>
</style:style>
<style:style style:name="P9" style:family="paragraph" style:parent-style-name="Standard">
<style:paragraph-properties loext:text-indent="2em" style:auto-text-indent="false"/>
<style:text-properties fo:font-size="24pt" style:font-size-asian="24pt" style:font-size-complex="24pt"/>
</style:style>
<style:style style:name="P9" style:family="paragraph">
<style:text-properties style:font-name="Liberation Serif" fo:font-size="12pt"/>
</style:style>
<style:style style:name="P10" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="1em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="12pt"/>
</style:style>
<style:style style:name="P11" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="2em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="12pt"/>
</style:style>
<style:style style:name="P12" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="3em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="12pt"/>
</style:style>
<style:style style:name="P13" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="2em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="16pt" style:font-size-complex="16pt"/>
</style:style>
<style:style style:name="P14" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="2em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="20pt" style:font-size-complex="20pt"/>
</style:style>
<style:style style:name="P15" style:family="paragraph">
<style:paragraph-properties fo:margin-left="0in" fo:margin-right="0in" loext:text-indent="2em"/>
<style:text-properties style:font-name="Liberation Serif" fo:font-size="24pt" style:font-size-complex="24pt"/>
</style:style>
<style:style style:name="P16" style:family="paragraph">
<loext:graphic-properties draw:fill="none" draw:fill-color="#ffffff"/>
<style:text-properties style:font-name="Liberation Serif"/>
</style:style>
<style:style style:name="T1" style:family="text">
<style:text-properties style:font-name="Liberation Serif"/>
</style:style>
<style:style style:name="gr1" style:family="graphic">
<style:graphic-properties draw:stroke="none" svg:stroke-color="#000000" draw:fill="none" draw:fill-color="#ffffff" fo:min-height="3.7945in" loext:decorative="false" style:run-through="foreground" style:wrap="run-through" style:number-wrapped-paragraphs="no-limit" style:vertical-pos="from-top" style:vertical-rel="paragraph" style:horizontal-pos="from-left" style:horizontal-rel="paragraph"/>
<style:paragraph-properties style:writing-mode="lr-tb"/>
</style:style>
<style:page-layout style:name="pm1">
<style:page-layout-properties fo:page-width="8.2681in" fo:page-height="11.6929in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:footnote-max-height="0in" loext:margin-gutter="0in">
<style:page-layout-properties fo:page-width="8.2681in" fo:page-height="11.6929in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:layout-grid-color="#c0c0c0" style:layout-grid-lines="20" style:layout-grid-base-height="0.278in" style:layout-grid-ruby-height="0.139in" style:layout-grid-mode="none" style:layout-grid-ruby-below="false" style:layout-grid-print="false" style:layout-grid-display="false" style:footnote-max-height="0in" loext:margin-gutter="0in">
<style:footnote-sep style:width="0.0071in" style:distance-before-sep="0.0398in" style:distance-after-sep="0.0398in" style:line-style="solid" style:adjustment="left" style:rel-width="25%" style:color="#000000"/>
</style:page-layout-properties>
<style:header-style/>
<style:footer-style/>
</style:page-layout>
<style:style style:name="dp1" style:family="drawing-page">
<style:drawing-page-properties draw:background-size="full"/>
</style:style>
</office:automatic-styles>
<office:master-styles>
<style:master-page style:name="Standard" style:page-layout-name="pm1"/>
<style:master-page style:name="Standard" style:page-layout-name="pm1" draw:style-name="dp1"/>
</office:master-styles>
<office:body>
<office:text>
@ -142,10 +179,22 @@
<text:p text:style-name="P3">2 em constant size</text:p>
<text:p text:style-name="P4">3 em constant size</text:p>
<text:p text:style-name="P5"/>
<text:p text:style-name="P3">2 em variable size</text:p>
<text:p text:style-name="P6">2 em variable size</text:p>
<text:p text:style-name="P7">2 em variable size</text:p>
<text:p text:style-name="P8">2 em variable size</text:p>
<text:p text:style-name="P9">2 em variable size</text:p>
<text:p text:style-name="P8"><draw:frame text:anchor-type="paragraph" draw:z-index="0" draw:name="Text Frame 1" draw:style-name="gr1" draw:text-style-name="P16" svg:width="6.4587in" svg:height="3.7949in" svg:x="0.0689in" svg:y="0.5937in">
<draw:text-box>
<text:p text:style-name="P9"><text:span text:style-name="T1">0 em constant size</text:span></text:p>
<text:p text:style-name="P10"><text:span text:style-name="T1">1 em constant size</text:span></text:p>
<text:p text:style-name="P11"><text:span text:style-name="T1">2 em constant size</text:span></text:p>
<text:p text:style-name="P12"><text:span text:style-name="T1">3 em constant size</text:span></text:p>
<text:p text:style-name="P9"><text:span text:style-name="T1"/></text:p>
<text:p text:style-name="P11"><text:span text:style-name="T1">2 em variable size</text:span></text:p>
<text:p text:style-name="P13"><text:span text:style-name="T1">2 em variable size</text:span></text:p>
<text:p text:style-name="P14"><text:span text:style-name="T1">2 em variable size</text:span></text:p>
<text:p text:style-name="P15"><text:span text:style-name="T1">2 em variable size</text:span></text:p>
</draw:text-box>
</draw:frame>2 em variable size</text:p>
</office:text>
</office:body>
</office:document>

View File

@ -5836,7 +5836,7 @@ CPPUNIT_TEST_FIXTURE(PdfExportTest2, testTdf36709FirstLineIndentEm)
int nPageObjectCount = pPdfPage->getObjectCount();
CPPUNIT_ASSERT_EQUAL(8, nPageObjectCount);
CPPUNIT_ASSERT_EQUAL(16, nPageObjectCount);
std::vector<OUString> aText;
std::vector<basegfx::B2DRectangle> aRect;
@ -5852,8 +5852,9 @@ CPPUNIT_TEST_FIXTURE(PdfExportTest2, testTdf36709FirstLineIndentEm)
}
}
CPPUNIT_ASSERT_EQUAL(size_t(8), aText.size());
CPPUNIT_ASSERT_EQUAL(size_t(16), aText.size());
// Lines from the Writer portion
CPPUNIT_ASSERT_EQUAL(u"0 em constant size"_ustr, aText.at(0).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(57.256, aRect.at(0).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"1 em constant size"_ustr, aText.at(1).trim());
@ -5871,6 +5872,25 @@ CPPUNIT_TEST_FIXTURE(PdfExportTest2, testTdf36709FirstLineIndentEm)
CPPUNIT_ASSERT_DOUBLES_EQUAL(97.680, aRect.at(6).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em variable size"_ustr, aText.at(7).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(105.856, aRect.at(7).getMinX(), /*delta*/ 2.0);
// Lines from the Edit Engine portion
CPPUNIT_ASSERT_EQUAL(u"0 em constant size"_ustr, aText.at(8).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(62.106, aRect.at(8).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"1 em constant size"_ustr, aText.at(9).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(76.010, aRect.at(9).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em constant size"_ustr, aText.at(10).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(88.778, aRect.at(10).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"3 em constant size"_ustr, aText.at(11).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(102.126, aRect.at(11).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em variable size"_ustr, aText.at(12).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(88.778, aRect.at(12).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em variable size"_ustr, aText.at(13).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(97.754, aRect.at(13).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em variable size"_ustr, aText.at(14).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(106.830, aRect.at(14).getMinX(), /*delta*/ 2.0);
CPPUNIT_ASSERT_EQUAL(u"2 em variable size"_ustr, aText.at(15).trim());
CPPUNIT_ASSERT_DOUBLES_EQUAL(115.906, aRect.at(15).getMinX(), /*delta*/ 2.0);
}
} // end anonymous namespace