Update View.

This commit is contained in:
Jonathan Puckey 2011-08-02 10:49:40 +02:00
parent ddec658653
commit 30e2ba5582

View file

@ -35,36 +35,19 @@ var View = this.View = Base.extend(/** @lends View# */{
this._index = this._scope.views.push(this) - 1; this._index = this._scope.views.push(this) - 1;
// Handle canvas argument // Handle canvas argument
var size; var size;
if (typeof canvas === 'string')
/*#*/ if (options.server) { canvas = document.getElementById(canvas);
if (canvas && canvas instanceof Canvas) { if (canvas instanceof HTMLCanvasElement) {
this._canvas = canvas;
size = Size.create(canvas.width, canvas.height);
} 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);
}
// Generate an id for this view / canvas if it does not have one
this._id = this._canvas.id;
if (this._id == null)
this._canvas.id = this._id = 'canvas-' + View._id++;
/*#*/ } // options.server
/*#*/ if (options.browser) {
if (canvas && canvas instanceof HTMLCanvasElement) {
this._canvas = canvas; this._canvas = canvas;
// If the canvas has the resize attribute, resize the it to fill the // If the canvas has the resize attribute, resize the it to fill the
// window and resize it again whenever the user resizes the window. // window and resize it again whenever the user resizes the window.
if (PaperScript.hasAttribute(canvas, 'resize')) { if (PaperScript.hasAttribute(canvas, 'resize')) {
// Subtract canvas' viewport offset from the total size, to // Subtract canvas' viewport offset from the total size, to
// stretch it in // stretch it in
var offset = DomElement.getOffset(canvas, false, true), var offset = DomElement.getOffset(canvas, true),
that = this; that = this;
size = DomElement.getViewportSize(canvas).subtract(offset); size = DomElement.getViewportBounds(canvas)
.getSize().subtract(offset);
canvas.width = size.width; canvas.width = size.width;
canvas.height = size.height; canvas.height = size.height;
DomEvent.add(window, { DomEvent.add(window, {
@ -72,11 +55,11 @@ var View = this.View = Base.extend(/** @lends View# */{
// Only update canvas offset if it's not invisible, as // Only update canvas offset if it's not invisible, as
// otherwise the offset would be wrong. // otherwise the offset would be wrong.
if (!DomElement.isInvisible(canvas)) if (!DomElement.isInvisible(canvas))
offset = DomElement.getOffset(canvas, false, true); offset = DomElement.getOffset(canvas, true);
// Set the size now, which internally calls onResize // Set the size now, which internally calls onResize
// and redraws the view // and redraws the view
that.setViewSize(DomElement.getViewportSize(canvas) that.setViewSize(DomElement.getViewportBounds(canvas)
.subtract(offset)); .getSize().subtract(offset));
} }
}); });
} else { } else {
@ -108,8 +91,6 @@ var View = this.View = Base.extend(/** @lends View# */{
this._id = this._canvas.getAttribute('id'); this._id = this._canvas.getAttribute('id');
if (this._id == null) if (this._id == null)
this._canvas.setAttribute('id', this._id = 'canvas-' + View._id++); this._canvas.setAttribute('id', this._id = 'canvas-' + View._id++);
/*#*/ } // options.browser
// Link this id to our view // Link this id to our view
View._views[this._id] = this; View._views[this._id] = this;
this._viewSize = LinkedSize.create(this, 'setViewSize', this._viewSize = LinkedSize.create(this, 'setViewSize',
@ -117,15 +98,11 @@ var View = this.View = Base.extend(/** @lends View# */{
this._context = this._canvas.getContext('2d'); this._context = this._canvas.getContext('2d');
this._matrix = new Matrix(); this._matrix = new Matrix();
this._zoom = 1; this._zoom = 1;
/*#*/ if (options.browser) {
this._events = this._createEvents(); this._events = this._createEvents();
DomEvent.add(this._canvas, this._events); DomEvent.add(this._canvas, this._events);
// Make sure the first view is focused for keyboard input straight away // Make sure the first view is focused for keyboard input straight away
if (!View._focused) if (!View._focused)
View._focused = this; View._focused = this;
/*#*/ } // options.browser
// As soon as a new view is added we need to mark the redraw as not // As soon as a new view is added we need to mark the redraw as not
// motified, so the next call loops through all the views again. // motified, so the next call loops through all the views again.
this._scope._redrawNotified = false; this._scope._redrawNotified = false;
@ -364,7 +341,6 @@ var View = this.View = Base.extend(/** @lends View# */{
delete this._onFrameCallback; delete this._onFrameCallback;
return; return;
} }
/*#*/ if (options.browser) {
var that = this, var that = this,
requested = false, requested = false,
before, before,
@ -398,81 +374,6 @@ var View = this.View = Base.extend(/** @lends View# */{
// of onFrame calls. // of onFrame calls.
if (!requested) if (!requested)
this._onFrameCallback(); this._onFrameCallback();
/*#*/ } // options.browser
},
// TODO: support exporting of jpg
exportFrames: function(param) {
/*#*/ if (options.server) {
param = Base.merge({
fps: 30,
prefix: 'frame-',
amount: 1
}, param);
if (!param.directory)
throw new Error('Missing param.directory');
var view = this,
count = 0,
fs = require('fs'),
frameDuration = 1 / param.fps,
lastTime = startTime = Date.now();
// Start exporting frames by exporting the first frame:
exportFrame(param);
// Utility function that converts a number to a string with
// x amount of padded 0 digits:
function toPaddedString(number, length) {
var str = number.toString(10);
for (var i = 0, l = length - str.length; i < l; i++) {
str = '0' + str;
}
return str;
}
function exportFrame(param) {
count++;
if (view.onFrame) {
var then = new Date();
view.onFrame({
delta: frameDuration,
time: frameDuration * count,
count: count
});
console.log(new Date() - then, ' onFrame');
}
view.draw();
var filename = param.prefix + toPaddedString(count, 6) + '.png',
uri = param.directory + '/' + filename,
out = fs.createWriteStream(uri),
stream = view._canvas.createPNGStream();
// Pipe the png stream to the write stream:
stream.pipe(out);
// When the file has been closed, export the next fame:
out.on('close', function() {
var now = Date.now();
if (param.onProgress) {
param.onProgress({
count: count,
amount: param.amount,
percentage: Math.round(count / param.amount * 10000) / 100,
time: now - startTime,
delta: now - lastTime
});
}
lastTime = now;
if (count < param.amount) {
exportFrame(param);
} else {
// Call onComplete handler when finished:
if (param.onComplete) {
param.onComplete();
}
}
});
}
/*#*/ } // options.server
}, },
/** /**
@ -493,13 +394,7 @@ var View = this.View = Base.extend(/** @lends View# */{
* @type Function * @type Function
*/ */
onResize: null onResize: null
}, {
statics: {
_views: {},
_id: 0
}
}, new function() { // Injection scope for mouse handlers }, new function() { // Injection scope for mouse handlers
/*#*/ if (options.browser) {
var tool, var tool,
timer, timer,
curPoint, curPoint,
@ -626,6 +521,8 @@ var View = this.View = Base.extend(/** @lends View# */{
}, },
statics: { statics: {
_views: {},
_id: 0,
/** /**
* Loops through all scopes and their views and sets the focus on * Loops through all scopes and their views and sets the focus on
@ -634,5 +531,4 @@ var View = this.View = Base.extend(/** @lends View# */{
updateFocus: updateFocus updateFocus: updateFocus
} }
}; };
/*#*/ } // options.browser
}); });