svgio: move SvgNumber methods to its own SvgNumber.cxx file

Change-Id: I2b52eaf83162b80ccc6f656a5808e8b2aa6c2541
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/114961
Tested-by: Jenkins
Reviewed-by: Tomaž Vajngerl <quikee@gmail.com>
This commit is contained in:
Tomaž Vajngerl
2021-05-01 13:17:21 +09:00
committed by Tomaž Vajngerl
parent 6fecdeac5d
commit 0919f55512
4 changed files with 162 additions and 132 deletions

View File

@@ -11141,6 +11141,7 @@ svgio/source/svgreader/svglinenode.cxx
svgio/source/svgreader/svgmarkernode.cxx
svgio/source/svgreader/svgmasknode.cxx
svgio/source/svgreader/svgnode.cxx
svgio/source/svgreader/SvgNumber.cxx
svgio/source/svgreader/svgpathnode.cxx
svgio/source/svgreader/svgpatternnode.cxx
svgio/source/svgreader/svgpolynode.cxx

View File

@@ -61,6 +61,7 @@ $(eval $(call gb_Library_add_exception_objects,svgio,\
svgio/source/svgreader/svgmarkernode \
svgio/source/svgreader/svgmasknode \
svgio/source/svgreader/svgnode \
svgio/source/svgreader/SvgNumber \
svgio/source/svgreader/svgpaint \
svgio/source/svgreader/svgpathnode \
svgio/source/svgreader/svgpatternnode \

View File

@@ -0,0 +1,160 @@
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <svgtools.hxx>
#include <sal/log.hxx>
namespace svgio::svgreader
{
double SvgNumber::solveNonPercentage(const InfoProvider& rInfoProvider) const
{
if(isSet())
{
switch(meUnit)
{
case SvgUnit::em:
{
return mfNumber * rInfoProvider.getCurrentFontSizeInherited();
}
case SvgUnit::ex:
{
return mfNumber * rInfoProvider.getCurrentXHeightInherited() * 0.5;
}
case SvgUnit::px:
{
return mfNumber;
}
case SvgUnit::pt:
case SvgUnit::pc:
case SvgUnit::cm:
case SvgUnit::mm:
case SvgUnit::in:
{
double fRetval(mfNumber);
switch(meUnit)
{
case SvgUnit::pt: fRetval *= F_SVG_PIXEL_PER_INCH / 72.0; break;
case SvgUnit::pc: fRetval *= F_SVG_PIXEL_PER_INCH / 6.0; break;
case SvgUnit::cm: fRetval *= F_SVG_PIXEL_PER_INCH / 2.54; break;
case SvgUnit::mm: fRetval *= 0.1 * F_SVG_PIXEL_PER_INCH / 2.54; break;
case SvgUnit::in: fRetval *= F_SVG_PIXEL_PER_INCH; break;
default: break;
}
return fRetval;
}
case SvgUnit::none:
{
SAL_WARN("svgio", "Design error, this case should have been handled in the caller");
return mfNumber;
}
default:
{
assert(false && "Do not use with percentage!");
return 0.0;
}
}
}
/// not set
assert(false && "SvgNumber not set (!)");
return 0.0;
}
double SvgNumber::solve(const InfoProvider& rInfoProvider, NumberType aNumberType) const
{
if(isSet())
{
switch(meUnit)
{
case SvgUnit::px:
{
return mfNumber;
}
case SvgUnit::pt:
case SvgUnit::pc:
case SvgUnit::cm:
case SvgUnit::mm:
case SvgUnit::in:
case SvgUnit::em:
case SvgUnit::ex:
case SvgUnit::none:
{
return solveNonPercentage( rInfoProvider);
}
case SvgUnit::percent:
{
double fRetval(mfNumber * 0.01);
basegfx::B2DRange aViewPort = rInfoProvider.getCurrentViewPort();
if ( aViewPort.isEmpty() )
{
SAL_WARN("svgio", "Design error, this case should have been handled in the caller");
// no viewPort, assume a normal page size (A4)
aViewPort = basegfx::B2DRange(
0.0,
0.0,
210.0 * F_SVG_PIXEL_PER_INCH / 2.54,
297.0 * F_SVG_PIXEL_PER_INCH / 2.54);
}
if ( !aViewPort.isEmpty() )
{
if (NumberType::xcoordinate == aNumberType)
{
// it's a x-coordinate, relative to current width (w)
fRetval *= aViewPort.getWidth();
}
else if (NumberType::ycoordinate == aNumberType)
{
// it's a y-coordinate, relative to current height (h)
fRetval *= aViewPort.getHeight();
}
else // length
{
// it's a length, relative to sqrt(w*w + h*h)/sqrt(2)
const double fCurrentWidth(aViewPort.getWidth());
const double fCurrentHeight(aViewPort.getHeight());
const double fCurrentLength(
sqrt(fCurrentWidth * fCurrentWidth + fCurrentHeight * fCurrentHeight)/sqrt(2.0));
fRetval *= fCurrentLength;
}
}
return fRetval;
}
default:
{
break;
}
}
}
/// not set
assert(false && "SvgNumber not set (!)");
return 0.0;
}
} // end of namespace svgio::svgreader
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */

View File

@@ -135,138 +135,6 @@ namespace svgio::svgreader
return aRetval;
}
double SvgNumber::solveNonPercentage(const InfoProvider& rInfoProvider) const
{
if(isSet())
{
switch(meUnit)
{
case SvgUnit::em:
{
return mfNumber * rInfoProvider.getCurrentFontSizeInherited();
}
case SvgUnit::ex:
{
return mfNumber * rInfoProvider.getCurrentXHeightInherited() * 0.5;
}
case SvgUnit::px:
{
return mfNumber;
}
case SvgUnit::pt:
case SvgUnit::pc:
case SvgUnit::cm:
case SvgUnit::mm:
case SvgUnit::in:
{
double fRetval(mfNumber);
switch(meUnit)
{
case SvgUnit::pt: fRetval *= F_SVG_PIXEL_PER_INCH / 72.0; break;
case SvgUnit::pc: fRetval *= F_SVG_PIXEL_PER_INCH / 6.0; break;
case SvgUnit::cm: fRetval *= F_SVG_PIXEL_PER_INCH / 2.54; break;
case SvgUnit::mm: fRetval *= 0.1 * F_SVG_PIXEL_PER_INCH / 2.54; break;
case SvgUnit::in: fRetval *= F_SVG_PIXEL_PER_INCH; break;
default: break;
}
return fRetval;
}
case SvgUnit::none:
{
SAL_WARN("svgio", "Design error, this case should have been handled in the caller");
return mfNumber;
}
default:
{
assert(false && "Do not use with percentage!");
return 0.0;
}
}
}
/// not set
assert(false && "SvgNumber not set (!)");
return 0.0;
}
double SvgNumber::solve(const InfoProvider& rInfoProvider, NumberType aNumberType) const
{
if(isSet())
{
switch(meUnit)
{
case SvgUnit::px:
{
return mfNumber;
}
case SvgUnit::pt:
case SvgUnit::pc:
case SvgUnit::cm:
case SvgUnit::mm:
case SvgUnit::in:
case SvgUnit::em:
case SvgUnit::ex:
case SvgUnit::none:
{
return solveNonPercentage( rInfoProvider);
}
case SvgUnit::percent:
{
double fRetval(mfNumber * 0.01);
basegfx::B2DRange aViewPort = rInfoProvider.getCurrentViewPort();
if ( aViewPort.isEmpty() )
{
SAL_WARN("svgio", "Design error, this case should have been handled in the caller");
// no viewPort, assume a normal page size (A4)
aViewPort = basegfx::B2DRange(
0.0,
0.0,
210.0 * F_SVG_PIXEL_PER_INCH / 2.54,
297.0 * F_SVG_PIXEL_PER_INCH / 2.54);
}
if ( !aViewPort.isEmpty() )
{
if (NumberType::xcoordinate == aNumberType)
{
// it's a x-coordinate, relative to current width (w)
fRetval *= aViewPort.getWidth();
}
else if (NumberType::ycoordinate == aNumberType)
{
// it's a y-coordinate, relative to current height (h)
fRetval *= aViewPort.getHeight();
}
else // length
{
// it's a length, relative to sqrt(w*w + h*h)/sqrt(2)
const double fCurrentWidth(aViewPort.getWidth());
const double fCurrentHeight(aViewPort.getHeight());
const double fCurrentLength(
sqrt(fCurrentWidth * fCurrentWidth + fCurrentHeight * fCurrentHeight)/sqrt(2.0));
fRetval *= fCurrentLength;
}
}
return fRetval;
}
default:
{
break;
}
}
}
/// not set
assert(false && "SvgNumber not set (!)");
return 0.0;
}
void skip_char(std::u16string_view rCandidate, sal_Unicode nChar, sal_Int32& nPos, const sal_Int32 nLen)
{
while(nPos < nLen && nChar == rCandidate[nPos])