PlacedSymbol & Raster: fix transformContent and support BlendMode.

This commit is contained in:
Jonathan Puckey 2011-02-25 19:38:55 +01:00
parent 049504a67a
commit f79e6a0454
2 changed files with 22 additions and 5 deletions

View file

@ -32,6 +32,14 @@ PlacedSymbol = Item.extend({
bounds.y = coords[1]; bounds.y = coords[1];
bounds.width = coords[2] - coords[0]; bounds.width = coords[2] - coords[0];
bounds.height = coords[3] - coords[1]; bounds.height = coords[3] - coords[1];
if (bounds.width < 0) {
bounds.x = coords[2];
bounds.width = -bounds.width;
}
if (bounds.height < 0) {
bounds.y = coords[3];
bounds.height = bounds.height;
}
}, },
getBounds: function() { getBounds: function() {
@ -39,14 +47,14 @@ PlacedSymbol = Item.extend({
}, },
draw: function(ctx, param) { draw: function(ctx, param) {
// TODO: BlendMode isn't working yet for PlacedSymbols.
if(this.blendMode != 'normal' && !param.ignoreBlendMode) { if(this.blendMode != 'normal' && !param.ignoreBlendMode) {
BlendMode.process(ctx, this, param); BlendMode.process(ctx, this, param);
} else { } else {
param.ignoreBlendMode = false;
// TODO: we need to preserve strokewidth, but still transform the fill // TODO: we need to preserve strokewidth, but still transform the fill
ctx.save(); ctx.save();
if(param.ignoreBlendMode !== true)
this.matrix.applyToContext(ctx); this.matrix.applyToContext(ctx);
param.ignoreBlendMode = false;
this.symbol.definition.draw(ctx, param); this.symbol.definition.draw(ctx, param);
ctx.restore(); ctx.restore();
} }

View file

@ -159,6 +159,14 @@ Raster = Item.extend({
bounds.y = coords[1]; bounds.y = coords[1];
bounds.width = coords[2] - coords[0]; bounds.width = coords[2] - coords[0];
bounds.height = coords[3] - coords[1]; bounds.height = coords[3] - coords[1];
if (bounds.width < 0) {
bounds.x = coords[2];
bounds.width = -bounds.width;
}
if (bounds.height < 0) {
bounds.y = coords[3];
bounds.height = bounds.height;
}
}, },
getBounds: function() { getBounds: function() {
@ -169,12 +177,13 @@ Raster = Item.extend({
if(this.blendMode != 'normal' && !param.ignoreBlendMode) { if(this.blendMode != 'normal' && !param.ignoreBlendMode) {
BlendMode.process(ctx, this, param); BlendMode.process(ctx, this, param);
} else { } else {
param.ignoreBlendMode = false;
ctx.save(); ctx.save();
if(param.ignoreBlendMode !== true)
this.matrix.applyToContext(ctx); this.matrix.applyToContext(ctx);
ctx.drawImage(this._canvas || this._image, ctx.drawImage(this._canvas || this._image,
-this.size.width / 2, -this.size.height / 2); -this.size.width / 2, -this.size.height / 2);
ctx.restore(); ctx.restore();
param.ignoreBlendMode = false;
} }
} }
}, new function() { }, new function() {