mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
We cannot cache #strokeBounds when #strokeScaling is false.
Closes #697
This commit is contained in:
parent
a02d7248c0
commit
a71c364594
1 changed files with 17 additions and 11 deletions
|
@ -794,7 +794,10 @@ new function() { // // Scope to inject various item event handlers
|
||||||
// cache gets messed up.
|
// cache gets messed up.
|
||||||
var getter = 'get' + Base.capitalize(key),
|
var getter = 'get' + Base.capitalize(key),
|
||||||
match = key.match(/^internal(.*)$/),
|
match = key.match(/^internal(.*)$/),
|
||||||
internal = match ? 'get' + match[1] : null;
|
internal = match ? 'get' + match[1] : null,
|
||||||
|
// Determine if the stroke is involved in the calculation of the
|
||||||
|
// bounds: strokeBounds, roughBounds,internalRoughBounds
|
||||||
|
stroke = /^stroke|rough/i.test(key);
|
||||||
this[getter] = function(_matrix) {
|
this[getter] = function(_matrix) {
|
||||||
// TODO: If we're getting stroke based bounds (strokeBounds,
|
// TODO: If we're getting stroke based bounds (strokeBounds,
|
||||||
// roughBounds, internalRoughBounds), and the object does not have
|
// roughBounds, internalRoughBounds), and the object does not have
|
||||||
|
@ -809,7 +812,15 @@ new function() { // // Scope to inject various item event handlers
|
||||||
name = !internal && (typeof boundsGetter === 'string'
|
name = !internal && (typeof boundsGetter === 'string'
|
||||||
? boundsGetter : boundsGetter && boundsGetter[getter])
|
? boundsGetter : boundsGetter && boundsGetter[getter])
|
||||||
|| getter,
|
|| getter,
|
||||||
bounds = this._getCachedBounds(name, _matrix, this, internal);
|
// We can only cache the bounds if the path uses stroke-scaling,
|
||||||
|
// or if no stroke is involved in the calculation of the bounds.
|
||||||
|
// When strokeScaling is false, the bounds are affected by the
|
||||||
|
// zoom level of the view, hence we can't cache.
|
||||||
|
canCache = !stroke || this.getStrokeScaling(),
|
||||||
|
// If we're caching bounds, pass on this item as cacheItem, so
|
||||||
|
// the children can setup _boundsCache structures for it.
|
||||||
|
bounds = this._getCachedBounds(name, _matrix, canCache && this,
|
||||||
|
internal);
|
||||||
// If we're returning 'bounds', create a LinkedRectangle that uses
|
// If we're returning 'bounds', create a LinkedRectangle that uses
|
||||||
// the setBounds() setter to update the Item whenever the bounds are
|
// the setBounds() setter to update the Item whenever the bounds are
|
||||||
// changed:
|
// changed:
|
||||||
|
@ -839,9 +850,9 @@ new function() { // // Scope to inject various item event handlers
|
||||||
// Scriptographer behaves weirdly then too.
|
// Scriptographer behaves weirdly then too.
|
||||||
if (!children || children.length === 0)
|
if (!children || children.length === 0)
|
||||||
return new Rectangle();
|
return new Rectangle();
|
||||||
// Call _updateBoundsCache() even when the group is currently empty
|
// Call _updateBoundsCache() even when the group only holds empty /
|
||||||
// (or only holds empty / invisible items), so future changes in these
|
// invisible items), so future changes in these items will cause right
|
||||||
// items will cause right handling of _boundsCache.
|
// handling of _boundsCache.
|
||||||
Item._updateBoundsCache(this, cacheItem);
|
Item._updateBoundsCache(this, cacheItem);
|
||||||
var x1 = Infinity,
|
var x1 = Infinity,
|
||||||
x2 = -x1,
|
x2 = -x1,
|
||||||
|
@ -896,17 +907,12 @@ new function() { // // Scope to inject various item event handlers
|
||||||
matrix = matrix && matrix._orNullIfIdentity();
|
matrix = matrix && matrix._orNullIfIdentity();
|
||||||
// Do not transform by the internal matrix if there is a internal getter
|
// Do not transform by the internal matrix if there is a internal getter
|
||||||
var _matrix = internal ? null : this._matrix._orNullIfIdentity(),
|
var _matrix = internal ? null : this._matrix._orNullIfIdentity(),
|
||||||
cache = (!matrix || matrix.equals(_matrix)) && getter;
|
cache = cacheItem && (!matrix || matrix.equals(_matrix)) && getter;
|
||||||
// NOTE: This needs to happen before returning cached values, since even
|
// NOTE: This needs to happen before returning cached values, since even
|
||||||
// then, _boundsCache needs to be kept up-to-date.
|
// then, _boundsCache needs to be kept up-to-date.
|
||||||
Item._updateBoundsCache(this._parent || this._parentSymbol, cacheItem);
|
Item._updateBoundsCache(this._parent || this._parentSymbol, cacheItem);
|
||||||
if (cache && this._bounds && this._bounds[cache])
|
if (cache && this._bounds && this._bounds[cache])
|
||||||
return this._bounds[cache].clone();
|
return this._bounds[cache].clone();
|
||||||
// If we're caching bounds on this item, pass it on as cacheItem, so the
|
|
||||||
// children can setup the _boundsCache structures for it.
|
|
||||||
// getInternalBounds is getBounds untransformed. Do not replace earlier,
|
|
||||||
// so we can cache both separately, since they're not in the same
|
|
||||||
// transformation space!
|
|
||||||
var bounds = this._getBounds(internal || getter, matrix || _matrix,
|
var bounds = this._getBounds(internal || getter, matrix || _matrix,
|
||||||
cacheItem, internal);
|
cacheItem, internal);
|
||||||
// If we can cache the result, update the _bounds cache structure
|
// If we can cache the result, update the _bounds cache structure
|
||||||
|
|
Loading…
Reference in a new issue