More work on Path#draw().

This commit is contained in:
Jürg Lehni 2011-06-04 15:28:06 +01:00
parent 45a04891ee
commit e5290c3f47
3 changed files with 60 additions and 54 deletions

View file

@ -104,6 +104,7 @@ var Group = this.Group = Item.extend({
draw: function(ctx, param) {
for (var i = 0, l = this._children.length; i < l; i++) {
Item.draw(this._children[i], ctx, param);
// TODO: Shouldn't clipping paths not be filled / stroked?
if (this._clipped && i == 0)
ctx.clip();
}

View file

@ -246,10 +246,8 @@ var Raster = this.Raster = Item.extend({
ctx.scale(width / bounds.width, height / bounds.height);
ctx.translate(-bounds.x, -bounds.y);
// If a path was passed, draw it as a clipping mask:
if (path) {
path.draw(ctx, { ignoreStyle: true });
ctx.clip();
}
if (path)
path.draw(ctx, { clip: true });
// Now draw the image clipped into it.
this.matrix.applyToContext(ctx);
ctx.drawImage(this._canvas || this._image,

View file

@ -716,12 +716,8 @@ var Path = this.Path = PathItem.extend({
}
}
return {
draw: function(ctx, param) {
if (!param.compound)
ctx.beginPath();
var segments = this._segments,
length = segments.length,
function drawSegments(ctx, segments) {
var length = segments.length,
handleOut, outX, outY;
function drawSegment(i) {
@ -750,20 +746,32 @@ var Path = this.Path = PathItem.extend({
// Close path by drawing first segment again
if (this._closed && length > 1)
drawSegment(0);
}
return {
draw: function(ctx, param) {
if (!param.compound)
ctx.beginPath();
var fillColor = this.getFillColor(),
strokeColor = this.getStrokeColor();
if (param.compound || param.selection || param.clip || fillColor || strokeColor) {
drawSegments(ctx, this._segments);
}
// If we are drawing the selection of a path, stroke it and draw
// its handles:
if (param.selection) {
ctx.stroke();
drawHandles(ctx, this._segments);
} else if (!param.ignoreStyle) {
} else if (param.clip) {
ctx.clip();
} else if (!param.compound && (fillColor || strokeColor)) {
// If the path is part of a compound path or doesn't have a fill
// or stroke, there is no need to continue.
var fillColor = this.getFillColor(),
strokeColor = this.getStrokeColor();
if (!param.compound && (fillColor || strokeColor)) {
this._setStyles(ctx);
ctx.save();
this._setStyles(ctx);
// If the path only defines a strokeColor or a fillColor,
// draw it directly with the globalAlpha set, otherwise
// we will do it later when we composite the temporary
@ -781,7 +789,6 @@ var Path = this.Path = PathItem.extend({
ctx.restore();
}
}
}
};
}, new function() { // Inject methods that require scoped privates