Always set canvas size, to avoid zooming pixels if size is set to a percentage.

This commit is contained in:
Jürg Lehni 2012-10-31 09:49:42 -07:00
parent bdb74b67e2
commit 04df1a0d4a

View file

@ -102,8 +102,6 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
that = this; that = this;
size = DomElement.getViewportBounds(element) size = DomElement.getViewportBounds(element)
.getSize().subtract(offset); .getSize().subtract(offset);
element.width = size.width;
element.height = size.height;
this._windowHandlers = { this._windowHandlers = {
resize: function(event) { resize: function(event) {
// Only update element offset if it's not invisible, as // Only update element offset if it's not invisible, as
@ -126,6 +124,11 @@ var View = this.View = Base.extend(Callback, /** @lends View# */{
parseInt(element.getAttribute('height'))) parseInt(element.getAttribute('height')))
: DomElement.getSize(element); : DomElement.getSize(element);
} }
// Set canvas size even if we just deterined the size from it, since
// it might have been set to a % size, in which case it would use some
// default internal size (300x150 on WebKit) and scale up the pixels.
element.width = size.width;
element.height = size.height;
// TODO: Test this on IE: // TODO: Test this on IE:
if (PaperScript.hasAttribute(element, 'stats')) { if (PaperScript.hasAttribute(element, 'stats')) {
this._stats = new Stats(); this._stats = new Stats();