mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
Implement loading Rasters from external sources and notify using a 'load' callback.
This commit is contained in:
parent
1e744e3db7
commit
373474d088
3 changed files with 37 additions and 4 deletions
|
@ -7,7 +7,13 @@
|
|||
<script type="text/javascript" src="../../dist/paper.js"></script>
|
||||
<script type="text/paperscript" canvas="canvas">
|
||||
// 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 center = view.center;
|
||||
function onFrame(event) {
|
||||
|
|
|
@ -97,7 +97,10 @@ var Item = this.Item = Base.extend(Callback, /** @lends Item# */{
|
|||
if (!onFrameItems.length)
|
||||
this._project.view.detach('frame', onFrame);
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
// Only for external sources, e.g. Raster
|
||||
onLoad: {}
|
||||
});
|
||||
},
|
||||
|
||||
|
|
|
@ -42,8 +42,32 @@ var Raster = this.Raster = PlacedItem.extend(/** @lends Raster# */{
|
|||
} else {
|
||||
/*#*/ if (options.browser) {
|
||||
// If it's a string, get the element with this id first.
|
||||
if (typeof object === 'string')
|
||||
object = document.getElementById(object);
|
||||
if (typeof object === 'string') {
|
||||
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) {
|
||||
// If we're running on the server and it's a string,
|
||||
// load it from disk:
|
||||
|
|
Loading…
Reference in a new issue