2018-12-10 17:41:26 +00:00
|
|
|
function CanvasPattern(image, repetition) {
|
|
|
|
this._shader = null;
|
2020-10-07 20:09:22 +00:00
|
|
|
// image should be an Image returned from HTMLCanvas.decodeImage()
|
2018-12-10 17:41:26 +00:00
|
|
|
this._image = image;
|
2020-10-07 20:09:22 +00:00
|
|
|
this._transform = CanvasKit.Matrix.identity();
|
2018-12-10 17:41:26 +00:00
|
|
|
|
|
|
|
if (repetition === '') {
|
|
|
|
repetition = 'repeat';
|
|
|
|
}
|
|
|
|
switch(repetition) {
|
|
|
|
case 'repeat-x':
|
|
|
|
this._tileX = CanvasKit.TileMode.Repeat;
|
|
|
|
// Skia's 'clamp' mode repeats the last row/column
|
|
|
|
// which looks very very strange.
|
|
|
|
// Decal mode does just transparent copying, which
|
|
|
|
// is exactly what the spec wants.
|
|
|
|
this._tileY = CanvasKit.TileMode.Decal;
|
|
|
|
break;
|
|
|
|
case 'repeat-y':
|
|
|
|
this._tileX = CanvasKit.TileMode.Decal;
|
|
|
|
this._tileY = CanvasKit.TileMode.Repeat;
|
|
|
|
break;
|
|
|
|
case 'repeat':
|
|
|
|
this._tileX = CanvasKit.TileMode.Repeat;
|
|
|
|
this._tileY = CanvasKit.TileMode.Repeat;
|
|
|
|
break;
|
|
|
|
case 'no-repeat':
|
|
|
|
this._tileX = CanvasKit.TileMode.Decal;
|
|
|
|
this._tileY = CanvasKit.TileMode.Decal;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
throw 'invalid repetition mode ' + repetition;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Takes a DOMMatrix like object. e.g. the identity would be:
|
|
|
|
// {a:1, b: 0, c: 0, d: 1, e: 0, f: 0}
|
|
|
|
// @param {DOMMatrix} m
|
|
|
|
this.setTransform = function(m) {
|
|
|
|
var t = [m.a, m.c, m.e,
|
|
|
|
m.b, m.d, m.f,
|
|
|
|
0, 0, 1];
|
|
|
|
if (allAreFinite(t)) {
|
|
|
|
this._transform = t;
|
|
|
|
}
|
2020-12-11 19:51:36 +00:00
|
|
|
};
|
2018-12-10 17:41:26 +00:00
|
|
|
|
|
|
|
this._copy = function() {
|
2020-12-11 19:51:36 +00:00
|
|
|
var cp = new CanvasPattern();
|
2018-12-10 17:41:26 +00:00
|
|
|
cp._tileX = this._tileX;
|
|
|
|
cp._tileY = this._tileY;
|
|
|
|
return cp;
|
2020-12-11 19:51:36 +00:00
|
|
|
};
|
2018-12-10 17:41:26 +00:00
|
|
|
|
|
|
|
this._dispose = function() {
|
|
|
|
if (this._shader) {
|
|
|
|
this._shader.delete();
|
|
|
|
this._shader = null;
|
|
|
|
}
|
2020-12-11 19:51:36 +00:00
|
|
|
};
|
2018-12-10 17:41:26 +00:00
|
|
|
|
|
|
|
this._getShader = function(currentTransform) {
|
|
|
|
// Ignore currentTransform since it will be applied later
|
|
|
|
this._dispose();
|
2020-12-11 19:51:36 +00:00
|
|
|
// A shader with cubic sampling options is high quality.
|
|
|
|
this._shader = this._image.makeShaderCubic(this._tileX, this._tileY, 1/3, 1/3, this._transform);
|
2018-12-10 17:41:26 +00:00
|
|
|
return this._shader;
|
|
|
|
}
|
|
|
|
|
2020-10-07 20:09:22 +00:00
|
|
|
}
|