mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Remove files forgotten in recent renaming.
This commit is contained in:
parent
378952666a
commit
c30565fb7b
3 changed files with 0 additions and 516 deletions
|
@ -1,137 +0,0 @@
|
||||||
/*
|
|
||||||
* Paper.js
|
|
||||||
*
|
|
||||||
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
||||||
* based on Scriptographer.org and designed to be largely API compatible.
|
|
||||||
* http://paperjs.org/
|
|
||||||
* http://scriptographer.org/
|
|
||||||
*
|
|
||||||
* Distributed under the MIT license. See LICENSE file for details.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
||||||
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
||||||
*
|
|
||||||
* All rights reserved.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Document = this.Document = Base.extend({
|
|
||||||
beans: true,
|
|
||||||
|
|
||||||
// XXX: Add arguments to define pages, but do not pass canvas here
|
|
||||||
initialize: function(canvas) {
|
|
||||||
// Store reference to the currently active global paper scope:
|
|
||||||
this._scope = paper;
|
|
||||||
// Push it onto this._scope.documents and set index:
|
|
||||||
this._index = this._scope.documents.push(this) - 1;
|
|
||||||
// Activate straight away so paper.document is set, as required by
|
|
||||||
// Layer and DoumentView constructors.
|
|
||||||
this.activate();
|
|
||||||
this.layers = [];
|
|
||||||
this.views = [];
|
|
||||||
this.symbols = [];
|
|
||||||
this.activeLayer = new Layer();
|
|
||||||
this.activeView = canvas ? new DocumentView(canvas) : null;
|
|
||||||
this._selectedItems = {};
|
|
||||||
this._selectedItemCount = 0;
|
|
||||||
this.setCurrentStyle(null);
|
|
||||||
},
|
|
||||||
|
|
||||||
getCurrentStyle: function() {
|
|
||||||
return this._currentStyle;
|
|
||||||
},
|
|
||||||
|
|
||||||
setCurrentStyle: function(style) {
|
|
||||||
this._currentStyle = PathStyle.create(null, style);
|
|
||||||
},
|
|
||||||
|
|
||||||
activate: function() {
|
|
||||||
if (this._index != null) {
|
|
||||||
this._scope.document = this;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
|
|
||||||
remove: function() {
|
|
||||||
var res = Base.splice(this._scope.documents, null, this._index, 1);
|
|
||||||
this._scope = null;
|
|
||||||
// Remove all views. This also removes the installed event handlers.
|
|
||||||
for (var i = this.views.length - 1; i >= 0; i--)
|
|
||||||
this.views[i].remove();
|
|
||||||
return !!res.length;
|
|
||||||
},
|
|
||||||
|
|
||||||
getIndex: function() {
|
|
||||||
return this._index;
|
|
||||||
},
|
|
||||||
|
|
||||||
getSelectedItems: function() {
|
|
||||||
// TODO: return groups if their children are all selected,
|
|
||||||
// and filter out their children from the list.
|
|
||||||
// TODO: the order of these items should be that of their
|
|
||||||
// drawing order.
|
|
||||||
var items = [];
|
|
||||||
Base.each(this._selectedItems, function(item) {
|
|
||||||
items.push(item);
|
|
||||||
});
|
|
||||||
return items;
|
|
||||||
},
|
|
||||||
|
|
||||||
// TODO: implement setSelectedItems?
|
|
||||||
|
|
||||||
_selectItem: function(item, select) {
|
|
||||||
if (select) {
|
|
||||||
this._selectedItemCount++;
|
|
||||||
this._selectedItems[item.getId()] = item;
|
|
||||||
} else {
|
|
||||||
this._selectedItemCount--;
|
|
||||||
delete this._selectedItems[item.getId()];
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Selects all items in the document.
|
|
||||||
*/
|
|
||||||
selectAll: function() {
|
|
||||||
// TODO: is using for var i in good practice?
|
|
||||||
// or should we use Base.each? (JP)
|
|
||||||
for (var i = 0, l = this.layers.length; i < l; i++)
|
|
||||||
this.layers[i].setSelected(true);
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Deselects all selected items in the document.
|
|
||||||
*/
|
|
||||||
deselectAll: function() {
|
|
||||||
// TODO: is using for var i in good practice?
|
|
||||||
// or should we use Base.each? (JP)
|
|
||||||
for (var i in this._selectedItems)
|
|
||||||
this._selectedItems[i].setSelected(false);
|
|
||||||
},
|
|
||||||
|
|
||||||
draw: function(ctx) {
|
|
||||||
ctx.save();
|
|
||||||
var param = { offset: new Point(0, 0) };
|
|
||||||
for (var i = 0, l = this.layers.length; i < l; i++)
|
|
||||||
Item.draw(this.layers[i], ctx, param);
|
|
||||||
ctx.restore();
|
|
||||||
|
|
||||||
// Draw the selection of the selected items in the document:
|
|
||||||
if (this._selectedItemCount > 0) {
|
|
||||||
ctx.save();
|
|
||||||
ctx.strokeWidth = 1;
|
|
||||||
// TODO: use Layer#color
|
|
||||||
ctx.strokeStyle = ctx.fillStyle = '#009dec';
|
|
||||||
param = { selection: true };
|
|
||||||
Base.each(this._selectedItems, function(item) {
|
|
||||||
item.draw(ctx, param);
|
|
||||||
});
|
|
||||||
ctx.restore();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
redraw: function() {
|
|
||||||
for (var i = 0, l = this.views.length; i < l; i++)
|
|
||||||
this.views[i].draw();
|
|
||||||
}
|
|
||||||
});
|
|
|
@ -1,341 +0,0 @@
|
||||||
/*
|
|
||||||
* Paper.js
|
|
||||||
*
|
|
||||||
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
||||||
* based on Scriptographer.org and designed to be largely API compatible.
|
|
||||||
* http://paperjs.org/
|
|
||||||
* http://scriptographer.org/
|
|
||||||
*
|
|
||||||
* Distributed under the MIT license. See LICENSE file for details.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
||||||
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
||||||
*
|
|
||||||
* All rights reserved.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var DocumentView = this.DocumentView = Base.extend({
|
|
||||||
beans: true,
|
|
||||||
|
|
||||||
// TODO: Add bounds parameter that defines position within canvas?
|
|
||||||
// Find a good name for these bounds, since #bounds is already the artboard
|
|
||||||
// bounds of the visible area.
|
|
||||||
initialize: function(canvas) {
|
|
||||||
// To go with the convention of never passing document to constructors,
|
|
||||||
// in all items, associate the view with the currently active document.
|
|
||||||
this._document = paper.document;
|
|
||||||
this._scope = this._document._scope;
|
|
||||||
// Push it onto document.views and set index:
|
|
||||||
this._index = this._document.views.push(this) - 1;
|
|
||||||
// Handle canvas argument
|
|
||||||
var size;
|
|
||||||
if (canvas && canvas instanceof HTMLCanvasElement) {
|
|
||||||
this._canvas = canvas;
|
|
||||||
var offset = DomElement.getOffset(canvas);
|
|
||||||
// If the canvas has the resize attribute, resize the it to fill the
|
|
||||||
// window and resize it again whenever the user resizes the window.
|
|
||||||
if (canvas.attributes.resize) {
|
|
||||||
size = DomElement.getWindowSize().subtract(offset);
|
|
||||||
canvas.width = size.width;
|
|
||||||
canvas.height = size.height;
|
|
||||||
var that = this;
|
|
||||||
DomEvent.add(window, {
|
|
||||||
resize: function(event) {
|
|
||||||
// Only get canvas offset if it's not invisible (size is
|
|
||||||
// 0, 0), as otherwise the offset would be wrong.
|
|
||||||
if (!DomElement.getSize(canvas).equals([0, 0]))
|
|
||||||
offset = DomElement.getOffset(canvas);
|
|
||||||
// Set the size now, which internally calls onResize
|
|
||||||
that.setViewSize(
|
|
||||||
DomElement.getWindowSize().subtract(offset));
|
|
||||||
// If there's a _onFrameCallback, call it staight away,
|
|
||||||
// but without requesting another animation frame.
|
|
||||||
if (that._onFrameCallback) {
|
|
||||||
that._onFrameCallback(0, true);
|
|
||||||
} else {
|
|
||||||
that.draw();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
size = Size.create(canvas.offsetWidth, canvas.offsetHeight);
|
|
||||||
}
|
|
||||||
// TODO: Test this on IE:
|
|
||||||
if (canvas.attributes.stats) {
|
|
||||||
this._stats = new Stats();
|
|
||||||
// Align top-left to the canvas
|
|
||||||
var element = this._stats.domElement,
|
|
||||||
style = element.style;
|
|
||||||
style.position = 'absolute';
|
|
||||||
style.left = offset.x + 'px';
|
|
||||||
style.top = offset.y + 'px';
|
|
||||||
document.body.appendChild(element);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// 2nd argument onwards could be view size, otherwise use default:
|
|
||||||
size = Size.read(arguments, 1);
|
|
||||||
if (size.isZero())
|
|
||||||
size = new Size(1024, 768);
|
|
||||||
this._canvas = CanvasProvider.getCanvas(size);
|
|
||||||
}
|
|
||||||
this._viewBounds = LinkedRectangle.create(this, 'setViewBounds',
|
|
||||||
0, 0, size.width, size.height);
|
|
||||||
this._context = this._canvas.getContext('2d');
|
|
||||||
this._matrix = new Matrix();
|
|
||||||
this._zoom = 1;
|
|
||||||
this._events = this._createEvents();
|
|
||||||
DomEvent.add(this._canvas, this._events);
|
|
||||||
// Make sure the first view is focused for keyboard input straight away
|
|
||||||
if (!DocumentView.focused)
|
|
||||||
DocumentView.focused = this;
|
|
||||||
},
|
|
||||||
|
|
||||||
getDocument: function() {
|
|
||||||
return this._document;
|
|
||||||
},
|
|
||||||
|
|
||||||
getViewBounds: function() {
|
|
||||||
return this._viewBounds;
|
|
||||||
},
|
|
||||||
|
|
||||||
setViewBounds: function(bounds) {
|
|
||||||
bounds = Rectangle.read(arguments);
|
|
||||||
var size = bounds.getSize(),
|
|
||||||
delta = size.subtract(this._viewBounds.getSize());
|
|
||||||
// TODO: Take into acount bounds.x/y and decide on what grounds to
|
|
||||||
// change canvas size. Also, if x/y is not 0, do we need to add that
|
|
||||||
// to transform, or is that up to the user?
|
|
||||||
this._canvas.width = size.width;
|
|
||||||
this._canvas.height = size.height;
|
|
||||||
// Call onResize handler on any size change
|
|
||||||
if (this.onResize) {
|
|
||||||
this.onResize({
|
|
||||||
size: size,
|
|
||||||
delta: delta
|
|
||||||
});
|
|
||||||
}
|
|
||||||
// Force recalculation
|
|
||||||
this._bounds = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
getViewSize: function() {
|
|
||||||
return this._viewBounds.getSize();
|
|
||||||
},
|
|
||||||
|
|
||||||
setViewSize: function(size) {
|
|
||||||
this._viewBounds.setSize.apply(this._viewBounds, arguments);
|
|
||||||
},
|
|
||||||
|
|
||||||
getBounds: function() {
|
|
||||||
if (!this._bounds)
|
|
||||||
this._bounds = this._matrix._transformBounds(this._viewBounds);
|
|
||||||
return this._bounds;
|
|
||||||
},
|
|
||||||
|
|
||||||
getSize: function() {
|
|
||||||
return this.getBounds().getSize();
|
|
||||||
},
|
|
||||||
|
|
||||||
getCenter: function() {
|
|
||||||
return this.getBounds().getCenter();
|
|
||||||
},
|
|
||||||
|
|
||||||
setCenter: function(center) {
|
|
||||||
this.scrollBy(Point.read(arguments).subtract(this.getCenter()));
|
|
||||||
},
|
|
||||||
|
|
||||||
getZoom: function() {
|
|
||||||
return this._zoom;
|
|
||||||
},
|
|
||||||
|
|
||||||
setZoom: function(zoom) {
|
|
||||||
// TODO: Clamp the view between 1/32 and 64, just like Illustrator?
|
|
||||||
var mx = new Matrix();
|
|
||||||
mx.scale(zoom / this._zoom, this._center);
|
|
||||||
this.transform(mx);
|
|
||||||
this._zoom = zoom;
|
|
||||||
},
|
|
||||||
|
|
||||||
scrollBy: function(point) {
|
|
||||||
this.transform(new Matrix().translate(Point.read(arguments).negate()));
|
|
||||||
},
|
|
||||||
|
|
||||||
draw: function() {
|
|
||||||
if (this._stats)
|
|
||||||
this._stats.update();
|
|
||||||
// Initial tests conclude that clearing the canvas using clearRect
|
|
||||||
// is always faster than setting canvas.width = canvas.width
|
|
||||||
// http://jsperf.com/clearrect-vs-setting-width/7
|
|
||||||
var bounds = this._viewBounds;
|
|
||||||
this._context.clearRect(bounds._x, bounds._y,
|
|
||||||
// TODO: +1... what if we have multiple views in one canvas?
|
|
||||||
bounds._width + 1, bounds._height + 1);
|
|
||||||
this._document.draw(this._context);
|
|
||||||
},
|
|
||||||
|
|
||||||
activate: function() {
|
|
||||||
this._document.activeView = this;
|
|
||||||
},
|
|
||||||
|
|
||||||
remove: function() {
|
|
||||||
var res = Base.splice(this._document.views, null, this._index, 1);
|
|
||||||
// Uninstall event handlers again for this view.
|
|
||||||
DomEvent.remove(this._canvas, this._events);
|
|
||||||
this._document = this._scope = this._canvas = this._events = null;
|
|
||||||
// Clearing _onFrame makes the frame handler stop automatically.
|
|
||||||
this._onFrame = null;
|
|
||||||
return !!res.length;
|
|
||||||
},
|
|
||||||
|
|
||||||
transform: function(matrix, flags) {
|
|
||||||
this._matrix.preConcatenate(matrix);
|
|
||||||
// Force recalculation of these values next time they are requested.
|
|
||||||
this._bounds = null;
|
|
||||||
this._inverse = null;
|
|
||||||
},
|
|
||||||
|
|
||||||
_getInverse: function() {
|
|
||||||
if (!this._inverse)
|
|
||||||
this._inverse = this._matrix.createInverse();
|
|
||||||
return this._inverse;
|
|
||||||
},
|
|
||||||
|
|
||||||
// TODO: getInvalidBounds
|
|
||||||
// TODO: invalidate(rect)
|
|
||||||
// TODO: style: artwork / preview / raster / opaque / ink
|
|
||||||
// TODO: getShowGrid
|
|
||||||
// TODO: getMousePoint
|
|
||||||
// TODO: artworkToView(rect)
|
|
||||||
artworkToView: function(point) {
|
|
||||||
return this._matrix._transformPoint(Point.read(arguments));
|
|
||||||
},
|
|
||||||
|
|
||||||
viewToArtwork: function(point) {
|
|
||||||
return this._getInverse()._transformPoint(Point.read(arguments));
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handler to be called whenever a view gets resized.
|
|
||||||
*/
|
|
||||||
onResize: null,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Handler to be called on each frame of an animation.
|
|
||||||
*/
|
|
||||||
getOnFrame: function() {
|
|
||||||
return this._onFrame;
|
|
||||||
},
|
|
||||||
|
|
||||||
setOnFrame: function(onFrame) {
|
|
||||||
this._onFrame = onFrame;
|
|
||||||
if (!onFrame) {
|
|
||||||
delete this._onFrameCallback;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var that = this,
|
|
||||||
requested = false,
|
|
||||||
before,
|
|
||||||
time = 0,
|
|
||||||
count = 0;
|
|
||||||
this._onFrameCallback = function(param, dontRequest) {
|
|
||||||
requested = false;
|
|
||||||
if (!that._onFrame)
|
|
||||||
return;
|
|
||||||
// Set the global paper object to the current scope
|
|
||||||
paper = that._scope;
|
|
||||||
// Request next frame already
|
|
||||||
requested = true;
|
|
||||||
if (!dontRequest) {
|
|
||||||
DomEvent.requestAnimationFrame(that._onFrameCallback,
|
|
||||||
that._canvas);
|
|
||||||
}
|
|
||||||
var now = Date.now() / 1000,
|
|
||||||
delta = before ? now - before : 0;
|
|
||||||
that._onFrame({
|
|
||||||
delta: delta, // Time elapsed since last redraw in seconds
|
|
||||||
time: time += delta, // Time since first call of frame() in seconds
|
|
||||||
count: count++
|
|
||||||
});
|
|
||||||
before = now;
|
|
||||||
// Automatically draw view on each frame.
|
|
||||||
that.draw();
|
|
||||||
};
|
|
||||||
// Call the onFrame handler straight away, initializing the sequence
|
|
||||||
// of onFrame calls.
|
|
||||||
if (!requested)
|
|
||||||
this._onFrameCallback();
|
|
||||||
},
|
|
||||||
|
|
||||||
_createEvents: function() {
|
|
||||||
var that = this,
|
|
||||||
tool,
|
|
||||||
timer,
|
|
||||||
curPoint,
|
|
||||||
dragging = false;
|
|
||||||
|
|
||||||
function viewToArtwork(event) {
|
|
||||||
return that.viewToArtwork(DomEvent.getOffset(event));
|
|
||||||
}
|
|
||||||
|
|
||||||
function mousedown(event) {
|
|
||||||
// Tell the Key class which view should receive keyboard input.
|
|
||||||
DocumentView.focused = that;
|
|
||||||
if (!(tool = that._scope.tool))
|
|
||||||
return;
|
|
||||||
curPoint = viewToArtwork(event);
|
|
||||||
tool.onHandleEvent('mousedown', curPoint, event);
|
|
||||||
if (tool.onMouseDown)
|
|
||||||
that.draw();
|
|
||||||
if (tool.eventInterval != null)
|
|
||||||
timer = setInterval(mousemove, tool.eventInterval);
|
|
||||||
dragging = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
function mousemove(event) {
|
|
||||||
if (!(tool = that._scope.tool))
|
|
||||||
return;
|
|
||||||
// If the event was triggered by a touch screen device, prevent the
|
|
||||||
// default behaviour, as it will otherwise scroll the page:
|
|
||||||
if (event && event.targetTouches)
|
|
||||||
DomEvent.preventDefault(event);
|
|
||||||
var point = event && viewToArtwork(event);
|
|
||||||
var onlyMove = !!(!tool.onMouseDrag && tool.onMouseMove);
|
|
||||||
if (dragging && !onlyMove) {
|
|
||||||
curPoint = point || curPoint;
|
|
||||||
if (curPoint)
|
|
||||||
tool.onHandleEvent('mousedrag', curPoint, event);
|
|
||||||
if (tool.onMouseDrag)
|
|
||||||
that.draw();
|
|
||||||
// PORT: If there is only an onMouseMove handler, also call it when
|
|
||||||
// the user is dragging:
|
|
||||||
} else if (!dragging || onlyMove) {
|
|
||||||
tool.onHandleEvent('mousemove', point, event);
|
|
||||||
if (tool.onMouseMove)
|
|
||||||
that.draw();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function mouseup(event) {
|
|
||||||
if (!dragging)
|
|
||||||
return;
|
|
||||||
dragging = false;
|
|
||||||
curPoint = null;
|
|
||||||
if (tool) {
|
|
||||||
if (tool.eventInterval != null)
|
|
||||||
timer = clearInterval(timer);
|
|
||||||
tool.onHandleEvent('mouseup', viewToArtwork(event), event);
|
|
||||||
if (tool.onMouseUp)
|
|
||||||
that.draw();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
mousedown: mousedown,
|
|
||||||
mousemove: mousemove,
|
|
||||||
mouseup: mouseup,
|
|
||||||
touchstart: mousedown,
|
|
||||||
touchmove: mousemove,
|
|
||||||
touchend: mouseup
|
|
||||||
};
|
|
||||||
}
|
|
||||||
});
|
|
|
@ -1,38 +0,0 @@
|
||||||
/*
|
|
||||||
* Paper.js
|
|
||||||
*
|
|
||||||
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
||||||
* based on Scriptographer.org and designed to be largely API compatible.
|
|
||||||
* http://paperjs.org/
|
|
||||||
* http://scriptographer.org/
|
|
||||||
*
|
|
||||||
* Distributed under the MIT license. See LICENSE file for details.
|
|
||||||
*
|
|
||||||
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
||||||
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
||||||
*
|
|
||||||
* All rights reserved.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Symbol = this.Symbol = Base.extend({
|
|
||||||
beans: true,
|
|
||||||
|
|
||||||
initialize: function(item) {
|
|
||||||
this.document = paper.document;
|
|
||||||
this.document.symbols.push(this);
|
|
||||||
this.setDefinition(item);
|
|
||||||
},
|
|
||||||
|
|
||||||
getDefinition: function() {
|
|
||||||
return this._definition;
|
|
||||||
},
|
|
||||||
|
|
||||||
setDefinition: function(item) {
|
|
||||||
this._definition = item;
|
|
||||||
item._removeFromParent();
|
|
||||||
item.setPosition(new Point());
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO:
|
|
||||||
// remove()
|
|
||||||
});
|
|
Loading…
Reference in a new issue