BonsaiJS 简短的快速入门 API 文档
这是一篇简短的 BonsaiJS 快速入门 API 文档,旨在帮助使用 BonsaiJS 的开发这快速查询手册,这里并没有完整的列出所有 API 的方法,以及他们的使用方法和示例。
APIs To Use In Your Movie
Movie Controls
Stop and play a movie
movie.play();
movie.stop();
movie.pause();
Control movie timeline
movie.goto(2); // Goto frame 2
movie.goto('10s'); // Goto 10 seconds after start
Stage
Set background color
stage.setBackgroundColor('red');
Set Framerate of the movie (frames per second)
stage.setFramerate(30);
Freeze and unfreeze the movie
stage.freeze();
stage.unfreeze();
Draw a Path
Create a new shape with a specified path. (still invisible)
shape = new Path();
shape.moveTo(0, 0).lineTo(100, 0);
shape.addTo(stage);
Use SVG-like paths to create the same shape. (visible)
shape = new Path('M0,0 l100,0');
shape.attr({strokeWidth:1, strokeColor:'red'});
shape.addTo(stage);
Draw a rectangle
Overview
new Rect(x, y, width, height, cornerRadius)
Draw a rectangle, at 0x0 of size 100x100 (still invisible)
new Rect(0, 0, 100, 100).addTo(stage);
Rectangle, with rounded corners of radius 5px (still invisible)
new Rect(0, 0, 100, 100, 5).addTo(stage);
Red rectangle with green border, 10px wide (visible)
new Rect(0, 0, 100, 100)
.attr({ fillColor:'red', strokeWidth:10, strokeColor:'green' })
.addTo(stage);
Rectangle with 1px borders of color 0xFFAABB, no fill color
new Rect(0, 0, 100, 100)
.attr({ strokeWidth:1, strokeColor:0xFFAABB})
.addTo(stage);
Half opaque rectangle of color rgba(100,100,255,0.5)
new Rect(0, 0, 100, 100)
.attr('fillColor', 'rgba(100,100,255,.5)')
.addTo(stage);
Draw a circle
Overview
new Circle(x, y, radius)
Draw a circle at {200,200} with radius 100px (no fill, invisible)
new Circle(200, 200, 100).addTo(stage);
Draw a circle filled with red
new Circle(200,200,100)
.attr({fillColor:'red'})
.addTo(stage);
Draw an ellipse
Overview
new Ellipse(x, y, width, height)
Draw an ellipse with center at {200,200} and 100px wide, 50px high
new Ellipse(200, 200, 100/2, 50/2)
.attr({fillColor: 'orange'})
.addTo(stage);
Draw a star
Overview
new Star(x, y, radius, rays, factor)
Draw a star with a radius of 100 and 5 tips:
new Star(0, 0, 100, 5);
Draw a star with a radius of 100 and 10 tips:
new Star(0, 0, 100, 10);
Draw an arc (donat, pizza slice)
Overview
new Arc(x, y, radius, startAngle, endAngle[, anticlockwise])
new Path().arc(x, y, radius, startAngle, endAngle[, anticlockwise])
Draw a circle at 100x100 with a radius of 50
new Arc(100, 100, 50, 0, Math.PI*2)
.attr('strokeWidth', 1)
.addTo(stage);
Draw half of a donat at 100x100 with a radius of 50
new Arc(100, 100, 50, 0, Math.PI, 0)
.attr('strokeWidth', 20)
.addTo(stage);
Draw a pizza slice at 100x100 with a radius of 50
var center = {x: 100, y:100}, radius = 50;
new Path()
.moveTo(center.x, center.y)
.lineBy(radius, 0)
.arc(center.x, center.y, radius, 0, Math.PI*0.3)
.closePath()
.attr('fillColor', 'red')
.addTo(stage);
Draw a polygon
Overview
new Polygon(x, y, radius, sides)
Draw a polygon at 100x100 with a radius of 50 and 5 sides
new Polygon(100, 100, 50, 5)
.attr('strokeWidth', 2)
.addTo(stage);
Modify Paths (attr)
Overview
aPath.attr(propertyName, value);
aPath.attr(propertyMap);
Move a shape to the given x and y coordinates
aPath.attr({ x: 100, y: 200 })
Set opacity to 50%
aPath.attr('opacity', 0.5)
Bitmap
Overview
new Bitmap(source)
Add a Bitmap to the stage
new Bitmap('url/to/image')
.addTo(stage);
Add data in-line via data-uri
new Bitmap('…')
.addTo(stage);
Wait until image is loaded before adding it to the stage
new Bitmap([{
src: 'http://bit.ly/VOuAfy',
type: 'image/jpg'
}])
// or just
// new Bitmap('url/to/image.jpg') // uses extension as type
.on('load', function() {
this.attr('filters', filter.blur(2))
.addTo(stage);
});
Animation
Overview
var anim = new Animation(duration, properties, options);
aDisplayObject.animate(anim);
aDisplayObject.animate(duration, properties, options)
Animate x
position to 300px in 1 second
var anim = new Animation('1000ms', { x: 300 });
new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage)
.animate(anim);
Animate x
position to 300px in 1 second (shortcut version)
new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage)
.animate('1s', { x: 300 });
Animate fill color from 'red' to 'blue'.
new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage)
.animate('3s', {fillColor: 'blue'});
Rotate a shape around its left upper corner in 2 seconds
new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage)
.animate('2s', { rotation: Math.PI*2 });
Animate multiple properties
new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage)
.animate('3s', {
x: 300,
y: 300,
opacity: 0
}, { easing:'linear' });
Apply animation object on multiple shapes
var shape1 = new Rect(0,0,100,100).attr('fillColor', 'red')
.addTo(stage);
var shape2 = new Rect(200,0,100,100).attr('fillColor', 'blue')
.addTo(stage);
[shape1, shape2].forEach(function(shape) {
shape.animate('1s', {y: 100});
});
Animation Callbacks
Hook onto events of the animation, using 'on()'
anim = new Animation('1s',{x:300});
anim.on('play', onStart);
anim.on('end', onEnd);
aDisplayObject.animate(anim);
Hook events animation, using the options parameter
aDisplayObject.animate('2s', { x:300 }, { onEnd:onEnd, onPlay:onStart });
Keyframe animation
var anim = new KeyframeAnimation('2s', {
'0s': {x:0, y:0},
'1s': {x:200, y:0},
'2s': {x:200, y:200}
});
new Rect(0,0,100,100)
.attr('fillColor', 'red')
.addTo(stage)
.animate(anim);
Animate Options
easing
aDisplayObject.animate('1s', {x:300}, {easing:'xxx'});
linear, quadIn, quadOut, quadInOut, cubicIn, cubicOut, cubicInOut,
quartIn, quartOut, quartInOut, quintIn, quintOut, quintInOut, sineIn,
sineOut, sineInOut, expoIn, expoOut, expoInOut, circIn, circOut,
circInOut, backIn, backOut, backInOut, elasticIn, elasticOut,
elasticInOut, bounceIn, bounceOut, bounceInOut
repeat
aDisplayObject.animate('1s', {x:300}, {repeat:3}); // 0 - Infinity
Gradients
Overview:
gradient.linear(direction, colorStops, doRepeat)
gradient.radial(colorStops, radius, cx, cy, doRepeat)
Applying a gradient as the fill of a shape
shape.attr({
fillGradient: gradient.linear(arguments);
});
** Note: a fillGradient will appear in front of a fillColor
Animate a gradient to 0º-red-orange to -45º-blue-orange
shape.attr({
fillGradient: gradient.linear(0, ['red','orange']);
}).animate('3s', {
fillGradient: gradient.linear(-45, ['blue','orange']);
});
Define a linear gradient going towards the left, with a color-stop of green at 20%
gradient.linear('left', [
'rgb(255,25,5)',
['green', 20],
'yellow'
]);
Define a radial gradient going from blue (center) to yellow (outer)
gradient.radial(['blue', 'yellow']);
Define a radial gradient with a radius of 50 and a {cx,cy} or {0,0}
gradient.radial(['blue', 'yellow'], 50, 0, 0);
Colors
Create a color instance
color('red');
color('#F00');
color('#FF0000');
color('#FF0000FF'); // #RRGGBBAA
color('rgb(255,0,0)');
color('rgba(255,0,0,1)');
color('hsl(0,100%,50%)');
color('hsla(0,100%,50%,1)');
Spawn a color a bit darker than red
color('red').darker(0.2)
Spawn a random color by randomizing the hue of blue
color('blue').randomize(['hue'])
Adjust a color
color('#F0F').r(200).g(25).b(100); // rgb(200,25,100)
Output a color as an RGBA string
color('red').rgba(); // => 'rgba(255,0,0,1)'
Events
Hook on the click event of a shape
shape.on('click', function(data){});
Catch the drag event on a shape
shape.on('drag', function(data){});
Set the hand cursor when dragging
shape.on('drag', function(data){
this.attr('cursor', 'pointer');
});
Bind to the next event only (use once()
)
shape.once('click', function() {});
Text
Print "Hello World"
text = new Text('Hello World');
stage.addChild(text);
Position baseline of text at {100,100}
text.attr({ x:100, y:100 });
Position text on baseline (bottom) at {100,100}
text.attr({ x:100, y:100, textOrigin: 'base' });
Setting font family and size
text.attr({ fontFamily:'Arial', fontSize:'20px' });
Setting text color and line color
text.attr({
textFillColor:'orange',
textLineColor:'blue',
textLineWidth:2
});
Setting custom fontFamily
var myFont = new FontFamily('myFont', [
'path/to/myFont.ttf',
'path/to/myFont.woff',
'path/to/myFont.svg'
]);
text.attr('fontFamily', myFont);
Video
Start video playback
video = new Video({url:'', type:''}).attr({
width:320,
height:240
});
stage.addChild(video);
Start video playback with onload event listener *
video = new Video([
'video.ogg',
'video.mpg'
], {
onload: function() {
this.attr({
width:320,
height:240
}).addTo(stage);
}
});
** Most mobile browsers don't allow autoplaying of videos due to excessive bandwidth consumption and therefore shorter battery life. If you're targeting such devices please make sure to avoid ´onload´ event listeners because it won't be fired without user interaction.
Other loadLevel settings
options.loadLevel = 'start-with-nothing'; // nothing to play
options.loadLevel = 'metadata'; // nothing to play but metadata
options.loadLevel = 'risky-to-play'; // loaded data but not enough to play
options.loadLevel = 'can-play'; // can play (default)
options.loadLevel = 'can-play-through'; // can play through
Filter
Apply a blur filter (level of 3) on a DisplayObject
aDisplayObject.attr('filters', filter.blur(3)); // 0 - Infinity
Apply a brightness filter on a DisplayObject
aDisplayObject.attr('filters', filter.brightness(2)); // 0 - Infinity
Apply a colorMatrix filter on a DisplayObject
var aMatrix = [
1, 0, 0, 0, 0,
0, 1, 0, 1, 0,
0, 0, 1, 0, 0,
0, 0, 0, 1, 0
];
aDisplayObject.attr('filters', filter.colorMatrix(aMatrix));
Apply a contrast filter on a DisplayObject
aDisplayObject.attr('filters', filter.contrast(2)); // 0 - Infinity
Apply a dropShadow filter on a DisplayObject
// [offsetX, offsetY, blurRadius, color]
aDisplayObject.attr('filters', filter.dropShadow([1, 1, 2, 0x000000FF]));
Apply a grayscale filter on a DisplayObject
aDisplayObject.attr('filters', filter.grayscale(1)); // 0 - 1
Apply a hueRotate filter on a DisplayObject
aDisplayObject.attr('filters', filter.hueRotate(90)); // 0 - 360
Apply a invert filter on a DisplayObject
aDisplayObject.attr('filters', filter.invert(1)); // 0 - 1
Apply a saturate filter on a DisplayObject
aDisplayObject.attr('filters', filter.saturate(5)); // 0 - Infinity
Apply a sepia filter on a DisplayObject
aDisplayObject.attr('filters', filter.sepia(1)); // 0 - 1
Apply multiple filters on a DisplayObject
aDisplayObject.attr('filters', [
filter.blur(1),
filter.saturate(2)
]);
Add Bonsai to your web page
Development Mode
To use bonsai in development mode, requirejs needs to be included and configured. Development mode is useful when developing bonsai itself, not when debugging a movie.
<script src="bonsai/lib/requirejs/require.js"></script>
<script>
require.config({
paths: {
bonsai: 'bonsai/src' // path to bonsai's src folder
});
require([
'bonsai/bootstrapper/_dev/iframe'
//or, for a worker environment: 'bonsai/bootstrapper/_dev/worker'
], function(bonsai) {
// Do something with bonsai here (see below)
});
</script>
Production Mode
When using bonsai to create a movie, you should use the built version of bonsai.
<script src="bonsai.min.js"></script>
<script>
// do something with the bonsai object (see below)
</script>
Embed a Movie Into Your Page
// The node the movie will be appended to
var node = document.getElementById('movie');
// options for the movie
var options = {
/* possible options: */
// (String)
// Base URL used to resolve movie and plugin URLs.
// Default: relative to current page.
baseUrl: '.',
// (String) – Base URL used to resolve any assets loaded within movies
// Default: relative to loaded-movie
assetBaseUrl: '.',
// (Array) of plugin URLs to load (all relative to the optional baseUrl)
plugins: ['a-plugin.js', '../../bonsai-plugins/my-plugin.js'],
// (Array) – Array of movie URLs to load (all relative to the optional baseUrl)
urls: ['a-movie.js'],
// (String) - URL of movie (relative to the optional baseUrl)
// Alternative approach when movie is not passed as second parameter to `run`
url: 'a-movie.js',
// (String|Function) – JavaScript code to run directly as a movie
// Note: the passed Function gets stringified (useful for code-highlighting)
code: 'new Rect(0, 0, 100, 100).attr({"fill": "red"}).addTo(stage);',
// (Number) the desired FPS (frames per second) of movie. Default: 30
framerate: 24,
// (Number), the desired width of the movie. Default: Infinity
width: 500,
// (Number), the desired height of the movie. Default: Infinity
height: 310,
// (Boolean|Function), whether to display a frame rate
// if true, the frame rate is displayed within the movie.
// if function, the frame rate is passed to the function every second.
// Default: false
fpsLog: true
};
// A movie from a file
var movie = bonsai.run(node,
// path to the movie to play
'movies/example.js',
options
);
// A movie from a file using url option
var movie = bonsai.run(node, {
url: 'movies/example.js'
});
// A movie from source code
var movie = bonsai.run(node, {
// the code to execute as string
code: 'new Rect(0, 0, 100, 100).attr({"fill": "red"}).addTo(stage);'
// or wrapped in a function
// code: function() {
// new Rect(0, 0, 100, 100).attr({"fill": "red"}).addTo(stage);
// }
// base url for assets, relative to the current page
baseUrl: 'movies/assets'
// other options like width, height
});
movie.stop(); // stops the movie
movie.play(); // plays the movie
movie.destroy(); // completely destroys the movie
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论