KineticJS教程(11)
KineticJS教程(11)
11.对象的上下关系
11.1.层的上下关系
Kinetic的层是按照添加到舞台的次序,由下向上排列,上层遮盖下层的图形。每个层各自有一个ZIndex编号来表示在层级中的上下位置,编号从0开始,表示最底层,向上层依次增1。
Kinetic提供了几个方法用于调整层的上下层位置,包括:
<script>
//移动到最上层
layer.moveToTop();
//移动到最下层
layer.moveToBottom();
//向上移动一层
layer.moveUp();
//向下移动一层
layer.moveDown();
//设定层的ZIndex值
layer.setZIndex(5);
</script>
如下代码通过点击某层上圆将所圆所在层调整至最上层:
<!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 layer1 = new Kinetic.Layer();
var layer2 = new Kinetic.Layer();
var layer3 = new Kinetic.Layer();
var config1 = {
x : 200,
y : 200,
radius : 100,
height : 100,
fill : “red”,
stroke : “black”,
strokeWidth : 4
};
var circle1 = new Kinetic.Circle(config1);
var config2 = {
x : 250,
y : 200,
radius : 100,
height : 100,
fill : “green”,
stroke : “black”,
strokeWidth : 4
};
var circle2 = new Kinetic.Circle(config2);
var config3 = {
x : 300,
y : 200,
radius : 100,
height : 100,
fill : “blue”,
stroke : “black”,
strokeWidth : 4
};
var circle3 = new Kinetic.Circle(config3);
layer1.add(circle1);
layer2.add(circle2);
layer3.add(circle3);
layer1.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本层移动至最上层
this.moveToTop();
alert(“to Z index:” + this.getZIndex());
});
layer2.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本层移动至最上层
this.moveToTop();
alert(“to Z index:” + this.getZIndex());
});
layer3.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本层移动至最上层
this.moveToTop();
alert(“to Z index:” + this.getZIndex());
});
//将层添加到舞台中
stage.add(layer1);
stage.add(layer2);
stage.add(layer3);
};
</script>
<div id=“container”></div>
</body>
</html>
11.2.图形对象的上下关系
在某一层中的各图形对象也有类似于层之间的上下层叠关系,由下向上排列,上层图形对象遮盖下层的图形对象。每个图形对象各自有一个ZIndex编号来表示在层级中的上下位置,编号从0开始,表示最底层,向上层依次增1。
Kinetic提供了几个方法用于调整图形对象的上下层位置,包括:
<script>
//移动到最上层
shape.moveToTop();
//移动到最下层
shape.moveToBottom();
//向上移动一层
shape.moveUp();
//向下移动一层
shape.moveDown();
//设定层的ZIndex值
shape.setZIndex(5);
</script>
如下代码通过点击圆将所点击的圆调整至其所在层中各圆的最上层:
<!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 config1 = {
x : 200,
y : 200,
radius : 100,
height : 100,
fill : “red”,
stroke : “black”,
strokeWidth : 4
};
var circle1 = new Kinetic.Circle(config1);
circle1.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本对象移动到本层所有对象中的最上面
this.moveToTop();
//重绘对象所在本层
layer.draw();
alert(“to Z index:” + this.getZIndex());
});
var config2 = {
x : 250,
y : 200,
radius : 100,
height : 100,
fill : “green”,
stroke : “black”,
strokeWidth : 4
};
var circle2 = new Kinetic.Circle(config2);
circle2.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本对象移动到本层所有对象中的最上面
this.moveToTop();
//重绘对象所在本层
layer.draw();
alert(“to Z index:” + this.getZIndex());
});
var config3 = {
x : 300,
y : 200,
radius : 100,
height : 100,
fill : “blue”,
stroke : “black”,
strokeWidth : 4
};
var circle3 = new Kinetic.Circle(config3);
circle3.on(“click”, function() {
alert(“from Z index:” + this.getZIndex());
//将本对象移动到本层所有对象中的最上面
this.moveToTop();
//重绘对象所在本层
layer.draw();
alert(“to Z index:” + this.getZIndex());
});
layer.add(circle1);
layer.add(circle2);
layer.add(circle3);
//将层添加到舞台中
stage.add(layer);
};
</script>
<div id=“container”></div>
</body>
</html>
KineticJS教程(11)的更多相关文章
- KineticJS教程(5)
KineticJS教程(5) 作者: ysm 5.事件响应 5.1.图形的事件响应 图形对象对事件的响应处理可以使用 on() 方法绑定事件类型和相应方法. On() 方法需要一个事件类型参数和相应 ...
- node-webkit教程(11)Platform Service之shell
node-webkit教程(11)Platform Service之shell 文/玄魂 目录 node-webkit教程(10)Platform Service之shell 前言 11.1 She ...
- 【译】ASP.NET MVC 5 教程 - 11:Details 和 Delete 方法详解
原文:[译]ASP.NET MVC 5 教程 - 11:Details 和 Delete 方法详解 在教程的这一部分,我们将研究一下自动生成的 Details 和Delete 方法. Details ...
- KineticJS教程(12)
KineticJS教程(12) 作者: ysm 12.舞台 12.1.舞台的大小 舞台创建后还可以用舞台对象的setSize(width, height)方法来设置舞台的宽度与高度. <scr ...
- KineticJS教程(10)
KineticJS教程(10) 作者: ysm 10.在容器之间移动图形对象 Kinetic支持通过图形对象的moveTo(container)方法把图形对象从一个容器移动到另一个容器里,这个容器指 ...
- KineticJS教程(9)
KineticJS教程(9) 作者: ysm 9.选择器 Kinetic在舞台.层和组对象上都提供了get方法,用于返回这三者中包含的对象. 9.1.根据ID获取对象 要用id获取对象,首先要给对象 ...
- KineticJS教程(8)
KineticJS教程(8) 作者: ysm 8.动画 动画就是一帧帧的画面按照时间间隔显示出来,Kinetic给我们提供了一个舞台对象的onFrame方法,用这个方法可以绑定一个动画方法,我们要显 ...
- KineticJS教程(7)
KineticJS教程(7) 作者: ysm 7.图形变换 7.1.线性变化 Kinetic提供了一个图形对象的transitionTo(config)方法实现图形的线性变换,也就是从原始的状态线性变 ...
- KineticJS教程(6)
KineticJS教程(6) 作者: ysm 6.拖拽 6.1.拖拽功能 要实现Kinetic对象的拖拽功能很简单,只需要将图形对象的draggable属性设为true就可以了. <script ...
随机推荐
- python @classmethod 的使用场合
python @classmethod 的使用场合 官方的说法: classmethod(function)中文说明:classmethod是用来指定一个类的方法为类方法,没有此参数指定的类的方法为实 ...
- 安卓 onTouch OnTouchEvent onChick 顺序
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 分发触摸事件 -> 在 触摸 时候 -> 在触摸事件时候->在点击时候 ...
- Eigen学习笔记2:C++矩阵运算库Eigen介绍
Eigen常规矩阵定义 1.使用 Eigen的使用在官网上有详细的介绍,这里对我学习过程中用到的基本操作进行介绍.首先是矩阵的定义.在矩阵类的模板参数共有6个.一般情况下我们只需要关注前三个参数即可. ...
- Nginx 502 Bad Gateway 解决方法
proxy_next_upstream error timeout invalid_header http_500 http_503;或者尝试设置:large_client_header_buffer ...
- php-streams扩展学习
一. streams是干嘛的: 用于统一文件.网络.数据压缩等类文件操作方式,并为这些类文件操作提供一组通用的函数接口. 二. stream是具有流式行为的资源对象,这个对象有一个包装类 例如: pr ...
- 比较page、request、session、application的使用范围(转自用)
(1)直接在web contain中进行对象的实例化. 内置对象 类型 作用域 pageContext javax.servlet.jsp.pageContext page request javax ...
- 使用IE9、FireFox与Chrome浏览WPF Browser Application(.XBAP)的方式
最近开始写一些WPF的小Sample和文章,但是毕竟WPF应用程式不像Silverlight那么方便的只要装个Plugin就可以透过浏览器来看执行结果,因此把脑筋动到了改用WPF Browser Ap ...
- jquery开发之第一个程序
前一段时间学习了js和css.可是发现好多的程序里面都用到了jquery当时本来想着先吧js弄熟了 再搞这个.后来发现不行,好多的程序好像是有益和自己为难似的,所以我决定接下来认认真真的把jquery ...
- Maven之——仓库(下)
Maven之--仓库(下) 1. 快照版本号 Maven世界中不论什么项目或者构件都有自己的版本号. Maven在构建时检測到构件是快照版本号.而且当前构件不是最新版本号的时候.就会自己主动更新 ...
- SharePoint 入门书籍推荐
最近,总有人说刚入门SharePoint,没有好的资料或者电子书,资料推荐大家多看看博客园和CSDN的博客.对于看博客,我一般是两个思路,要么找一个人的从头到尾看一遍,觉得有意义的,就把地址加收藏:或 ...