mirror of
https://github.com/konvajs/konva.git
synced 2025-04-05 20:48:28 +08:00
new method to
for tweening nodes
This commit is contained in:
parent
31755b298c
commit
ff983ea8c0
@ -20,6 +20,7 @@ This project adheres to [Semantic Versioning](http://semver.org/).
|
|||||||
- new `perfectDrawEnabled` property for shape. See [http://konvajs.github.io/docs/performance/Disable_Perfect_Draw.html](http://konvajs.github.io/docs/performance/Disable_Perfect_Draw.html)
|
- new `perfectDrawEnabled` property for shape. See [http://konvajs.github.io/docs/performance/Disable_Perfect_Draw.html](http://konvajs.github.io/docs/performance/Disable_Perfect_Draw.html)
|
||||||
- new `shadowForStrokeEnabled` property for shape. See [http://konvajs.github.io/docs/performance/All_Performance_Tips.html](http://konvajs.github.io/docs/performance/All_Performance_Tips.html)
|
- new `shadowForStrokeEnabled` property for shape. See [http://konvajs.github.io/docs/performance/All_Performance_Tips.html](http://konvajs.github.io/docs/performance/All_Performance_Tips.html)
|
||||||
- new `getClientRect` method.
|
- new `getClientRect` method.
|
||||||
|
- new `to` method for every nodes for shorter tweening
|
||||||
|
|
||||||
## [0.8.0] - 2015-02-04
|
## [0.8.0] - 2015-02-04
|
||||||
|
|
||||||
|
24
src/Tween.js
24
src/Tween.js
@ -272,6 +272,30 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tween node properties. Shorter usage of {@link Konva.Tween} object.
|
||||||
|
*
|
||||||
|
* @method Konva.Node#to
|
||||||
|
* @memberof Konva.Node
|
||||||
|
* @param {Object} [params] tween params
|
||||||
|
* @example
|
||||||
|
*
|
||||||
|
* circle.to({
|
||||||
|
* x : 50,
|
||||||
|
* duration : 0.5
|
||||||
|
* });
|
||||||
|
*/
|
||||||
|
Konva.Node.prototype.to = function(params) {
|
||||||
|
var onFinish = params.onFinish;
|
||||||
|
params.node = this;
|
||||||
|
params.onFinish = function() {
|
||||||
|
tween.destroy();
|
||||||
|
onFinish();
|
||||||
|
};
|
||||||
|
var tween = new Konva.Tween(params);
|
||||||
|
tween.play();
|
||||||
|
};
|
||||||
|
|
||||||
var Tween = function(prop, propFunc, func, begin, finish, duration, yoyo) {
|
var Tween = function(prop, propFunc, func, begin, finish, duration, yoyo) {
|
||||||
this.prop = prop;
|
this.prop = prop;
|
||||||
this.propFunc = propFunc;
|
this.propFunc = propFunc;
|
||||||
|
@ -170,5 +170,32 @@ suite('Tween', function() {
|
|||||||
tween.play();
|
tween.play();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('transitionTo method', function(done) {
|
||||||
|
var stage = addStage();
|
||||||
|
|
||||||
});
|
var layer = new Konva.Layer();
|
||||||
|
|
||||||
|
var circle = new Konva.Circle({
|
||||||
|
radius: 70,
|
||||||
|
fill: 'red',
|
||||||
|
stroke: 'blue',
|
||||||
|
strokeWidth: 4
|
||||||
|
});
|
||||||
|
|
||||||
|
layer.add(circle);
|
||||||
|
stage.add(layer);
|
||||||
|
|
||||||
|
circle.to({
|
||||||
|
x: stage.width() / 2,
|
||||||
|
y: stage.getHeight() / 2,
|
||||||
|
duration : 0.1,
|
||||||
|
onFinish : function() {
|
||||||
|
assert.equal(circle.x(), stage.width() / 2);
|
||||||
|
assert.equal(Object.keys(Konva.Tween.attrs[circle._id]).length, 0);
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user