mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 06:00:56 -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/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) {
|
||||||
|
|
|
@ -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: {}
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue