2015-05-03 22:32:37 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2014-06-24 22:15:00 +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/. */
|
|
|
|
|
|
|
|
#ifndef MOZILLA_DOM_DOMMATRIX_H_
|
|
|
|
#define MOZILLA_DOM_DOMMATRIX_H_
|
|
|
|
|
2020-11-23 19:06:52 +03:00
|
|
|
#include <cstring>
|
|
|
|
#include <utility>
|
|
|
|
#include "js/RootingAPI.h"
|
|
|
|
#include "mozilla/AlreadyAddRefed.h"
|
|
|
|
#include "mozilla/Assertions.h"
|
2020-04-04 00:05:29 +03:00
|
|
|
#include "mozilla/UniquePtr.h"
|
2014-06-24 22:15:00 +04:00
|
|
|
#include "mozilla/dom/TypedArray.h"
|
2020-11-23 19:06:52 +03:00
|
|
|
#include "mozilla/gfx/Matrix.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsCycleCollectionParticipant.h"
|
|
|
|
#include "nsISupports.h"
|
|
|
|
#include "nsStringFwd.h"
|
|
|
|
#include "nsWrapperCache.h"
|
2014-06-24 22:15:00 +04:00
|
|
|
|
2020-11-23 19:06:52 +03:00
|
|
|
class JSObject;
|
2019-06-25 09:48:29 +03:00
|
|
|
class nsIGlobalObject;
|
2020-11-23 19:06:52 +03:00
|
|
|
struct JSContext;
|
|
|
|
struct JSStructuredCloneReader;
|
|
|
|
struct JSStructuredCloneWriter;
|
2019-06-25 09:48:29 +03:00
|
|
|
|
2014-06-24 22:15:00 +04:00
|
|
|
namespace mozilla {
|
2020-11-23 19:06:52 +03:00
|
|
|
class ErrorResult;
|
|
|
|
|
2014-06-24 22:15:00 +04:00
|
|
|
namespace dom {
|
|
|
|
|
|
|
|
class GlobalObject;
|
|
|
|
class DOMMatrix;
|
2016-04-11 19:02:35 +03:00
|
|
|
class DOMPoint;
|
2020-11-23 19:06:52 +03:00
|
|
|
template <typename T>
|
|
|
|
class Optional;
|
2020-01-07 12:46:53 +03:00
|
|
|
class UTF8StringOrUnrestrictedDoubleSequenceOrDOMMatrixReadOnly;
|
2016-04-11 19:02:35 +03:00
|
|
|
struct DOMPointInit;
|
2019-06-30 06:02:13 +03:00
|
|
|
struct DOMMatrixInit;
|
2019-07-11 09:14:58 +03:00
|
|
|
struct DOMMatrix2DInit;
|
2014-06-24 22:15:00 +04:00
|
|
|
|
|
|
|
class DOMMatrixReadOnly : public nsWrapperCache {
|
|
|
|
public:
|
2018-03-25 20:42:10 +03:00
|
|
|
explicit DOMMatrixReadOnly(nsISupports* aParent)
|
2019-06-19 18:59:54 +03:00
|
|
|
: mParent(aParent), mMatrix2D(new gfx::MatrixDouble()) {}
|
2014-06-24 22:15:00 +04:00
|
|
|
|
|
|
|
DOMMatrixReadOnly(nsISupports* aParent, const DOMMatrixReadOnly& other)
|
2018-03-25 20:42:10 +03:00
|
|
|
: mParent(aParent) {
|
2014-06-24 22:15:00 +04:00
|
|
|
if (other.mMatrix2D) {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix2D = MakeUnique<gfx::MatrixDouble>(*other.mMatrix2D);
|
2014-06-24 22:15:00 +04:00
|
|
|
} else {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix3D = MakeUnique<gfx::Matrix4x4Double>(*other.mMatrix3D);
|
2014-06-24 22:15:00 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-25 20:42:10 +03:00
|
|
|
DOMMatrixReadOnly(nsISupports* aParent, const gfx::Matrix4x4& aMatrix)
|
|
|
|
: mParent(aParent) {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix3D = MakeUnique<gfx::Matrix4x4Double>(aMatrix);
|
2017-05-10 00:29:42 +03:00
|
|
|
}
|
|
|
|
|
2019-07-11 09:14:58 +03:00
|
|
|
DOMMatrixReadOnly(nsISupports* aParent, const gfx::Matrix& aMatrix)
|
|
|
|
: mParent(aParent) {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix2D = MakeUnique<gfx::MatrixDouble>(aMatrix);
|
2019-07-11 09:14:58 +03:00
|
|
|
}
|
|
|
|
|
2014-11-01 16:10:59 +03:00
|
|
|
NS_INLINE_DECL_CYCLE_COLLECTING_NATIVE_REFCOUNTING(DOMMatrixReadOnly)
|
|
|
|
NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_NATIVE_CLASS(DOMMatrixReadOnly)
|
|
|
|
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
nsISupports* GetParentObject() const { return mParent; }
|
|
|
|
virtual JSObject* WrapObject(JSContext* cx,
|
|
|
|
JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
|
2019-07-11 09:14:58 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> FromMatrix(
|
|
|
|
nsISupports* aParent, const DOMMatrix2DInit& aMatrixInit,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2019-07-06 09:55:53 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> FromMatrix(
|
|
|
|
nsISupports* aParent, const DOMMatrixInit& aMatrixInit, ErrorResult& aRv);
|
|
|
|
|
2019-06-30 06:02:13 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> FromMatrix(
|
|
|
|
const GlobalObject& aGlobal, const DOMMatrixInit& aMatrixInit,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2019-07-03 08:51:30 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> FromFloat32Array(
|
|
|
|
const GlobalObject& aGlobal, const Float32Array& aArray32,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
|
|
|
static already_AddRefed<DOMMatrixReadOnly> FromFloat64Array(
|
|
|
|
const GlobalObject& aGlobal, const Float64Array& aArray64,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> Constructor(
|
|
|
|
const GlobalObject& aGlobal,
|
2020-01-07 12:46:53 +03:00
|
|
|
const Optional<UTF8StringOrUnrestrictedDoubleSequenceOrDOMMatrixReadOnly>&
|
2019-07-17 00:12:38 +03:00
|
|
|
aArg,
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2019-06-15 20:26:25 +03:00
|
|
|
static already_AddRefed<DOMMatrixReadOnly> ReadStructuredClone(
|
2019-06-25 09:48:29 +03:00
|
|
|
JSContext* aCx, nsIGlobalObject* aGlobal,
|
|
|
|
JSStructuredCloneReader* aReader);
|
2019-06-15 20:26:25 +03:00
|
|
|
|
2019-06-13 23:29:24 +03:00
|
|
|
// clang-format off
|
2014-06-24 22:15:00 +04:00
|
|
|
#define GetMatrixMember(entry2D, entry3D, default) \
|
|
|
|
{ \
|
|
|
|
if (mMatrix3D) { \
|
|
|
|
return mMatrix3D->entry3D; \
|
|
|
|
} \
|
|
|
|
return mMatrix2D->entry2D; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Get3DMatrixMember(entry3D, default) \
|
|
|
|
{ \
|
|
|
|
if (mMatrix3D) { \
|
|
|
|
return mMatrix3D->entry3D; \
|
|
|
|
} \
|
|
|
|
return default; \
|
|
|
|
}
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2019-06-13 23:29:24 +03:00
|
|
|
double A() const GetMatrixMember(_11, _11, 1.0)
|
|
|
|
double B() const GetMatrixMember(_12, _12, 0)
|
|
|
|
double C() const GetMatrixMember(_21, _21, 0)
|
|
|
|
double D() const GetMatrixMember(_22, _22, 1.0)
|
|
|
|
double E() const GetMatrixMember(_31, _41, 0)
|
|
|
|
double F() const GetMatrixMember(_32, _42, 0)
|
|
|
|
|
|
|
|
double M11() const GetMatrixMember(_11, _11, 1.0)
|
|
|
|
double M12() const GetMatrixMember(_12, _12, 0)
|
|
|
|
double M13() const Get3DMatrixMember(_13, 0)
|
|
|
|
double M14() const Get3DMatrixMember(_14, 0)
|
|
|
|
double M21() const GetMatrixMember(_21, _21, 0)
|
|
|
|
double M22() const GetMatrixMember(_22, _22, 1.0)
|
|
|
|
double M23() const Get3DMatrixMember(_23, 0)
|
|
|
|
double M24() const Get3DMatrixMember(_24, 0)
|
|
|
|
double M31() const Get3DMatrixMember(_31, 0)
|
|
|
|
double M32() const Get3DMatrixMember(_32, 0)
|
|
|
|
double M33() const Get3DMatrixMember(_33, 1.0)
|
|
|
|
double M34() const Get3DMatrixMember(_34, 0)
|
|
|
|
double M41() const GetMatrixMember(_31, _41, 0)
|
|
|
|
double M42() const GetMatrixMember(_32, _42, 0)
|
|
|
|
double M43() const Get3DMatrixMember(_43, 0)
|
|
|
|
double M44() const Get3DMatrixMember(_44, 1.0)
|
2014-06-24 22:15:00 +04:00
|
|
|
|
|
|
|
#undef GetMatrixMember
|
|
|
|
#undef Get3DMatrixMember
|
|
|
|
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
// Defined here so we can construct DOMMatrixReadOnly objects.
|
|
|
|
#define Set2DMatrixMember(entry2D, entry3D) \
|
|
|
|
{ \
|
|
|
|
if (mMatrix3D) { \
|
|
|
|
mMatrix3D->entry3D = v; \
|
|
|
|
} else { \
|
|
|
|
mMatrix2D->entry2D = v; \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Set3DMatrixMember(entry3D, default) \
|
|
|
|
{ \
|
|
|
|
if (mMatrix3D || (v != default)) { \
|
|
|
|
Ensure3DMatrix(); \
|
|
|
|
mMatrix3D->entry3D = v; \
|
|
|
|
} \
|
|
|
|
}
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2019-06-13 23:29:24 +03:00
|
|
|
void SetA(double v) Set2DMatrixMember(_11, _11)
|
|
|
|
void SetB(double v) Set2DMatrixMember(_12, _12)
|
|
|
|
void SetC(double v) Set2DMatrixMember(_21, _21)
|
|
|
|
void SetD(double v) Set2DMatrixMember(_22, _22)
|
|
|
|
void SetE(double v) Set2DMatrixMember(_31, _41)
|
|
|
|
void SetF(double v) Set2DMatrixMember(_32, _42)
|
|
|
|
|
|
|
|
void SetM11(double v) Set2DMatrixMember(_11, _11)
|
|
|
|
void SetM12(double v) Set2DMatrixMember(_12, _12)
|
|
|
|
void SetM13(double v) Set3DMatrixMember(_13, 0)
|
|
|
|
void SetM14(double v) Set3DMatrixMember(_14, 0)
|
|
|
|
void SetM21(double v) Set2DMatrixMember(_21, _21)
|
|
|
|
void SetM22(double v) Set2DMatrixMember(_22, _22)
|
|
|
|
void SetM23(double v) Set3DMatrixMember(_23, 0)
|
|
|
|
void SetM24(double v) Set3DMatrixMember(_24, 0)
|
|
|
|
void SetM31(double v) Set3DMatrixMember(_31, 0)
|
|
|
|
void SetM32(double v) Set3DMatrixMember(_32, 0)
|
|
|
|
void SetM33(double v) Set3DMatrixMember(_33, 1.0)
|
|
|
|
void SetM34(double v) Set3DMatrixMember(_34, 0)
|
|
|
|
void SetM41(double v) Set2DMatrixMember(_31, _41)
|
|
|
|
void SetM42(double v) Set2DMatrixMember(_32, _42)
|
|
|
|
void SetM43(double v) Set3DMatrixMember(_43, 0)
|
|
|
|
void SetM44(double v) Set3DMatrixMember(_44, 1.0)
|
|
|
|
; // semi-colon here to get clang-format to align properly from here on
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
|
|
|
|
#undef Set2DMatrixMember
|
|
|
|
#undef Set3DMatrixMember
|
2019-06-13 23:29:24 +03:00
|
|
|
// clang-format on
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
|
2019-06-13 23:29:24 +03:00
|
|
|
already_AddRefed<DOMMatrix> Translate(double aTx, double aTy,
|
|
|
|
double aTz = 0) const;
|
2019-06-28 18:11:00 +03:00
|
|
|
already_AddRefed<DOMMatrix> Scale(double aScaleX,
|
|
|
|
const Optional<double>& aScaleY,
|
|
|
|
double aScaleZ, double aOriginX,
|
|
|
|
double aOriginY, double aOriginZ) const;
|
2014-06-24 22:15:00 +04:00
|
|
|
already_AddRefed<DOMMatrix> Scale3d(double aScale, double aOriginX = 0,
|
|
|
|
double aOriginY = 0,
|
|
|
|
double aOriginZ = 0) const;
|
2019-06-28 18:11:00 +03:00
|
|
|
already_AddRefed<DOMMatrix> ScaleNonUniform(double aScaleX,
|
|
|
|
double aScaleY) const;
|
2019-07-02 11:29:46 +03:00
|
|
|
already_AddRefed<DOMMatrix> Rotate(double aRotX,
|
|
|
|
const Optional<double>& aRotY,
|
|
|
|
const Optional<double>& aRotZ) const;
|
2014-06-24 22:15:00 +04:00
|
|
|
already_AddRefed<DOMMatrix> RotateFromVector(double aX, double aY) const;
|
|
|
|
already_AddRefed<DOMMatrix> RotateAxisAngle(double aX, double aY, double aZ,
|
|
|
|
double aAngle) const;
|
|
|
|
already_AddRefed<DOMMatrix> SkewX(double aSx) const;
|
|
|
|
already_AddRefed<DOMMatrix> SkewY(double aSy) const;
|
2019-06-30 06:02:13 +03:00
|
|
|
already_AddRefed<DOMMatrix> Multiply(const DOMMatrixInit& aOther,
|
|
|
|
ErrorResult& aRv) const;
|
2014-06-24 22:15:00 +04:00
|
|
|
already_AddRefed<DOMMatrix> FlipX() const;
|
|
|
|
already_AddRefed<DOMMatrix> FlipY() const;
|
|
|
|
already_AddRefed<DOMMatrix> Inverse() const;
|
|
|
|
|
|
|
|
bool Is2D() const;
|
2017-11-21 11:44:49 +03:00
|
|
|
bool IsIdentity() const;
|
2014-06-24 22:15:00 +04:00
|
|
|
already_AddRefed<DOMPoint> TransformPoint(const DOMPointInit& aPoint) const;
|
|
|
|
void ToFloat32Array(JSContext* aCx, JS::MutableHandle<JSObject*> aResult,
|
|
|
|
ErrorResult& aRv) const;
|
|
|
|
void ToFloat64Array(JSContext* aCx, JS::MutableHandle<JSObject*> aResult,
|
|
|
|
ErrorResult& aRv) const;
|
2019-07-11 05:49:51 +03:00
|
|
|
void Stringify(nsAString& aResult, ErrorResult& aRv);
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2019-06-25 09:48:29 +03:00
|
|
|
bool WriteStructuredClone(JSContext* aCx,
|
|
|
|
JSStructuredCloneWriter* aWriter) const;
|
2019-07-11 09:14:58 +03:00
|
|
|
const gfx::MatrixDouble* GetInternal2D() const {
|
|
|
|
if (Is2D()) {
|
2020-04-04 00:05:29 +03:00
|
|
|
return mMatrix2D.get();
|
2019-07-11 09:14:58 +03:00
|
|
|
}
|
|
|
|
return nullptr;
|
|
|
|
}
|
2019-06-15 20:26:25 +03:00
|
|
|
|
2014-06-24 22:15:00 +04:00
|
|
|
protected:
|
|
|
|
nsCOMPtr<nsISupports> mParent;
|
2020-04-04 00:05:29 +03:00
|
|
|
UniquePtr<gfx::MatrixDouble> mMatrix2D;
|
|
|
|
UniquePtr<gfx::Matrix4x4Double> mMatrix3D;
|
2014-07-06 00:35:35 +04:00
|
|
|
|
2020-02-21 13:41:47 +03:00
|
|
|
virtual ~DOMMatrixReadOnly() = default;
|
2014-11-01 16:10:59 +03:00
|
|
|
|
2019-06-30 06:02:13 +03:00
|
|
|
/**
|
|
|
|
* Sets data from a fully validated and fixed-up matrix init,
|
|
|
|
* where all of its members are properly defined.
|
|
|
|
* The init dictionary's dimension must match the matrix one.
|
|
|
|
*/
|
2019-07-11 09:14:58 +03:00
|
|
|
void SetDataFromMatrix2DInit(const DOMMatrix2DInit& aMatrixInit);
|
|
|
|
void SetDataFromMatrixInit(const DOMMatrixInit& aMatrixInit);
|
2019-06-30 06:02:13 +03:00
|
|
|
|
2020-01-07 12:46:53 +03:00
|
|
|
DOMMatrixReadOnly* SetMatrixValue(const nsACString&, ErrorResult&);
|
Bug 1186265 - Partially update DOMPoint, DOMQuad, DOMRect, DOMMatrix. r=bz
Some notes: this does not fully bring us to compliance to the current spec.
Instead, these are the fixes that I needed to make in order to make
css/geometry/interfaces.html pass with the DOMPoint changes in the previous
patches. I don't fully understand why that patch caused the test to fail the
way it did, but it ended up being easier to fix our code than understand why
the harness was falling over.
The DOMQuad::QuadBounds class was the source of some confusion for me. Now
that DOMRectReadOnly is a concrete class with members, I wanted to avoid
wasting them. However, the spec is unclear as to whether a DOMQuad's bound's
should be live -- that is because DOMQuad exposes DOMPoint, we can set its
points after retrieving a QuadBounds object. Our current code is live, setting
the points changes the QuadBounds. Chromium's current behavior is to never
update the QuadBounds object. I've left our behavior untouched in this patch
(and waste 4 doubles per QuadBounds object), but I am intending to file a bug
to understand what the intent of the spec is. I wonder if the author intended
the points to be DOMPointReadOnly instead. If so, we could simplify the
DOMRectReadOnly code and get rid of the virtual getters, which would be nice.
I also wasn't thrilled to put the DOMMatrix setters on the DOMMatrixReadOnly
class, but for brevity and simplicity of implementation, I've made them
public. I briefly considered making the setters protected on the ReadOnly
version of the class, but I'm not convinced that having to explicitly make
them public on the derived class is worth the extra copies of the names.
MozReview-Commit-ID: CjdW4Nbnc6A
--HG--
extra : rebase_source : 44489693afebff571a415b487e29fa6153288421
2018-03-30 02:19:31 +03:00
|
|
|
void Ensure3DMatrix();
|
|
|
|
|
2019-06-15 20:26:25 +03:00
|
|
|
DOMMatrixReadOnly(nsISupports* aParent, bool is2D) : mParent(aParent) {
|
|
|
|
if (is2D) {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix2D = MakeUnique<gfx::MatrixDouble>();
|
2019-06-15 20:26:25 +03:00
|
|
|
} else {
|
2020-04-04 00:05:29 +03:00
|
|
|
mMatrix3D = MakeUnique<gfx::Matrix4x4Double>();
|
2019-06-15 20:26:25 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-25 09:48:29 +03:00
|
|
|
static bool ReadStructuredCloneElements(JSStructuredCloneReader* aReader,
|
|
|
|
DOMMatrixReadOnly* matrix);
|
|
|
|
|
2014-06-24 22:15:00 +04:00
|
|
|
private:
|
2015-01-07 02:35:02 +03:00
|
|
|
DOMMatrixReadOnly() = delete;
|
|
|
|
DOMMatrixReadOnly(const DOMMatrixReadOnly&) = delete;
|
|
|
|
DOMMatrixReadOnly& operator=(const DOMMatrixReadOnly&) = delete;
|
2014-06-24 22:15:00 +04:00
|
|
|
};
|
|
|
|
|
2016-01-21 01:48:01 +03:00
|
|
|
class DOMMatrix : public DOMMatrixReadOnly {
|
2014-06-24 22:15:00 +04:00
|
|
|
public:
|
2018-03-25 20:42:10 +03:00
|
|
|
explicit DOMMatrix(nsISupports* aParent) : DOMMatrixReadOnly(aParent) {}
|
2014-06-24 22:15:00 +04:00
|
|
|
|
|
|
|
DOMMatrix(nsISupports* aParent, const DOMMatrixReadOnly& other)
|
|
|
|
: DOMMatrixReadOnly(aParent, other) {}
|
|
|
|
|
2018-03-25 20:42:10 +03:00
|
|
|
DOMMatrix(nsISupports* aParent, const gfx::Matrix4x4& aMatrix)
|
|
|
|
: DOMMatrixReadOnly(aParent, aMatrix) {}
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2019-07-11 09:14:58 +03:00
|
|
|
DOMMatrix(nsISupports* aParent, const gfx::Matrix& aMatrix)
|
|
|
|
: DOMMatrixReadOnly(aParent, aMatrix) {}
|
|
|
|
|
2019-06-30 06:02:13 +03:00
|
|
|
static already_AddRefed<DOMMatrix> FromMatrix(
|
|
|
|
nsISupports* aParent, const DOMMatrixInit& aMatrixInit, ErrorResult& aRv);
|
|
|
|
|
|
|
|
static already_AddRefed<DOMMatrix> FromMatrix(
|
|
|
|
const GlobalObject& aGlobal, const DOMMatrixInit& aMatrixInit,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2019-07-03 08:51:30 +03:00
|
|
|
static already_AddRefed<DOMMatrix> FromFloat32Array(
|
|
|
|
const GlobalObject& aGlobal, const Float32Array& aArray32,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
|
|
|
static already_AddRefed<DOMMatrix> FromFloat64Array(
|
|
|
|
const GlobalObject& aGlobal, const Float64Array& aArray64,
|
|
|
|
ErrorResult& aRv);
|
|
|
|
|
2014-06-24 22:15:00 +04:00
|
|
|
static already_AddRefed<DOMMatrix> Constructor(
|
2019-07-17 00:12:38 +03:00
|
|
|
const GlobalObject& aGlobal,
|
2020-01-07 12:46:53 +03:00
|
|
|
const Optional<UTF8StringOrUnrestrictedDoubleSequenceOrDOMMatrixReadOnly>&
|
2019-07-17 00:12:38 +03:00
|
|
|
aArg,
|
2014-06-24 22:15:00 +04:00
|
|
|
ErrorResult& aRv);
|
2018-11-30 13:46:48 +03:00
|
|
|
|
2019-06-15 20:26:25 +03:00
|
|
|
static already_AddRefed<DOMMatrix> ReadStructuredClone(
|
2019-06-25 09:48:29 +03:00
|
|
|
JSContext* aCx, nsIGlobalObject* aGlobal,
|
|
|
|
JSStructuredCloneReader* aReader);
|
2019-06-15 20:26:25 +03:00
|
|
|
|
2015-03-21 19:28:04 +03:00
|
|
|
virtual JSObject* WrapObject(JSContext* aCx,
|
|
|
|
JS::Handle<JSObject*> aGivenProto) override;
|
2014-06-24 22:15:00 +04:00
|
|
|
|
2019-06-30 06:02:13 +03:00
|
|
|
DOMMatrix* MultiplySelf(const DOMMatrixInit& aOther, ErrorResult& aRv);
|
|
|
|
DOMMatrix* PreMultiplySelf(const DOMMatrixInit& aOther, ErrorResult& aRv);
|
2014-06-24 22:15:00 +04:00
|
|
|
DOMMatrix* TranslateSelf(double aTx, double aTy, double aTz = 0);
|
2019-06-28 18:11:00 +03:00
|
|
|
DOMMatrix* ScaleSelf(double aScaleX, const Optional<double>& aScaleY,
|
|
|
|
double aScaleZ, double aOriginX, double aOriginY,
|
|
|
|
double aOriginZ);
|
2014-06-24 22:15:00 +04:00
|
|
|
DOMMatrix* Scale3dSelf(double aScale, double aOriginX = 0,
|
|
|
|
double aOriginY = 0, double aOriginZ = 0);
|
2019-07-02 11:29:46 +03:00
|
|
|
DOMMatrix* RotateSelf(double aRotX, const Optional<double>& aRotY,
|
|
|
|
const Optional<double>& aRotZ);
|
2014-06-24 22:15:00 +04:00
|
|
|
DOMMatrix* RotateFromVectorSelf(double aX, double aY);
|
|
|
|
DOMMatrix* RotateAxisAngleSelf(double aX, double aY, double aZ,
|
|
|
|
double aAngle);
|
|
|
|
DOMMatrix* SkewXSelf(double aSx);
|
|
|
|
DOMMatrix* SkewYSelf(double aSy);
|
|
|
|
DOMMatrix* InvertSelf();
|
2020-01-07 12:46:53 +03:00
|
|
|
DOMMatrix* SetMatrixValue(const nsACString&, ErrorResult&);
|
2016-01-21 01:48:01 +03:00
|
|
|
|
2020-02-21 13:41:47 +03:00
|
|
|
virtual ~DOMMatrix() = default;
|
2019-06-15 20:26:25 +03:00
|
|
|
|
|
|
|
private:
|
|
|
|
DOMMatrix(nsISupports* aParent, bool is2D)
|
|
|
|
: DOMMatrixReadOnly(aParent, is2D) {}
|
2014-06-24 22:15:00 +04:00
|
|
|
};
|
|
|
|
|
2015-07-13 18:25:42 +03:00
|
|
|
} // namespace dom
|
|
|
|
} // namespace mozilla
|
2014-06-24 22:15:00 +04:00
|
|
|
|
|
|
|
#endif /*MOZILLA_DOM_DOMMATRIX_H_*/
|