KineticJS教程(3)

KineticJS教程(3)

作者: ysm

3.图形对象

3.1.Shape

Kinetic提供了一个Shape对象用于在层上绘制图形,我们可以通过Kinetic.Shape()构造方法返回一个Shape对象:

<script>

var shape = new Kinetic.Shape(config);

</script>

Shape方法的config参数是关于具体的绘图参数的数组对象,Kinetic就是根据这个参数里的具体信息进行绘图的。

Config的完整参数如下表所示:

Property Description Default Required
drawFunc draw function - required
fill can be a color, linear gradient, radial gradient, or pattern - optional
stroke stroke color - optional
strokeWidth stroke width - optional
lineJoin can be miterround, or bevel miter optional
shadow shadow object - optional
detectonType can be path or pixel path optional
x x position 0 optional
y y position 0 optional
visible whether or not the shape is visible true optional
listening whether or not to listen to events true optional
id unique shape id - optional
name shape name - optional
alpha shape opacity 1 optional
scale shape scale [1,1] optional
rotation rotation about the center point in radians 0 optional
rotationDeg rotation about the center point in degrees 0 optional
centerOffset center offset [0,0] optional
draggable whether or not the shape is draggable false optional
dragConstraint can be nonehorizontal, or vertical none optional
dragBounds drag and drop bounds - optional

其中最重要的参数就是drawFunc,这是一个由用户创建的方法对象,Kinetic绘图时就是调用的这个方法。

比如我们可以如下在页面上画一个矩形:

<!DOCTYPE html>

<html>

<head>

<meta charset=“UTF-8″>

<title>KineticJS</title>

<script src=“../kinetic.js”></script>

</head>

<body>

<script>

window.onload = function() {

//创建舞台

var stage = new Kinetic.Stage({

container : “container”,

width : 600,

height : 400

});

var layer = new Kinetic.Layer();

//创建config参数

var config = {

//绘图方法,画一个矩形

drawFunc : function() {

var context = this.getContext();

context.rect(200, 150, 200, 100);

this.fill();

this.stroke();

},

//填充色

fill : “green”,

//边缘线颜色

stroke : “black”,

//边缘线宽度

strokeWidth : 4

};

//创建Shape对象

var rectShape = new Kinetic.Shape(config);

//把Shape对象添加到层里

layer.add(rectShape);

//将层添加到舞台中

stage.add(layer);

};

</script>

<div id=“container”></div>

</body>

</html>

3.2.常用图形

Kinetic除了有Shape可以用于绘图外,还为我们提供了一系列用于常见图形绘制的对象,包括矩形(Rect)、圆(Circle)、图像(Image)、精灵(Sprite)、文本(Text)、线(Line)、多边形(Polygon)、常用多边形(Regular Polygon)、路径(Path)、星星(Star)几种。

这几个图形对象都是继承自Shape,所以使用方法与Shape类似,以一个config对象指定绘图细节,与Shape不同的是,不需要我们指定drawFunc,只需要根据图形的类型指定关键参数就可以了。

在此,我们以Shape.Rect为例,绘制矩形图形的代码如下:

<!DOCTYPE html>

<html>

<head>

<meta charset=“UTF-8″>

<title>KineticJS</title>

<script src=“../kinetic.js”></script>

</head>

<body>

<script>

window.onload = function() {

var stage = new Kinetic.Stage({

container : “container”,

width : 600,

height : 400

});

var layer = new Kinetic.Layer();

//创建config参数

var config = {

//左上角x坐标

x : 200,

//左上角y坐标

y : 150,

//矩形宽度

width : 200,

//矩形高度

height : 100,

//填充色

fill : “blue”,

//边缘线颜色

stroke : “black”,

//边缘线宽度

strokeWidth : 4

};

//创建Shape对象

var rect = new Kinetic.Rect(config);

//把Shape对象添加到层里

layer.add(rect);

//将层添加到舞台中

stage.add(layer);

};

</script>

<div id=“container”></div>

</body>

</html>

具体每种图形的config参数细节可以参见Kinetic的文档。

3.3.图形组

Kinetic提供了Group对象,用于把若干个不同的图形对象,或者是其他的Group对象组合成一个复杂的图形进行统一管理。

比如,我们创建一个包含一个矩形和一个圆的group,并添加到层中显示出来。

<!DOCTYPE html>

<html>

<head>

<meta charset=“UTF-8″>

<title>KineticJS</title>

<script src=“../kinetic.js”></script>

</head>

<body>

<script>

window.onload = function() {

var stage = new Kinetic.Stage({

container : “container”,

width : 600,

height : 400

});

var layer = new Kinetic.Layer();

//创建一个要加进组中的圆

var circle = new Kinetic.Circle({

x : 200,

y : 100,

radius : 50,

fill : “red”

});

//创建一个要加进组中的矩形

var rect = new Kinetic.Rect({

x : 300,

y : 200,

width : 100,

height : 100,

fill : “blue”

});

//创建group对象

var group = new Kinetic.Group();

//把多个图形对象添加到group里

group.add(circle);

group.add(rect);

//把group对象添加到层里

layer.add(group);

//将层添加到舞台中

stage.add(layer);

};

</script>

<div id=“container”></div>

</body>

</html>

