blob: 580454b7b81141dd114a23a0e66e7bd4d8b6b33b [file] [log] [blame]
/*
* Copyright (C) Research In Motion Limited 2010-2011. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include "config.h"
#include "core/svg/SVGPathStringBuilder.h"
#include "wtf/text/WTFString.h"
namespace WebCore {
String SVGPathStringBuilder::result()
{
unsigned size = m_stringBuilder.length();
if (!size)
return String();
// Remove trailing space.
m_stringBuilder.resize(size - 1);
return m_stringBuilder.toString();
}
void SVGPathStringBuilder::moveTo(const FloatPoint& targetPoint, bool, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates)
m_stringBuilder.append("M " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
else
m_stringBuilder.append("m " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::lineTo(const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates)
m_stringBuilder.append("L " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
else
m_stringBuilder.append("l " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::lineToHorizontal(float x, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates)
m_stringBuilder.append("H " + String::number(x) + ' ');
else
m_stringBuilder.append("h " + String::number(x) + ' ');
}
void SVGPathStringBuilder::lineToVertical(float y, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates)
m_stringBuilder.append("V " + String::number(y) + ' ');
else
m_stringBuilder.append("v " + String::number(y) + ' ');
}
void SVGPathStringBuilder::curveToCubic(const FloatPoint& point1, const FloatPoint& point2, const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates) {
m_stringBuilder.append("C " + String::number(point1.x()) + ' ' + String::number(point1.y())
+ ' ' + String::number(point2.x()) + ' ' + String::number(point2.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
return;
}
m_stringBuilder.append("c " + String::number(point1.x()) + ' ' + String::number(point1.y())
+ ' ' + String::number(point2.x()) + ' ' + String::number(point2.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::curveToCubicSmooth(const FloatPoint& point2, const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates) {
m_stringBuilder.append("S " + String::number(point2.x()) + ' ' + String::number(point2.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
return;
}
m_stringBuilder.append("s " + String::number(point2.x()) + ' ' + String::number(point2.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::curveToQuadratic(const FloatPoint& point1, const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates) {
m_stringBuilder.append("Q " + String::number(point1.x()) + ' ' + String::number(point1.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
return;
}
m_stringBuilder.append("q " + String::number(point1.x()) + ' ' + String::number(point1.y())
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::curveToQuadraticSmooth(const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates)
m_stringBuilder.append("T " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
else
m_stringBuilder.append("t " + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::arcTo(float r1, float r2, float angle, bool largeArcFlag, bool sweepFlag, const FloatPoint& targetPoint, PathCoordinateMode mode)
{
if (mode == AbsoluteCoordinates) {
m_stringBuilder.append("A " + String::number(r1) + ' ' + String::number(r2)
+ ' ' + String::number(angle) + ' ' + String::number(largeArcFlag) + ' ' + String::number(sweepFlag)
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
return;
}
m_stringBuilder.append("a " + String::number(r1) + ' ' + String::number(r2)
+ ' ' + String::number(angle) + ' ' + String::number(largeArcFlag) + ' ' + String::number(sweepFlag)
+ ' ' + String::number(targetPoint.x()) + ' ' + String::number(targetPoint.y()) + ' ');
}
void SVGPathStringBuilder::closePath()
{
m_stringBuilder.append("Z ");
}
} // namespace WebCore