зеркало из https://github.com/mozilla/gecko-dev.git
98 строки
2.9 KiB
C++
98 строки
2.9 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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/. */
|
|
|
|
#ifndef DOM_SVG_DOMSVGPOINT_H_
|
|
#define DOM_SVG_DOMSVGPOINT_H_
|
|
|
|
#include "DOMSVGPointList.h"
|
|
#include "mozilla/gfx/2D.h"
|
|
#include "nsDebug.h"
|
|
#include "nsISVGPoint.h"
|
|
#include "SVGPoint.h"
|
|
#include "mozilla/Attributes.h"
|
|
#include "mozilla/FloatingPoint.h"
|
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
|
struct DOMMatrix2DInit;
|
|
class SVGElement;
|
|
|
|
/**
|
|
* Class DOMSVGPoint
|
|
*
|
|
* This class creates the DOM objects that wrap internal SVGPoint objects that
|
|
* are in an SVGPointList. It is also used to create the objects returned by
|
|
* SVGSVGElement.createSVGPoint() and other functions that return DOM SVGPoint
|
|
* objects.
|
|
*
|
|
* See the architecture comment in DOMSVGPointList.h for an overview of the
|
|
* important points regarding these DOM wrapper structures.
|
|
*
|
|
* See the architecture comment in DOMSVGLength.h (yes, LENGTH) for an overview
|
|
* of the important points regarding how this specific class works.
|
|
*/
|
|
class DOMSVGPoint final : public nsISVGPoint {
|
|
template <class T>
|
|
friend class AutoChangePointListNotifier;
|
|
|
|
using Point = gfx::Point;
|
|
|
|
public:
|
|
/**
|
|
* Generic ctor for DOMSVGPoint objects that are created for an attribute.
|
|
*/
|
|
DOMSVGPoint(DOMSVGPointList* aList, uint32_t aListIndex, bool aIsAnimValItem)
|
|
: nsISVGPoint() {
|
|
mList = aList;
|
|
mListIndex = aListIndex;
|
|
mIsAnimValItem = aIsAnimValItem;
|
|
|
|
// These shifts are in sync with the members.
|
|
MOZ_ASSERT(aList && aListIndex <= MaxListIndex(), "bad arg");
|
|
|
|
MOZ_ASSERT(IndexIsValid(), "Bad index for DOMSVGPoint!");
|
|
}
|
|
|
|
explicit DOMSVGPoint(const DOMSVGPoint* aPt = nullptr) : nsISVGPoint() {
|
|
if (aPt) {
|
|
mPt = aPt->ToSVGPoint();
|
|
}
|
|
}
|
|
|
|
explicit DOMSVGPoint(const Point& aPt) : nsISVGPoint() {
|
|
mPt.mX = aPt.x;
|
|
mPt.mY = aPt.y;
|
|
NS_ASSERTION(IsFinite(mPt.mX) && IsFinite(mPt.mY),
|
|
"DOMSVGPoint coords are not finite");
|
|
}
|
|
|
|
// WebIDL
|
|
virtual float X() override;
|
|
virtual void SetX(float aX, ErrorResult& rv) override;
|
|
virtual float Y() override;
|
|
virtual void SetY(float aY, ErrorResult& rv) override;
|
|
virtual already_AddRefed<nsISVGPoint> MatrixTransform(
|
|
const DOMMatrix2DInit& aMatrix, ErrorResult& aRv) override;
|
|
nsISupports* GetParentObject() override { return mList; }
|
|
|
|
/**
|
|
* Returns true if our attribute is animating (in which case our animVal is
|
|
* not simply a mirror of our baseVal).
|
|
*/
|
|
bool AttrIsAnimating() const { return mList && mList->AttrIsAnimating(); }
|
|
|
|
virtual DOMSVGPoint* Copy() override { return new DOMSVGPoint(this); }
|
|
|
|
protected:
|
|
SVGElement* Element() { return mList->Element(); }
|
|
};
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
#endif // DOM_SVG_DOMSVGPOINT_H_
|