mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
Allow new Raster(size)
constructor
This commit is contained in:
parent
fcfebdc43b
commit
e436d44f14
1 changed files with 26 additions and 8 deletions
|
@ -81,22 +81,40 @@ var Raster = Item.extend(/** @lends Raster# */{
|
||||||
* raster.scale(0.5);
|
* raster.scale(0.5);
|
||||||
* raster.rotate(10);
|
* raster.rotate(10);
|
||||||
*/
|
*/
|
||||||
initialize: function Raster(object, position) {
|
initialize: function Raster(source, position) {
|
||||||
// Support two forms of item initialization: Passing one object literal
|
// Support two forms of item initialization: Passing one object literal
|
||||||
// describing all the different properties to be set, or an image
|
// describing all the different properties to be set, or an image
|
||||||
// (object) and a point where it should be placed (point).
|
// (object) and a point where it should be placed (point).
|
||||||
// If _initialize can set properties through object literal, we're done.
|
// If _initialize can set properties through object literal, we're done.
|
||||||
// Otherwise we need to check the type of object:
|
// Otherwise we need to check the type of object:
|
||||||
if (!this._initialize(object,
|
|
||||||
position !== undefined && Point.read(arguments, 1))) {
|
// source can be an image, canvas, source URL or DOM-ID:
|
||||||
// object can be an image, canvas, URL or DOM-ID:
|
var image,
|
||||||
var image = typeof object === 'string'
|
type = typeof source,
|
||||||
? document.getElementById(object) : object;
|
object = type === 'string'
|
||||||
|
? document.getElementById(source)
|
||||||
|
: type === 'object'
|
||||||
|
? source
|
||||||
|
: null;
|
||||||
|
if (object && object !== Item.NO_INSERT) {
|
||||||
|
// #setImage() handles both canvas and image types.
|
||||||
|
if (object.getContent || object.naturalHeight != null) {
|
||||||
|
image = object;
|
||||||
|
} else if (object) {
|
||||||
|
// See if the arguments describe the raster size:
|
||||||
|
var size = Size.read(arguments);
|
||||||
|
if (!size.isZero()) {
|
||||||
|
image = CanvasProvider.getCanvas(size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this._initialize(source,
|
||||||
|
position !== undefined && Point.read(arguments))) {
|
||||||
if (image) {
|
if (image) {
|
||||||
// #setImage() handles both canvas and image types.
|
|
||||||
this.setImage(image);
|
this.setImage(image);
|
||||||
} else {
|
} else {
|
||||||
this.setSource(object);
|
this.setSource(source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!this._size) {
|
if (!this._size) {
|
||||||
|
|
Loading…
Reference in a new issue