由于Group继承自Node,而Shape也是继承自Node,因此,Group的一些属性和行为也和Shape比较类似,比如Group的构造方法也可以像接受一个config参数配置Group的位置、旋转、缩放等属性。

如:

var config = {

x : 220,

y : 40,

rotationDeg : 20

};

或者也可以不在创建group时通过config参数设定,而是创建group对象后通过相对应的方法设定各属性,比如x和y参数就可以分别用group.setX(220)和group.setY(20)来设定。

KineticJS教程(3)

时间: 2024-11-02 03:39:56

KineticJS教程(3)的相关文章

KineticJS教程(7)

KineticJS教程(7) 作者: ysm 7.图形变换 7.1.线性变化 Kinetic提供了一个图形对象的transitionTo(config)方法实现图形的线性变换,也就是从原始的状态线性变换到新的状态,这里的状态是指的尺度上的参数.方法的config参数也就是有关图形尺度的一些参数,比如 x, y, rotation, width, height, radius, strokeWidth, alpha, scale, centerOffset等.除了这些尺度参数,还需要一个durat

KineticJS教程(4)

KineticJS教程(4) 作者: ysm 4.图形样式 4.1.填充 Kinetic中图形的填充属性可以在构造方法中的config参数中的fill属性进行设定,也可以用图形对象的setFill方法进行设定.不过要注意,setFill使用的填充类型必须与创建这个对象时的config中所用的填充类型相同. Kinetic支持颜色.图像.线性渐变和径向渐变四种填充模式. 4.1.1.颜色填充 <!DOCTYPE html> <html> <head> <meta c

KineticJS教程(5)

KineticJS教程(5) 作者: ysm 5.事件响应 5.1.图形的事件响应 图形对象对事件的响应处理可以使用 on() 方法绑定事件类型和相应方法. On() 方法需要一个事件类型参数和相应方法,其中所支持的事件类型包括: mouseover, mouseout, mousemove, mousedown, mouseup, click, dblclick, dragstart 以及 dragend 事件.默认情况下,图形对象事件响应使用的是路径检测方法,下一节还会介绍像素检测方法. 绑

KineticJS教程(6)

KineticJS教程(6) 作者: ysm 6.拖拽 6.1.拖拽功能 要实现Kinetic对象的拖拽功能很简单,只需要将图形对象的draggable属性设为true就可以了. <script> // 在构造方法中的config参数设置 var shape = new Kinetic.Circle({ draggable: true; }); // 用图形对象的方法设置 shape.draggable(true); </script> 这种拖拽功能还可以应用到组(Group).层

KineticJS教程(8)

KineticJS教程(8) 作者: ysm 8.动画 动画就是一帧帧的画面按照时间间隔显示出来,Kinetic给我们提供了一个舞台对象的onFrame方法,用这个方法可以绑定一个动画方法,我们要显示的动画的每一帧画面就是在这个方法中完成绘制的. 其中,这个方法接受一个对象frame为参数,此参数对象包含两个属性,一个是frame.time,表示当前帧是动画开始后的毫秒数,另一个属性是 frame.timeDiff,表示的是当前帧与上一帧之间的时间毫秒差.当前帧因该是什么形态就是根据这两个事件来

KineticJS教程(9)

KineticJS教程(9) 作者: ysm 9.选择器 Kinetic在舞台.层和组对象上都提供了get方法,用于返回这三者中包含的对象. 9.1.根据ID获取对象 要用id获取对象,首先要给对象赋予一个id,比如下面代码创建的Rect的id就是id1: <script> var rect = new Kinetic.Rect({ id : “id1“ }); </script> 要注意的是,id是唯一的,不同对象不能使用相同的id,否则get也只能返回其中的一个. 然后用get

KineticJS教程(1-2)

1.基本结构 KineticJS首先是要绑定到HTML页面上的一个DOM容器元素上,比如最常用的<div>标签.KineticJS在此容器中创建一个称之为舞台(stage)的结构,这个舞台由一个不可见的后台层和一个不可见的缓冲层组成,提供了高性能的路径和像素检测能力.舞台上再包含若干(至少一层)用户层(layer),每个层上又包含有若干canvas元素,比如各种图形.图像.元素组(组可以包含其他的图形和其他的组)等.用户还可以给这些层上的图形.元素组.层本身以及舞台本身添加事件监听方法,以响应

html5开放资料

http://www.cnblogs.com/tim-li/archive/2012/08/06/2580252.html KineticJS教程(12) 摘要: KineticJS教程(12) 作者: ysm 12.舞台12.1.舞台的大小舞台创建后还可以用舞台对象的setSize(width, height)方法来设置舞台的宽度与高度.12.2.舞台的缩放舞台创建后还可以用舞台对象的setScale()方法来对舞台进行缩放.setScale方法可以接受一个...阅读全文 posted @ 2

Windows Git+TortoiseGit简易使用教程

转载自 http://blog.csdn.net/jarelzhou/article/details/8256139 官方教程:http://tortoisegit.org/docs/tortoisegit/(英文版) 为什么选择Git 效率 很多人有一种习惯吧,什么软件都要最新的,最好的.其实吧,软件就是工具,生产力工具,为的是提高我们的生产力.如果现有的工具已经可以满足生产力要求了,就没有必要换了.生产效率高低应当是选择工具的第一位. 历史 开源世界的版本控制系统,经历了这么几代: 第一代,