2007-04-17 00:18:32 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2012-05-21 15:12:37 +04: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-04-17 00:18:32 +04:00
|
|
|
|
|
|
|
#ifndef GFX_PATH_H
|
|
|
|
#define GFX_PATH_H
|
|
|
|
|
|
|
|
#include "gfxTypes.h"
|
2010-04-01 22:05:40 +04:00
|
|
|
#include "nsISupportsImpl.h"
|
2007-04-17 00:18:32 +04:00
|
|
|
|
2008-07-18 22:26:02 +04:00
|
|
|
class gfxContext;
|
2007-04-17 00:18:32 +04:00
|
|
|
struct gfxPoint;
|
|
|
|
typedef struct cairo_path cairo_path_t;
|
|
|
|
|
2008-07-18 22:26:02 +04:00
|
|
|
/**
|
|
|
|
* Class representing a path. Can be created by copying the current path
|
|
|
|
* of a gfxContext.
|
|
|
|
*/
|
|
|
|
class THEBES_API gfxPath {
|
2010-04-01 22:05:40 +04:00
|
|
|
NS_INLINE_DECL_REFCOUNTING(gfxPath)
|
2007-04-17 00:18:32 +04:00
|
|
|
|
2008-07-18 22:26:02 +04:00
|
|
|
friend class gfxContext;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
gfxPath(cairo_path_t* aPath);
|
|
|
|
|
2007-04-17 00:18:32 +04:00
|
|
|
public:
|
2008-07-18 22:26:02 +04:00
|
|
|
virtual ~gfxPath();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
cairo_path_t* mPath;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Specialization of a path that only contains linear pieces. Can be created
|
|
|
|
* from the existing path of a gfxContext.
|
|
|
|
*/
|
|
|
|
class THEBES_API gfxFlattenedPath : public gfxPath {
|
|
|
|
friend class gfxContext;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
gfxFlattenedPath(cairo_path_t* aPath);
|
|
|
|
|
|
|
|
public:
|
|
|
|
virtual ~gfxFlattenedPath();
|
2007-04-17 00:18:32 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns calculated total length of path
|
|
|
|
*/
|
|
|
|
gfxFloat GetLength();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a point a certain distance along the path. Return is
|
|
|
|
* first or last point of the path if the requested length offset
|
|
|
|
* is outside the range for the path.
|
|
|
|
* @param aOffset offset inpath parameter space (x=length, y=normal offset)
|
|
|
|
* @param aAngle optional - output tangent
|
|
|
|
*/
|
|
|
|
gfxPoint FindPoint(gfxPoint aOffset,
|
2012-07-30 18:20:58 +04:00
|
|
|
gfxFloat* aAngle = nullptr);
|
2007-04-17 00:18:32 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|