Implement loading Rasters from external sources and notify using a 'load' callback.

This commit is contained in:
Jürg Lehni 2012-11-21 10:39:26 -08:00
parent 1e744e3db7
commit 373474d088
3 changed files with 37 additions and 4 deletions

View file

@ -7,7 +7,13 @@
<script type="text/javascript" src="../../dist/paper.js"></script> <script type="text/javascript" src="../../dist/paper.js"></script>
<script type="text/paperscript" canvas="canvas"> <script type="text/paperscript" canvas="canvas">
// http://en.wikipedia.org/wiki/Lenna // http://en.wikipedia.org/wiki/Lenna
var raster = new Raster('lenna'); // Load from Server:
var raster = new Raster('http://upload.wikimedia.org/wikipedia/zh/3/34/Lenna.jpg');
// Load from DOM image:
// var raster = new Raster('lenna');
raster.onLoad = function() {
console.log('Successfully loaded image!');
};
var lastScale = 1; var lastScale = 1;
var center = view.center; var center = view.center;
function onFrame(event) { function onFrame(event) {

View file

@ -97,7 +97,10 @@ var Item = this.Item = Base.extend(Callback, /** @lends Item# */{
if (!onFrameItems.length) if (!onFrameItems.length)
this._project.view.detach('frame', onFrame); this._project.view.detach('frame', onFrame);
} }
} },
// Only for external sources, e.g. Raster
onLoad: {}
}); });
}, },

View file

@ -42,8 +42,32 @@ var Raster = this.Raster = PlacedItem.extend(/** @lends Raster# */{
} else { } else {
/*#*/ if (options.browser) { /*#*/ if (options.browser) {
// If it's a string, get the element with this id first. // If it's a string, get the element with this id first.
if (typeof object === 'string') if (typeof object === 'string') {
object = document.getElementById(object); var str = object,
that = this;
object = document.getElementById(str);
if (!object) {
// str could be a URL to load the image from?
object = new Image();
object.src = str;
}
// Trigger the onLoad event on the image once it's loaded
DomEvent.add(object, {
load: function() {
that.setImage(object);
that.fire('load');
}
});
// If the image is already loaded, fire a 'load' event anyway,
// so code does not need to make the distinction, and cachig is
// transparently handled too.
if (object.naturalWidth) {
setTimeout(function() {
that.fire('load');
}, 0);
}
}
/*#*/ } else if (options.server) { /*#*/ } else if (options.server) {
// If we're running on the server and it's a string, // If we're running on the server and it's a string,
// load it from disk: // load it from disk: