Rename Paper to paper, implement it as an object literal and add paper.populate() and paper.install() methods that do the bootstraping.

This commit is contained in:
Jürg Lehni 2011-03-03 16:21:17 +00:00
parent 6923e168ab
commit d088dc629e
10 changed files with 42 additions and 32 deletions

View file

@ -58,7 +58,7 @@
} }
}); });
var children = Paper.document.activeLayer.children; var children = paper.document.activeLayer.children;
var count = 0; var count = 0;
function draw() { function draw() {
count++; count++;

View file

@ -1,10 +0,0 @@
var Paper = Base.extend({
statics: {
documents: [],
activateDocument: function(doc) {
var index = this.documents.indexOf(doc);
if (index != -1)
this.document = this.documents[index];
}
}
});

View file

@ -1,6 +1,6 @@
(function(scope) { (function(scope) {
#include "Paper.js" #include "paper.js"
#include "basic/Point.js" #include "basic/Point.js"
#include "basic/Size.js" #include "basic/Size.js"
@ -36,15 +36,7 @@
#include "tool/ToolHandler.js" #include "tool/ToolHandler.js"
#include "tool/Tool.js" #include "tool/Tool.js"
// Now inject all these local prototypes into the paper scope. paper.populate();
Base.each(['Point', 'Size', 'Rectangle', 'Matrix', 'DocumentView', 'Doc', paper.install(scope);
'Symbol', 'Item', 'Group', 'Layer', 'Raster', 'PlacedSymbol', 'PathStyle',
'Segment', 'Curve', 'PathItem', 'Path', 'CompoundPath', 'Color', 'RGBColor',
'GrayColor', 'GradientColor', 'Gradient', 'GradientStop', 'ToolEvent',
'ToolHandler', 'Tool'],
function(name) {
scope[name] = eval(name);
}
);
})(this); })(this);

View file

@ -13,7 +13,7 @@ var Doc = Base.extend({
} }
this.bounds = new Rectangle(new Point(0, 0), this.size); this.bounds = new Rectangle(new Point(0, 0), this.size);
this.ctx = this.canvas.getContext('2d'); this.ctx = this.canvas.getContext('2d');
Paper.documents.push(this); paper.documents.push(this);
this.activate(); this.activate();
this.layers = []; this.layers = [];
this.activeLayer = new Layer(); this.activeLayer = new Layer();
@ -32,7 +32,12 @@ var Doc = Base.extend({
}, },
activate: function() { activate: function() {
Paper.activateDocument(this); var index = paper.documents.indexOf(this);
if (index != -1) {
paper.document = this;
return true;
}
return false;
}, },
draw: function() { draw: function() {

View file

@ -2,7 +2,7 @@ var Symbol = Base.extend({
beans: true, beans: true,
initialize: function(item) { initialize: function(item) {
this.document = Paper.document; this.document = paper.document;
this.document.symbols.push(this); this.document.symbols.push(this);
this.definition = item; this.definition = item;
}, },

View file

@ -2,7 +2,7 @@ var Item = Base.extend({
beans: true, beans: true,
initialize: function() { initialize: function() {
Paper.document.activeLayer.appendTop(this); paper.document.activeLayer.appendTop(this);
this.style = this.document.currentStyle; this.style = this.document.currentStyle;
}, },

View file

@ -3,7 +3,7 @@ var Layer = Group.extend({
initialize: function() { initialize: function() {
this.children = []; this.children = [];
this.document = Paper.document; this.document = paper.document;
this.document.layers.push(this); this.document.layers.push(this);
this.activate(); this.activate();
}, },

23
src/paper.js Normal file
View file

@ -0,0 +1,23 @@
var paper = {
document: null,
documents: [],
populate: function() {
// Inject all prototypes from the paper scope into the paper object.
Base.each(['Point', 'Size', 'Rectangle', 'Matrix', 'DocumentView',
'Doc', 'Symbol', 'Item', 'Group', 'Layer', 'Raster', 'PlacedSymbol',
'PathStyle', 'Segment', 'Curve', 'PathItem', 'Path', 'CompoundPath',
'Color', 'RGBColor', 'GrayColor', 'GradientColor', 'Gradient',
'GradientStop', 'ToolEvent', 'ToolHandler', 'Tool'],
function(name) {
paper[name] = eval(name);
}
);
},
install: function(scope) {
for (var i in paper) {
scope[i] = paper[i];
}
}
};

View file

@ -10,14 +10,14 @@ var Tool = ToolHandler.extend(new function() {
initialize: function(handlers, doc) { initialize: function(handlers, doc) {
this.base(handlers); this.base(handlers);
if (Paper.document) if (paper.document)
this.document = Paper.document; this.document = paper.document;
}, },
setDocument: function(doc) { setDocument: function(doc) {
if (this._document) if (this._document)
$(this._document.canvas).removeEvents(); $(this._document.canvas).removeEvents();
this._document = doc || Paper.document; this._document = doc || paper.document;
var that = this, curPoint; var that = this, curPoint;
var dragging = false; var dragging = false;
var events = { var events = {

View file

@ -112,9 +112,9 @@ test('isGroupedWith', function() {
equals(secondGroup.isDescendant(path), false); equals(secondGroup.isDescendant(path), false);
equals(secondGroup.isDescendant(secondGroup), false); equals(secondGroup.isDescendant(secondGroup), false);
equals(path.isGroupedWith(secondGroup), false); equals(path.isGroupedWith(secondGroup), false);
Paper.document.activeLayer.appendTop(path); paper.document.activeLayer.appendTop(path);
equals(path.isGroupedWith(secondPath), false); equals(path.isGroupedWith(secondPath), false);
Paper.document.activeLayer.appendTop(secondPath); paper.document.activeLayer.appendTop(secondPath);
equals(path.isGroupedWith(secondPath), false); equals(path.isGroupedWith(secondPath), false);
}); });