paper.js/src/util/CanvasProvider.js

56 lines
1.6 KiB
JavaScript
Raw Normal View History

2011-03-06 19:50:44 -05:00
/*
* Paper.js
*
2011-03-06 19:50:44 -05:00
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
* based on Scriptographer.org and designed to be largely API compatible.
2011-03-07 20:41:50 -05:00
* http://paperjs.org/
2011-03-06 19:50:44 -05:00
* http://scriptographer.org/
*
2011-03-07 20:41:50 -05:00
* Distributed under the MIT license. See LICENSE file for details.
*
2011-03-06 19:50:44 -05:00
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
* http://lehni.org/ & http://jonathanpuckey.com/
*
2011-03-07 20:41:50 -05:00
* All rights reserved.
2011-03-06 19:50:44 -05:00
*/
2011-06-01 05:49:43 -04:00
// TODO: It might be better to make a ContextProvider class, since you
// can always find the canvas through context.canvas. This saves code and
2011-02-26 09:29:51 -05:00
// speed by not having to do canvas.getContext('2d')
// TODO: Run through the canvas array to find a canvas with the requested
// width / height, so we don't need to resize it?
var CanvasProvider = {
canvases: [],
getCanvas: function(size) {
2011-02-28 12:30:08 -05:00
if (this.canvases.length) {
2011-02-26 09:29:51 -05:00
var canvas = this.canvases.pop();
// If they are not the same size, we don't need to clear them
// using clearRect and visa versa.
if ((canvas.width != size.width)
|| (canvas.height != size.height)) {
2011-02-26 09:29:51 -05:00
canvas.width = size.width;
canvas.height = size.height;
} else {
// +1 is needed on some browsers to really clear the borders
canvas.getContext('2d').clearRect(0, 0,
size.width + 1, size.height + 1);
2011-02-26 09:29:51 -05:00
}
return canvas;
} else {
//#ifdef BROWSER
2011-02-26 09:29:51 -05:00
var canvas = document.createElement('canvas');
canvas.width = size.width;
canvas.height = size.height;
return canvas;
//#else // !BROWSER
// Only rhino-canvas for now:
return new Image(size.width, size.height);
//#endif // !BROWSER
2011-02-26 09:29:51 -05:00
}
},
returnCanvas: function(canvas) {
this.canvases.push(canvas);
}
};