use SkM44 internally

Today we use SkM44 in canvas, and SkMatrix44 in sksl (and colormatrix).
This CL tries to move core to use a single type.

SkMatrix44 has callers in android and chrome, is loaded with double/float
variants in its API. I am suggesting moving to a private, clean-start,
API for internal use. SkM44 is much faster, and has a leaner API.

If eventually we can migrate clients to a shared impl/api, great. For now,
I want to have one we are free to optimize/use as we see fit without
worrying about changing client results.

Change-Id: Id782ac1cc8b8d7f6621970e44e1f9729964d2a94
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/265299
Commit-Queue: Mike Reed <reed@google.com>
Reviewed-by: Brian Salomon <bsalomon@google.com>
This commit is contained in:
Mike Reed 2020-01-22 12:00:38 -05:00 committed by Skia Commit-Bot
parent f9aea7f7e5
commit 295cdf8775
48 changed files with 151 additions and 138 deletions

View File

@ -358,7 +358,7 @@ protected:
if (fType == k3x3_Type) {
m[7] = 0.0001f;
}
SkMatrix44 m4(m);
SkM44 m4(m);
for (int i = 0; i < loops; ++i) {
canvas->save();

View File

@ -8,9 +8,9 @@
#ifndef SkM44_DEFINED
#define SkM44_DEFINED
#include "include/core/SkMatrix.h"
#include "include/core/SkScalar.h"
class SkMatrix;
class SkMatrix44;
struct SkV3 {
@ -19,6 +19,7 @@ struct SkV3 {
bool operator==(const SkV3& v) const {
return x == v.x && y == v.y && z == v.z;
}
bool operator!=(const SkV3& v) const { return !(*this == v); }
static SkScalar Dot(const SkV3& a, const SkV3& b) { return a.x*b.x + a.y*b.y + a.z*b.z; }
static SkV3 Cross(const SkV3& a, const SkV3& b) {
@ -47,6 +48,14 @@ struct SkV4 {
bool operator==(const SkV4& v) const {
return x == v.x && y == v.y && z == v.z && w == v.w;
}
bool operator!=(const SkV4& v) const { return !(*this == v); }
SkV4 operator-() const { return {-x, -y, -z, -w}; }
SkV4 operator+(const SkV4& v) const { return { x + v.x, y + v.y, z + v.z, w + v.w }; }
SkV4 operator-(const SkV4& v) const { return { x - v.x, y - v.y, z - v.z, w - v.w }; }
const float* vec() const { return &x; }
float* vec() { return &x; }
};
class SkM44 {
@ -68,9 +77,18 @@ public:
enum Uninitialized_Constructor {
kUninitialized_Constructor
};
SkM44(Uninitialized_Constructor) {}
enum NaN_Constructor {
kNaN_Constructor
};
SkM44(NaN_Constructor)
: fMat{SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN,
SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN,
SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN,
SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN, SK_ScalarNaN}
{}
/**
* Parameters are treated as row-major.
*/

View File

@ -13,7 +13,6 @@
class SkArenaAlloc;
class SkColorSpace;
class SkMatrix;
class SkPaint;
class SkRasterPipeline;

View File

@ -8,6 +8,7 @@
#ifndef SkImageFilterTypes_DEFINED
#define SkImageFilterTypes_DEFINED
#include "include/core/SkMatrix.h"
#include "src/core/SkSpecialImage.h"
#include "src/core/SkSpecialSurface.h"

View File

@ -5,7 +5,7 @@
* found in the LICENSE file.
*/
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/core/SkYUVMath.h"
// in SkColorMatrix order (row-major)
@ -106,29 +106,34 @@ void SkColorMatrix_YUV2RGB(SkYUVColorSpace cs, float m[20]) {
// | 3x3 tg |
// | tb |
// | 0 0 0 1 |
static void colormatrix_to_matrix44(const float src[20], SkMatrix44* dst) {
for (int r = 0; r < 3; ++r) {
for (int c = 0; c < 3; ++c) {
dst->set(r, c, src[r*5 + c]);
}
dst->set(r, 3, src[r*5 + 4]);
}
dst->set(3, 0, 0);
dst->set(3, 1, 0);
dst->set(3, 2, 0);
dst->set(3, 3, 1);
static void colormatrix_to_matrix44(const float src[20], SkM44* dst) {
*dst = SkM44(src[ 0], src[ 1], src[ 2], src[ 4],
src[ 5], src[ 6], src[ 7], src[ 9],
src[10], src[11], src[12], src[14],
0, 0, 0, 1);
}
// input: ignore the bottom row
// output: inject identity row/column for alpha
static void matrix44_to_colormatrix(const SkMatrix44& src, float dst[20]) {
for (int r = 0; r < 3; ++r) {
for (int c = 0; c < 3; ++c) {
dst[r*5 + c] = src.get(r, c);
}
dst[r*5 + 3] = 0; // scale alpha
dst[r*5 + 4] = src.get(r, 3); // translate
}
static void matrix44_to_colormatrix(const SkM44& src, float dst[20]) {
dst[0] = src.atColMajor(0);
dst[1] = src.atColMajor(4);
dst[2] = src.atColMajor(8);
dst[3] = 0;
dst[4] = src.atColMajor(12); // tx
dst[5] = src.atColMajor(1);
dst[6] = src.atColMajor(5);
dst[7] = src.atColMajor(9);
dst[8] = 0;
dst[9] = src.atColMajor(13); // ty
dst[10] = src.atColMajor(2);
dst[11] = src.atColMajor(6);
dst[12] = src.atColMajor(10);
dst[13] = 0;
dst[14] = src.atColMajor(14); // tz
dst[15] = dst[16] = dst[17] = dst[19] = 0;
dst[18] = 1;
}
@ -206,7 +211,7 @@ void SkColorMatrix_DumpYUVMatrixTables() {
float m[20];
make_rgb_to_yuv_matrix(m, gCoeff[(unsigned)cs]);
dump(m, cs, true);
SkMatrix44 m44, im44;
SkM44 m44, im44;
colormatrix_to_matrix44(m, &m44);
float im[20];
#ifdef SK_DEBUG

View File

@ -5,8 +5,8 @@
* found in the LICENSE file.
*/
layout(ctype=SkMatrix44, tracked) in uniform half4x4 m;
layout(ctype=SkVector4, tracked) in uniform half4 v;
layout(ctype=SkM44, tracked) in uniform half4x4 m;
layout(ctype=SkV4, tracked) in uniform half4 v;
layout(key) in bool unpremulInput;
layout(key) in bool clampRGBOutput;
layout(key) in bool premulOutput;
@ -45,11 +45,8 @@ void main() {
color.fB = input.fB;
color.fA = input.fA;
}
m.mapScalars(color.vec());
color.fR += v.fData[0];
color.fG += v.fData[1];
color.fB += v.fData[2];
color.fA += v.fData[3];
auto v4 = m.map(color.fR, color.fG, color.fB, color.fA) + v;
color = {v4.x, v4.y, v4.z, v4.w};
color.fA = SkTPin(color.fA, 0.f, 1.f);
if (clampRGBOutput) {
color.fR = SkTPin(color.fR, 0.f, 1.f);
@ -66,14 +63,13 @@ void main() {
@make {
static std::unique_ptr<GrFragmentProcessor> Make(const float matrix[20], bool unpremulInput, bool clampRGBOutput, bool premulOutput) {
SkMatrix44 m44;
m44.set4x4(
SkM44 m44(
matrix[0], matrix[5], matrix[10], matrix[15],
matrix[1], matrix[6], matrix[11], matrix[16],
matrix[2], matrix[7], matrix[12], matrix[17],
matrix[3], matrix[8], matrix[13], matrix[18]
);
auto v4 = SkVector4(matrix[4], matrix[9], matrix[14], matrix[19]);
SkV4 v4 = {matrix[4], matrix[9], matrix[14], matrix[19]};
return std::unique_ptr<GrFragmentProcessor>(new GrColorMatrixFragmentProcessor(m44, v4, unpremulInput, clampRGBOutput, premulOutput));
}
}

View File

@ -11,7 +11,7 @@
#ifndef GrAARectEffect_DEFINED
#define GrAARectEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrAlphaThresholdFragmentProcessor_DEFINED
#define GrAlphaThresholdFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrBlurredEdgeFragmentProcessor_DEFINED
#define GrBlurredEdgeFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrCircleBlurFragmentProcessor_DEFINED
#define GrCircleBlurFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrCircleEffect_DEFINED
#define GrCircleEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrClampFragmentProcessor_DEFINED
#define GrClampFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -55,20 +55,20 @@ private:
const GrFragmentProcessor& _proc) override {
const GrColorMatrixFragmentProcessor& _outer = _proc.cast<GrColorMatrixFragmentProcessor>();
{
const SkMatrix44& mValue = _outer.m;
const SkM44& mValue = _outer.m;
if (mPrev != (mValue)) {
mPrev = mValue;
pdman.setSkMatrix44(mVar, mValue);
pdman.setSkM44(mVar, mValue);
}
const SkVector4& vValue = _outer.v;
const SkV4& vValue = _outer.v;
if (vPrev != (vValue)) {
vPrev = vValue;
pdman.set4fv(vVar, 1, vValue.fData);
pdman.set4fv(vVar, 1, vValue.vec());
}
}
}
SkMatrix44 mPrev = SkMatrix44(SkMatrix44::kNaN_Constructor);
SkVector4 vPrev = SkVector4(SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN);
SkM44 mPrev = SkM44(SkM44::kNaN_Constructor);
SkV4 vPrev = SkV4{SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN};
UniformHandle mVar;
UniformHandle vVar;
};

View File

@ -11,7 +11,7 @@
#ifndef GrColorMatrixFragmentProcessor_DEFINED
#define GrColorMatrixFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"
@ -27,11 +27,8 @@ public:
color.fB = input.fB;
color.fA = input.fA;
}
m.mapScalars(color.vec());
color.fR += v.fData[0];
color.fG += v.fData[1];
color.fB += v.fData[2];
color.fA += v.fData[3];
auto v4 = m.map(color.fR, color.fG, color.fB, color.fA) + v;
color = {v4.x, v4.y, v4.z, v4.w};
color.fA = SkTPin(color.fA, 0.f, 1.f);
if (clampRGBOutput) {
color.fR = SkTPin(color.fR, 0.f, 1.f);
@ -47,26 +44,25 @@ public:
static std::unique_ptr<GrFragmentProcessor> Make(const float matrix[20], bool unpremulInput,
bool clampRGBOutput, bool premulOutput) {
SkMatrix44 m44;
m44.set4x4(matrix[0], matrix[5], matrix[10], matrix[15], matrix[1], matrix[6], matrix[11],
SkM44 m44(matrix[0], matrix[5], matrix[10], matrix[15], matrix[1], matrix[6], matrix[11],
matrix[16], matrix[2], matrix[7], matrix[12], matrix[17], matrix[3], matrix[8],
matrix[13], matrix[18]);
auto v4 = SkVector4(matrix[4], matrix[9], matrix[14], matrix[19]);
SkV4 v4 = {matrix[4], matrix[9], matrix[14], matrix[19]};
return std::unique_ptr<GrFragmentProcessor>(new GrColorMatrixFragmentProcessor(
m44, v4, unpremulInput, clampRGBOutput, premulOutput));
}
GrColorMatrixFragmentProcessor(const GrColorMatrixFragmentProcessor& src);
std::unique_ptr<GrFragmentProcessor> clone() const override;
const char* name() const override { return "ColorMatrixFragmentProcessor"; }
SkMatrix44 m;
SkVector4 v;
SkM44 m;
SkV4 v;
bool unpremulInput;
bool clampRGBOutput;
bool premulOutput;
private:
GrColorMatrixFragmentProcessor(SkMatrix44 m, SkVector4 v, bool unpremulInput,
bool clampRGBOutput, bool premulOutput)
GrColorMatrixFragmentProcessor(SkM44 m, SkV4 v, bool unpremulInput, bool clampRGBOutput,
bool premulOutput)
: INHERITED(kGrColorMatrixFragmentProcessor_ClassID,
(OptimizationFlags)kConstantOutputForConstantInput_OptimizationFlag)
, m(m)

View File

@ -11,7 +11,7 @@
#ifndef GrComposeLerpEffect_DEFINED
#define GrComposeLerpEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrComposeLerpRedEffect_DEFINED
#define GrComposeLerpRedEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrConfigConversionEffect_DEFINED
#define GrConfigConversionEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "include/gpu/GrContext.h"
#include "src/gpu/GrClip.h"

View File

@ -11,7 +11,7 @@
#ifndef GrConstColorProcessor_DEFINED
#define GrConstColorProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrEllipseEffect_DEFINED
#define GrEllipseEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrShaderCaps.h"

View File

@ -11,7 +11,7 @@
#ifndef GrHSLToRGBFilterEffect_DEFINED
#define GrHSLToRGBFilterEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrLumaColorFilterEffect_DEFINED
#define GrLumaColorFilterEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrMagnifierEffect_DEFINED
#define GrMagnifierEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrMixerEffect_DEFINED
#define GrMixerEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrOverrideInputFragmentProcessor_DEFINED
#define GrOverrideInputFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrPremulInputFragmentProcessor_DEFINED
#define GrPremulInputFragmentProcessor_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrRGBToHSLFilterEffect_DEFINED
#define GrRGBToHSLFilterEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrRRectBlurEffect_DEFINED
#define GrRRectBlurEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "include/gpu/GrContext.h"
#include "include/private/GrRecordingContext.h"

View File

@ -11,7 +11,7 @@
#ifndef GrRectBlurEffect_DEFINED
#define GrRectBlurEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include <cmath>
#include "include/core/SkRect.h"

View File

@ -8,7 +8,7 @@
#include "src/gpu/glsl/GrGLSLProgramDataManager.h"
#include "include/core/SkMatrix.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
void GrGLSLProgramDataManager::setSkMatrix(UniformHandle u, const SkMatrix& matrix) const {
float mt[] = {
@ -25,8 +25,6 @@ void GrGLSLProgramDataManager::setSkMatrix(UniformHandle u, const SkMatrix& matr
this->setMatrix3f(u, mt);
}
void GrGLSLProgramDataManager::setSkMatrix44(UniformHandle u, const SkMatrix44& matrix) const {
float mt[16];
matrix.asColMajorf(mt);
this->setMatrix4f(u, mt);
void GrGLSLProgramDataManager::setSkM44(UniformHandle u, const SkM44& matrix) const {
this->setMatrix4f(u, matrix.asColMajor());
}

View File

@ -13,7 +13,7 @@
#include "src/gpu/GrResourceHandle.h"
class SkMatrix;
class SkMatrix44;
class SkM44;
/** Manages the resources used by a shader program.
* The resources are objects the program uses to communicate with the
@ -56,7 +56,7 @@ public:
// convenience method for uploading a SkMatrix to a 3x3 matrix uniform
void setSkMatrix(UniformHandle, const SkMatrix&) const;
// convenience method for uploading a SkMatrix to a 4x4 matrix uniform
void setSkMatrix44(UniformHandle, const SkMatrix44&) const;
void setSkM44(UniformHandle, const SkM44&) const;
// for nvpr only
GR_DEFINE_RESOURCE_HANDLE_CLASS(VaryingHandle);

View File

@ -11,7 +11,7 @@
#ifndef GrClampedGradientEffect_DEFINED
#define GrClampedGradientEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrDualIntervalGradientColorizer_DEFINED
#define GrDualIntervalGradientColorizer_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrLinearGradientLayout_DEFINED
#define GrLinearGradientLayout_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/gradients/GrGradientShader.h"
#include "src/shaders/gradients/SkLinearGradient.h"

View File

@ -11,7 +11,7 @@
#ifndef GrRadialGradientLayout_DEFINED
#define GrRadialGradientLayout_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/gradients/GrGradientShader.h"
#include "src/shaders/gradients/SkRadialGradient.h"

View File

@ -11,7 +11,7 @@
#ifndef GrSingleIntervalGradientColorizer_DEFINED
#define GrSingleIntervalGradientColorizer_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrSweepGradientLayout_DEFINED
#define GrSweepGradientLayout_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/gradients/GrGradientShader.h"
#include "src/shaders/gradients/SkSweepGradient.h"

View File

@ -11,7 +11,7 @@
#ifndef GrTextureGradientColorizer_DEFINED
#define GrTextureGradientColorizer_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrTiledGradientEffect_DEFINED
#define GrTiledGradientEffect_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -11,7 +11,7 @@
#ifndef GrTwoPointConicalGradientLayout_DEFINED
#define GrTwoPointConicalGradientLayout_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/gradients/GrGradientShader.h"
#include "src/shaders/gradients/SkTwoPointConicalGradient.h"

View File

@ -11,7 +11,7 @@
#ifndef GrUnrolledBinaryGradientColorizer_DEFINED
#define GrUnrolledBinaryGradientColorizer_DEFINED
#include "include/core/SkTypes.h"
#include "include/core/SkMatrix44.h"
#include "include/private/SkM44.h"
#include "src/gpu/GrCoordTransform.h"
#include "src/gpu/GrFragmentProcessor.h"

View File

@ -208,11 +208,11 @@ void CPPCodeGenerator::writeRuntimeValue(const Type& type, const Layout& layout,
fFormatArgs.push_back(cppCode + ".fB");
fFormatArgs.push_back(cppCode + ".fA");
break;
case Layout::CType::kSkVector4:
fFormatArgs.push_back(cppCode + ".fData[0]");
fFormatArgs.push_back(cppCode + ".fData[1]");
fFormatArgs.push_back(cppCode + ".fData[2]");
fFormatArgs.push_back(cppCode + ".fData[3]");
case Layout::CType::kSkV4:
fFormatArgs.push_back(cppCode + ".x");
fFormatArgs.push_back(cppCode + ".y");
fFormatArgs.push_back(cppCode + ".z");
fFormatArgs.push_back(cppCode + ".w");
break;
case Layout::CType::kSkRect: // fall through
case Layout::CType::kDefault:

View File

@ -161,9 +161,9 @@ static const std::vector<UniformCTypeMapper>& get_mappers() {
"${pdman}.set4fv(${uniform}, 1, ${var}.vec())", // to gpu
"{SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN}"), // default value
REGISTER(Layout::CType::kSkVector4, { "half4", "float4", "double4" },
"${pdman}.set4fv(${uniform}, 1, ${var}.fData)", // to gpu
"SkVector4(SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN)", // default value
REGISTER(Layout::CType::kSkV4, { "half4", "float4", "double4" },
"${pdman}.set4fv(${uniform}, 1, ${var}.vec())", // to gpu
"SkV4{SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN}", // default value
"${oldVar} != (${newVar})"), // dirty check
REGISTER(Layout::CType::kSkPoint, { "half2", "float2", "double2" } ,
@ -179,9 +179,9 @@ static const std::vector<UniformCTypeMapper>& get_mappers() {
"SkMatrix::MakeScale(SK_FloatNaN)", // default value
"!${oldVar}.cheapEqualTo(${newVar})"), // dirty check
REGISTER(Layout::CType::kSkMatrix44, { "half4x4", "float4x4", "double4x4" },
"${pdman}.setSkMatrix44(${uniform}, ${var})", // to gpu
"SkMatrix44(SkMatrix44::kNaN_Constructor)", // default value
REGISTER(Layout::CType::kSkM44, { "half4x4", "float4x4", "double4x4" },
"${pdman}.setSkM44(${uniform}, ${var})", // to gpu
"SkM44(SkM44::kNaN_Constructor)", // default value
"${oldVar} != (${newVar})"), // dirty check
REGISTER(Layout::CType::kFloat, { "half", "float", "double" },

View File

@ -64,7 +64,7 @@ Layout::CType HCodeGenerator::ParameterCType(const Context& context, const Type&
} else if (type == *context.fFloat3x3_Type || type == *context.fHalf3x3_Type) {
return Layout::CType::kSkMatrix;
} else if (type == *context.fFloat4x4_Type || type == *context.fHalf4x4_Type) {
return Layout::CType::kSkMatrix44;
return Layout::CType::kSkM44;
} else if (type.kind() == Type::kSampler_Kind) {
return Layout::CType::kGrSurfaceProxy;
} else if (type == *context.fFragmentProcessor_Type) {
@ -347,7 +347,7 @@ bool HCodeGenerator::generateCode() {
fFullName.c_str(),
fFullName.c_str());
this->writef("#include \"include/core/SkTypes.h\"\n");
this->writef("#include \"include/core/SkMatrix44.h\"\n");
this->writef("#include \"include/private/SkM44.h\"\n");
this->writeSection(HEADER_SECTION);
this->writef("\n"
"#include \"src/gpu/GrCoordTransform.h\"\n"

View File

@ -90,11 +90,11 @@ void Parser::InitLayoutMap() {
TOKEN(TRACKED, "tracked");
TOKEN(CTYPE, "ctype");
TOKEN(SKPMCOLOR4F, "SkPMColor4f");
TOKEN(SKVECTOR4, "SkVector4");
TOKEN(SKV4, "SkV4");
TOKEN(SKRECT, "SkRect");
TOKEN(SKIRECT, "SkIRect");
TOKEN(SKPMCOLOR, "SkPMColor");
TOKEN(SKMATRIX44, "SkMatrix44");
TOKEN(SKM44, "SkM44");
TOKEN(BOOL, "bool");
TOKEN(INT, "int");
TOKEN(FLOAT, "float");
@ -730,8 +730,8 @@ Layout::CType Parser::layoutCType() {
switch (found->second) {
case LayoutToken::SKPMCOLOR4F:
return Layout::CType::kSkPMColor4f;
case LayoutToken::SKVECTOR4:
return Layout::CType::kSkVector4;
case LayoutToken::SKV4:
return Layout::CType::kSkV4;
case LayoutToken::SKRECT:
return Layout::CType::kSkRect;
case LayoutToken::SKIRECT:
@ -744,8 +744,8 @@ Layout::CType Parser::layoutCType() {
return Layout::CType::kInt32;
case LayoutToken::FLOAT:
return Layout::CType::kFloat;
case LayoutToken::SKMATRIX44:
return Layout::CType::kSkMatrix44;
case LayoutToken::SKM44:
return Layout::CType::kSkM44;
default:
break;
}

View File

@ -73,11 +73,11 @@ public:
TRACKED,
CTYPE,
SKPMCOLOR4F,
SKVECTOR4,
SKV4,
SKRECT,
SKIRECT,
SKPMCOLOR,
SKMATRIX44,
SKM44,
BOOL,
INT,
FLOAT,

View File

@ -90,11 +90,11 @@ struct Layout {
kSkIRect,
kSkPMColor4f,
kSkPMColor,
kSkVector4,
kSkV4,
kSkPoint,
kSkIPoint,
kSkMatrix,
kSkMatrix44,
kSkM44,
kGrSurfaceProxy,
kGrFragmentProcessor,
};
@ -167,16 +167,16 @@ struct Layout {
return "SkPMColor4f";
case CType::kSkPMColor:
return "SkPMColor";
case CType::kSkVector4:
return "SkVector4";
case CType::kSkV4:
return "SkV4";
case CType::kSkPoint:
return "SkPoint";
case CType::kSkIPoint:
return "SkIPoint";
case CType::kSkMatrix:
return "SkMatrix";
case CType::kSkMatrix44:
return "SkMatrix44";
case CType::kSkM44:
return "SkM44";
case CType::kGrSurfaceProxy:
return "sk_sp<GrSurfaceProxy>";
case CType::kGrFragmentProcessor:

View File

@ -94,7 +94,7 @@ DEF_TEST(SkSLFPHelloWorld, r) {
"#ifndef GrTest_DEFINED\n"
"#define GrTest_DEFINED\n"
"#include \"include/core/SkTypes.h\"\n"
"#include \"include/core/SkMatrix44.h\"\n\n"
"#include \"include/private/SkM44.h\"\n\n"
"#include \"src/gpu/GrCoordTransform.h\"\n"
"#include \"src/gpu/GrFragmentProcessor.h\"\n"
"class GrTest : public GrFragmentProcessor {\n"

View File

@ -5,8 +5,7 @@
* found in the LICENSE file.
*/
#include "include/core/SkMatrix44.h"
#include "include/core/SkPoint3.h"
#include "include/private/SkM44.h"
#include "src/sksl/SkSLByteCode.h"
#include "src/sksl/SkSLCompiler.h"
#include "src/sksl/SkSLExternalValue.h"
@ -369,12 +368,14 @@ DEF_TEST(SkSLInterpreterMatrix, r) {
// M*M
{
SkMatrix44 m;
m.setColMajorf(in);
SkMatrix44 m2;
SkM44 m;
m.setColMajor(in);
SkM44 m2;
float in2[16];
for (int i = 0; i < 16; ++i) {
m2.set(i % 4, i / 4, (i + 4) % 16);
in2[i] = (i + 4) % 16;
}
m2.setColMajor(in2);
m.setConcat(m, m2);
// Rearrange the columns on the RHS so we detect left-hand/right-hand errors
test(r, "float4x4 main(float4x4 m) { return m * float4x4(m[1], m[2], m[3], m[0]); }",
@ -860,9 +861,9 @@ DEF_TEST(SkSLInterpreterMix, r) {
DEF_TEST(SkSLInterpreterCross, r) {
float args[] = { 1.0f, 4.0f, -6.0f, -2.0f, 7.0f, -3.0f };
SkPoint3 cross = SkPoint3::CrossProduct(SkPoint3::Make(args[0], args[1], args[2]),
SkPoint3::Make(args[3], args[4], args[5]));
float expected[] = { cross.fX, cross.fY, cross.fZ };
SkV3 cross = SkV3::Cross({args[0], args[1], args[2]},
{args[3], args[4], args[5]});
float expected[] = { cross.x, cross.y, cross.z };
test(r, "float3 main(float3 x, float3 y) { return cross(x, y); }", args, expected);
}
@ -885,12 +886,11 @@ DEF_TEST(SkSLInterpreterInverse, r) {
}
{
float args[16], expt[16];
SkMatrix44 m;
// just some crazy thing that is invertible
m.set4x4(1, 2, 3, 4, 1, 2, 0, 3, 1, 0, 1, 4, 1, 3, 2, 0);
m.asColMajorf(args);
SkM44 m = {1, 2, 3, 4, 1, 2, 0, 3, 1, 0, 1, 4, 1, 3, 2, 0};
m.getColMajor(args);
SkAssertResult(m.invert(&m));
m.asColMajorf(expt);
m.getColMajor(expt);
test(r, "float4x4 main(float4x4 m) { return inverse(m); }", args, expt, false);
}
}