fix bugs in Image module
This commit is contained in:
parent
20b3508f86
commit
9434c60b53
1 changed files with 30 additions and 22 deletions
|
@ -9,12 +9,15 @@ Ox.load.Image = function(options, callback) {
|
||||||
To render the image as an image element, use its `src()` method, to
|
To render the image as an image element, use its `src()` method, to
|
||||||
render it as a canvas, use its `canvas` property.
|
render it as a canvas, use its `canvas` property.
|
||||||
(src, callback) -> <u> undefined
|
(src, callback) -> <u> undefined
|
||||||
(width, height, callback) -> <u> undefined
|
(width, height[, background], callback) -> <u> undefined
|
||||||
(width, height, background, callback) -> <u> undefined
|
|
||||||
src <s> Image source (local, remote or data URL)
|
src <s> Image source (local, remote or data URL)
|
||||||
width <n> Width in px
|
width <n> Width in px
|
||||||
image <n> Height in px
|
height <n> Height in px
|
||||||
background <[n]> Background color (RGB or RGBA)
|
background <[n]> Background color (RGB or RGBA)
|
||||||
|
callback <f> Callback function
|
||||||
|
image <o> Image object
|
||||||
|
> Ox.Image(1, 1, [255, 0, 0], function(i) { Ox.test(i.pixel([0, 0]), [255, 0, 0, 255]); })
|
||||||
|
undefined
|
||||||
> Ox.Image(Ox.UI.PATH + 'themes/classic/png/icon16.png', function(i) { i.encode('foo', function(i) { i.decode(function(s) { Ox.test(s, 'foo'); })})})
|
> Ox.Image(Ox.UI.PATH + 'themes/classic/png/icon16.png', function(i) { i.encode('foo', function(i) { i.decode(function(s) { Ox.test(s, 'foo'); })})})
|
||||||
undefined
|
undefined
|
||||||
@*/
|
@*/
|
||||||
|
@ -23,20 +26,6 @@ Ox.load.Image = function(options, callback) {
|
||||||
var self = {},
|
var self = {},
|
||||||
that = {};
|
that = {};
|
||||||
|
|
||||||
self.callback = arguments[arguments.length - 1];
|
|
||||||
if (arguments.length == 2) {
|
|
||||||
self.src = arguments[0];
|
|
||||||
self.image = new Image();
|
|
||||||
self.image.onload = init;
|
|
||||||
self.image.src = self.src;
|
|
||||||
} else {
|
|
||||||
self.width = arguments[0];
|
|
||||||
self.height = arguments[1];
|
|
||||||
self.background = arguments.length == 4
|
|
||||||
? arguments[2] : [0, 0, 0, 0];
|
|
||||||
init();
|
|
||||||
}
|
|
||||||
|
|
||||||
function error(mode) {
|
function error(mode) {
|
||||||
throw new RangeError('PNG codec can\'t ' + mode + ' ' + (
|
throw new RangeError('PNG codec can\'t ' + mode + ' ' + (
|
||||||
mode == 'encode' ? 'data' : 'image'
|
mode == 'encode' ? 'data' : 'image'
|
||||||
|
@ -75,8 +64,11 @@ Ox.load.Image = function(options, callback) {
|
||||||
that.context = that.canvas[0].getContext('2d');
|
that.context = that.canvas[0].getContext('2d');
|
||||||
if (self.image) {
|
if (self.image) {
|
||||||
that.context.drawImage(self.image, 0, 0);
|
that.context.drawImage(self.image, 0, 0);
|
||||||
} else if (Ox.sum(self.background)) {
|
} else if (!Ox.isEqual(self.background, [0, 0, 0, 0])) {
|
||||||
that.context.fillStyle(self.background);
|
that.context.fillStyle = (
|
||||||
|
self.background.length == 3 ? 'rgb' : 'rgba'
|
||||||
|
) + '(' + self.background.join(', ') + ')';
|
||||||
|
Ox.print('----------------------------------', self.width, self.height, that.context.fillStyle)
|
||||||
that.context.fillRect(0, 0, self.width, self.height);
|
that.context.fillRect(0, 0, self.width, self.height);
|
||||||
}
|
}
|
||||||
self.imageData = that.context.getImageData(
|
self.imageData = that.context.getImageData(
|
||||||
|
@ -128,6 +120,8 @@ Ox.load.Image = function(options, callback) {
|
||||||
return that.filter(filter);
|
return that.filter(filter);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//@ canvas <o> Canvas element
|
||||||
|
|
||||||
/*@
|
/*@
|
||||||
channel <f> Reduce the image to one channel
|
channel <f> Reduce the image to one channel
|
||||||
(channel) -> <o> The image object
|
(channel) -> <o> The image object
|
||||||
|
@ -790,6 +784,20 @@ Ox.load.Image = function(options, callback) {
|
||||||
return ret;
|
return ret;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
self.callback = arguments[arguments.length - 1];
|
||||||
|
if (arguments.length == 2) {
|
||||||
|
self.src = arguments[0];
|
||||||
|
self.image = new Image();
|
||||||
|
self.image.onload = init;
|
||||||
|
self.image.src = self.src;
|
||||||
|
} else {
|
||||||
|
self.width = arguments[0];
|
||||||
|
self.height = arguments[1];
|
||||||
|
self.background = arguments.length == 4
|
||||||
|
? arguments[2] : [0, 0, 0, 0];
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
callback(true);
|
callback(true);
|
||||||
|
|
Loading…
Reference in a new issue