2007-03-22 10:30:00 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* 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/. */
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
#ifndef __NS_SVGPATHGEOMETRYELEMENT_H__
|
|
|
|
#define __NS_SVGPATHGEOMETRYELEMENT_H__
|
|
|
|
|
2013-11-02 04:10:38 -07:00
|
|
|
#include "mozilla/gfx/2D.h"
|
2013-01-02 22:17:03 -08:00
|
|
|
#include "SVGGraphicsElement.h"
|
2013-03-11 15:05:58 -07:00
|
|
|
|
2014-06-25 04:59:46 -07:00
|
|
|
class gfxMatrix;
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
struct nsSVGMark {
|
2013-07-11 23:39:38 -07:00
|
|
|
enum Type {
|
|
|
|
eStart,
|
|
|
|
eMid,
|
|
|
|
eEnd,
|
|
|
|
|
|
|
|
eTypeCount
|
|
|
|
};
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
float x, y, angle;
|
2013-07-11 23:39:38 -07:00
|
|
|
Type type;
|
|
|
|
nsSVGMark(float aX, float aY, float aAngle, Type aType) :
|
|
|
|
x(aX), y(aY), angle(aAngle), type(aType) {}
|
2007-03-22 10:30:00 -07:00
|
|
|
};
|
|
|
|
|
2013-01-02 22:17:03 -08:00
|
|
|
typedef mozilla::dom::SVGGraphicsElement nsSVGPathGeometryElementBase;
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2013-01-05 22:25:52 -08:00
|
|
|
class nsSVGPathGeometryElement : public nsSVGPathGeometryElementBase
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2013-11-02 04:10:38 -07:00
|
|
|
protected:
|
2014-10-04 04:13:30 -07:00
|
|
|
typedef mozilla::gfx::DrawTarget DrawTarget;
|
2013-11-02 04:10:38 -07:00
|
|
|
typedef mozilla::gfx::FillRule FillRule;
|
|
|
|
typedef mozilla::gfx::Float Float;
|
2014-10-26 11:00:03 -07:00
|
|
|
typedef mozilla::gfx::Matrix Matrix;
|
2013-11-02 04:10:38 -07:00
|
|
|
typedef mozilla::gfx::Path Path;
|
2014-10-22 04:29:05 -07:00
|
|
|
typedef mozilla::gfx::Point Point;
|
2013-11-02 04:10:38 -07:00
|
|
|
typedef mozilla::gfx::PathBuilder PathBuilder;
|
2014-10-22 04:29:05 -07:00
|
|
|
typedef mozilla::gfx::Rect Rect;
|
2013-11-02 04:10:38 -07:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
public:
|
2014-08-31 18:08:04 -07:00
|
|
|
explicit nsSVGPathGeometryElement(already_AddRefed<mozilla::dom::NodeInfo>& aNodeInfo);
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2014-10-04 04:13:30 -07:00
|
|
|
virtual nsresult AfterSetAttr(int32_t aNamespaceID, nsIAtom* aName,
|
|
|
|
const nsAttrValue* aValue, bool aNotify) MOZ_OVERRIDE;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Causes this element to discard any Path object that GetOrBuildPath may
|
|
|
|
* have cached.
|
|
|
|
*/
|
|
|
|
virtual void ClearAnyCachedPath() MOZ_OVERRIDE MOZ_FINAL {
|
|
|
|
mCachedPath = nullptr;
|
|
|
|
}
|
|
|
|
|
2011-09-28 23:19:26 -07:00
|
|
|
virtual bool AttributeDefinesGeometry(const nsIAtom *aName);
|
2013-05-08 10:13:11 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if this element's geometry depends on the width or height of its
|
|
|
|
* coordinate context (typically the viewport established by its nearest <svg>
|
|
|
|
* ancestor). In other words, returns true if one of the attributes for which
|
|
|
|
* AttributeDefinesGeometry returns true has a percentage value.
|
|
|
|
*
|
|
|
|
* This could be moved up to a more general class so it can be used for non-leaf
|
|
|
|
* elements, but that would require care and for now there's no need.
|
|
|
|
*/
|
|
|
|
bool GeometryDependsOnCoordCtx();
|
|
|
|
|
2011-09-28 23:19:26 -07:00
|
|
|
virtual bool IsMarkable();
|
2007-03-22 10:30:00 -07:00
|
|
|
virtual void GetMarkPoints(nsTArray<nsSVGMark> *aMarks);
|
2013-11-02 04:10:38 -07:00
|
|
|
|
2014-10-28 18:59:36 -07:00
|
|
|
/**
|
|
|
|
* A method that can be faster than using a Moz2D Path and calling GetBounds/
|
|
|
|
* GetStrokedBounds on it. It also helps us avoid rounding error for simple
|
|
|
|
* shapes and simple transforms where the Moz2D Path backends can fail to
|
|
|
|
* produce the clean integer bounds that content authors expect in some cases.
|
|
|
|
*/
|
2014-10-26 11:00:03 -07:00
|
|
|
virtual bool GetGeometryBounds(Rect* aBounds, Float aStrokeWidth,
|
|
|
|
const Matrix& aTransform) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-10-22 04:29:05 -07:00
|
|
|
/**
|
|
|
|
* For use with GetAsSimplePath.
|
|
|
|
*/
|
|
|
|
class SimplePath
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
SimplePath()
|
|
|
|
: mType(NONE)
|
|
|
|
{}
|
|
|
|
bool IsPath() const {
|
|
|
|
return mType != NONE;
|
|
|
|
}
|
|
|
|
void SetRect(Float x, Float y, Float width, Float height) {
|
|
|
|
mX = x; mY = y, mWidthOrX2 = width, mHeightOrY2 = height;
|
|
|
|
mType = RECT;
|
|
|
|
}
|
|
|
|
Rect AsRect() const {
|
|
|
|
MOZ_ASSERT(mType == RECT);
|
|
|
|
return Rect(mX, mY, mWidthOrX2, mHeightOrY2);
|
|
|
|
}
|
|
|
|
bool IsRect() const {
|
|
|
|
return mType == RECT;
|
|
|
|
}
|
|
|
|
void SetLine(Float x1, Float y1, Float x2, Float y2) {
|
|
|
|
mX = x1, mY = y1, mWidthOrX2 = x2, mHeightOrY2 = y2;
|
|
|
|
mType = LINE;
|
|
|
|
}
|
|
|
|
Point Point1() const {
|
|
|
|
MOZ_ASSERT(mType == LINE);
|
|
|
|
return Point(mX, mY);
|
|
|
|
}
|
|
|
|
Point Point2() const {
|
|
|
|
MOZ_ASSERT(mType == LINE);
|
|
|
|
return Point(mWidthOrX2, mHeightOrY2);
|
|
|
|
}
|
|
|
|
bool IsLine() const {
|
|
|
|
return mType == LINE;
|
|
|
|
}
|
|
|
|
void Reset() {
|
|
|
|
mType = NONE;
|
|
|
|
}
|
|
|
|
private:
|
|
|
|
enum Type {
|
|
|
|
NONE, RECT, LINE
|
|
|
|
};
|
|
|
|
Float mX, mY, mWidthOrX2, mHeightOrY2;
|
|
|
|
Type mType;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* For some platforms there is significant overhead to creating and painting
|
|
|
|
* a Moz2D Path object. For Rects and lines it is better to get the path data
|
|
|
|
* using this method and then use the optimized DrawTarget methods for
|
|
|
|
* filling/stroking rects and lines.
|
|
|
|
*/
|
|
|
|
virtual void GetAsSimplePath(SimplePath* aSimplePath) {
|
|
|
|
aSimplePath->Reset();
|
|
|
|
}
|
|
|
|
|
2013-11-02 04:10:38 -07:00
|
|
|
/**
|
|
|
|
* Returns a Path that can be used to paint, hit-test or calculate bounds for
|
2014-10-04 04:13:30 -07:00
|
|
|
* this element. May return nullptr if there is no [valid] path. The path
|
|
|
|
* that is created may be cached and returned on subsequent calls.
|
|
|
|
*/
|
|
|
|
virtual mozilla::TemporaryRef<Path> GetOrBuildPath(const DrawTarget& aDrawTarget,
|
|
|
|
FillRule fillRule);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The same as GetOrBuildPath, but bypasses the cache (neither returns any
|
|
|
|
* previously cached Path, nor caches the Path that in does return).
|
2013-11-06 02:05:18 -08:00
|
|
|
* this element. May return nullptr if there is no [valid] path.
|
2013-11-02 04:10:38 -07:00
|
|
|
*/
|
2014-10-04 04:13:30 -07:00
|
|
|
virtual mozilla::TemporaryRef<Path> BuildPath(PathBuilder* aBuilder) = 0;
|
2013-11-02 04:10:38 -07:00
|
|
|
|
2014-10-04 04:13:30 -07:00
|
|
|
/**
|
|
|
|
* Returns a Path that can be used to measure the length of this elements
|
|
|
|
* path, or to find the position at a given distance along it.
|
|
|
|
*
|
|
|
|
* This is currently equivalent to calling GetOrBuildPath, but it may not be
|
|
|
|
* in the future. The reason for this function to be separate from
|
|
|
|
* GetOrBuildPath is because SVGPathData::BuildPath inserts small lines into
|
|
|
|
* the path if zero length subpaths are encountered, in order to implement
|
|
|
|
* the SVG specifications requirements that zero length subpaths should
|
|
|
|
* render circles/squares if stroke-linecap is round/square, respectively.
|
|
|
|
* In principle these inserted lines could interfere with path measurement,
|
|
|
|
* so we keep callers that are looking to do measurement separate in case we
|
|
|
|
* run into problems with the inserted lines negatively affecting measuring
|
|
|
|
* for content.
|
|
|
|
*/
|
|
|
|
virtual mozilla::TemporaryRef<Path> GetOrBuildPathForMeasuring();
|
2013-11-02 04:10:38 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the current computed value of the CSS property 'fill-rule' for
|
|
|
|
* this element.
|
|
|
|
*/
|
|
|
|
FillRule GetFillRule();
|
2014-10-04 04:13:30 -07:00
|
|
|
|
|
|
|
protected:
|
|
|
|
mutable mozilla::RefPtr<Path> mCachedPath;
|
2007-03-22 10:30:00 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|