mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
More work on Path#draw().
This commit is contained in:
parent
45a04891ee
commit
e5290c3f47
3 changed files with 60 additions and 54 deletions
|
@ -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();
|
||||
}
|
||||
|
|
|
@ -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,
|
||||
|
|
|
@ -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
|
||||
|
||||
|
|
Loading…
Reference in a new issue