`
zccst
  • 浏览: 3324232 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

显示容器 DisplayObjectContainer

阅读更多
显示容器 DisplayObjectContainer(DisplayObjectContainer 继承自 DisplayObject)

本节详细介绍显示容器以及显示列表的使用方法

批注:
Shape, Bitmap, textFeild, TextInput不可以addChild。原因是他们直接继承自DisplayObject
Sprite, Stage, MovieClip, BitmapText可以addChild,原因是他们继承自DisplayObjectContainer,又封装了一些显示列表中常用的功能




-----------1, 显示容器的概念与实现
所有的容器全部继承自 DisplayObjectContainer 类,这个名称为 DisplayObjectContainer 的类又继承自 DisplayObject 。也就是说,在Egret中,所有的容器其实也继承自 DisplayObject。

在Egret中, DisplayObjectContainer 封装了一些显示列表中常用的功能。在后面的内容中,我们将详细介绍显示列表的操作。这些常用操作主要分为四类:

添加、删除子对象
访问子对象
检测子对象
设置叠放次序


属性:

方法:






批注:GameApp类就是继承了DisplayObjectContainer,所以GameApp就像一个舞台,有自己的:
a, stage对象,可获取舞台宽高,
var stageW:number = this.stage.stageWidth;
        var stageH:number = this.stage.stageHeight;
this.stage.addChild(this.loadingView);
this.stage.removeChild(this.loadingView);
b, 监听事件,可以this.addEventListener(egret.Event.ADDED_TO_STAGE,this.onAddToStage,this);
c, 添加孩子,
//添加背景
var sky:egret.Bitmap = this.createBitmapByName("bgImage");
        this.addChild(sky);
//添加遮罩
        var topMask:egret.Shape = new egret.Shape();
        topMask.graphics.beginFill(0x000000, 0.5);
        topMask.graphics.drawRect(0, 0, stageW, stageH);
        topMask.graphics.endFill();
        topMask.width = stageW;
        topMask.height = stageH;
        this.addChild(topMask);
//添加logo
        var icon:egret.Bitmap = this.createBitmapByName("egretIcon");
        icon.anchorX = icon.anchorY = 0.5;
        this.addChild(icon);
        icon.x = stageW / 2;
        icon.y = stageH / 2 - 60;
        icon.scaleX = 0.55;
        icon.scaleY = 0.55;
//添加Hello Egret
        var colorLabel:egret.TextField = new egret.TextField();
        colorLabel.x = stageW / 2;
        colorLabel.y = stageH / 2 + 50;
        colorLabel.anchorX = colorLabel.anchorY = 0.5;
        colorLabel.textColor = 0xffffff;
        colorLabel.textAlign = "center";
        colorLabel.text = "Hello Egret";
        colorLabel.size = 20;
        this.addChild(colorLabel);

(1)最轻量级的容器

在Egret中,我们拥有一个非常轻量级的容器:Sprite。

如果你查看Sprite类的内容,你会发现,Sprite仅仅是继承 DisplayObjectContainer。同时添加了一个Graphics功能。

(2)自定义容器

想要自定义一个容器非常容易,我们编写一个类,并且继承 DisplayObjectContainer 即可。当然,如果你想实现相关的Graphics绘图功能,你也可以继承 Sprite。

下面是一个自定义容器类的示例,这里我们定义了一个GridSprite。这个类默认会绘制一个红蓝相间的格子。
与上同,仅写出继承
class GridSprite extends egret.Sprite

批注:也可以写继承 DisplayObjectContainer。由于Sprite也继承自DisplayObjectContainer,同时又加入了自己的功能,为方便起见,也可以直接继承Sprite

批注:Sprite,不是上节对象中的四种对象Bitmap、Shape、TextField、TextInput
Sprite是容器,里面可以放置很多东西
Bitmap、Shape、TextField、TextInput是对象,不能放置东西




-----------2,添加与删除显示对象

(1)添加显示对象到显示列表
this.addChild( spr );

显示列表是一个树状结构,这里 spr 的上一级就是 this,也就是我们的文档类。文档类是 stage 舞台的第一个子对象。

批注,他们之间的关系是:容器->舞台->spr
舞台:有自己的宽高,可以添加/删除spr,this(文档类)是舞台的第一个子对象
spr:是一个容器

(2)删除显示对象
this.removeChild( spr );


(3)显示对象操作的注意点
a.显示对象独立于显示列表

b.相对坐标系
显示对象的坐标系是相对坐标系,而非绝对坐标系。
当我们将一个显示对象的x,y坐标值均设置为100的时候,该坐标值表示,当前显示对象居于父级原点100,100的位置。

c.3.多次添加显示对象到显示列表
同一个显示对象不被被代码加入显示列表多少次,在屏幕上只绘制一次。
如果一个显示对象A被添加到了B这个容器中,然后A又被添加到了C容器中。那么在第二次执行 C.addChild(A) 的时候,A自动的从B容器中被删除,然后添加到C容器中。

d.删除操作的注意点

当我们想要删除一个显示对象的时候需要执行的操作是:
容器对象.removeChild( 显示对象 );
但执行这个删除操作,我们的“显示对象”必须拥有父级。换句话说,被删除的显示对象必须存在于显示列表当中。
如果当前删除显示对象不在显示列表之中,那么在JavaScript控制台中你将看见报错信息:Uncaught Error: [Fatal]child未被addChild到该parent:
避免这种问题的处理方法非常简单,就是当你每次removeChild之前,你都对即将要被删除的显示对象做一次判断,判断它是否拥有父级。判断的代码如下:
if( spr.parent )
{
    spr.parent.removeChild( spr );
}



-----------3, 深度管理
深度是由每个容器的子对象列表所管理。
每个容器都清楚自己拥有多少个子对象。我们可以通过容器的 numChildren 属性来获取当前容器的子对象数量。
容器.numChildren

(1)深度顺序
Egret中容器的深度都是从0开始的,当一个显示对象第一个被添加到容器中时,它的深度值为0。这个显示对象也处于容器的最底层。当我们添加第二个显示对象的时候,他的深度值为1,并且在第一个显示对象上方。如果两个显示对象发生了相交,那么我们可以从视觉上看到,第二个显示对象遮挡住第一个显示对象。

(2)添加/删除指定深度的对象
我们默认使用的 addChild 方法会默认按照当前子对象深度进行排序,从0开始,每次深度加1,以此类推。

当我们想讲某一个显示对象添加到一个指定深度的时候,我们需要使用 addChildAt 方法。这个操作很像排队时插队的想象。
使用 addChildAt 方法也非常的容易,具体使用方法如下:

容器.addChildAt( 显示对象, 深度值 )





-----------4, 访问容器子对象
(1)通过深度值获取子对象
通过深度值获取子对象可以使用 getChildAt 方法,具体使用方式如下:

容器.getChildAt( 深度值 );

(2)通过Name属性获取

第二种方式是通过显示对象的 name 属性来获取,这种方式更加直接简单。

(3)两种获取子对象方式的比较

我们通过深度值和name属性获取子对象的作用是相同的,但Egret在内部事项原理却大大不同。

使用深度值获取子对象,Egret会根据当前容器的显示列表查找指定深度的显示对象,并作为返回值返回给用户。这种检索方式是快速的,不需要进行大量运算。

通过name属性来获取子对象,Egret内部首先会对当前容器的所有子对象进行编译,同时匹配相同的name属性值,当发现相同name属性的时候,则将该子对象作为返回值返回给用户。虽然在Egret内部进行了相关算法优化,但还是在一定程度上消耗了一些性能。

官方推荐使用第一种方法,通过深度值来获取子对象。




如果您觉得本文的内容对您的学习有所帮助,您可以微信:
分享到:
评论

相关推荐

    Egret引擎开发指南之视觉编程

    舞台作为一个显示容器,可以包含各种显示对象,而文档类创建的主容器则位于舞台之内,它同样是一个显示对象容器。 例如,一个简单的场景可能包含背景、人物和草地等元素。背景可能由背景图和大树组成,人物和草地则...

    Actionscript3.0基础语法

    - **DisplayObjectContainer**:这是显示对象的容器类,它允许你包含其他DisplayObject子类。DisplayObjectContainer有三个主要子类: - **Sprite**:是最常用的容器,可以包含图形、文本和其他DisplayObject。 -...

    flash 显示拍照,裁剪图片上传

    3. **DisplayObject容器**:在Flash中,你可以使用`DisplayObjectContainer`类的子类(如`Sprite`或`MovieClip`)作为容器,将摄像头的视频流显示在舞台上。这允许用户看到来自摄像头的实时画面。 4. **BitmapData...

    二级导航 as3

    AS3二级导航的实现涉及多个知识点,包括事件处理、显示对象容器、数据绑定和动态内容加载。 首先,我们需要理解AS3中的基本概念,如MovieClip和Sprite,它们是显示对象容器,可以包含其他显示对象并进行组合。在...

    开发Flash网络游戏需要掌握的技术

    DisplayObject是所有可显示对象的基类,而DisplayObjectContainer是包含其他DisplayObject的对象,具备容器属性。Shape、Sprite、MovieClip和Bitmap是基本的可显示对象,分别用于绘制矢量图形、组合多个对象、创建...

    AS3.0制作的电子表

    这个电子表可能由多个DisplayObject(如Sprite或MovieClip)组成,它们被组织在一个或多个容器(如Stage或DisplayObjectContainer)中。开发者可以通过添加、删除和排列这些对象来构建UI元素,例如数字、分隔线和...

    starling中文API

    1. **Stage**:舞台是所有视觉元素的容器,类似于Flash中的DisplayObjectContainer。Stage类是所有显示对象的顶级容器,你可以设置舞台的大小、背景颜色等属性。 2. **DisplayObject**:所有的图形元素,如图像、...

    Flex启动与初始化

    整个 Flex 项目确实可以载入到其它项目中的,但不是以 Module 方式载入而是通过普通方法加载,例如使用 SWFLoader 或 Loader 加载,SystemManager 作为顶级容器加入到项目的显示列表。 SystemManager 的 ...

    自己做的as3折叠文本

    2. **显示对象容器**:AS3中的DisplayObjectContainer类可以用来管理显示列表中的多个元素,如MovieClip或Sprite。在这个案例中,我们可以创建一个DisplayObjectContainer来包含展开和折叠状态下的文本。 3. **动态...

    flash多图片可伸缩展示代码.rar

    5. **Stage**对象:舞台是所有内容显示的地方,是DisplayObjectContainer的顶级容器。代码可能通过改变DisplayObject在舞台上的位置和大小来实现图片的伸缩效果。 6. **Scaling and Resizing**:Flash提供了多种...

    ActionScript3.0

    7. **Display Object容器**:AS3.0 的显示对象容器(DisplayObjectContainer)体系结构提供了舞台上的图形组织和层次管理,包括MovieClip、Sprite等,它们可以包含其他显示对象并进行组合。 8. **Stage和Timeline**...

    HTML5 Canvas 游戏开发实例详解

    4. **DisplayObjectContainer**:作为容器类,可以包含其他显示对象。 5. **Text**:用于显示文本。 6. **Stage**:作为根容器,是所有可见元素的最高层级容器。 7. **Sprite**:动画精灵,可以用于实现动画效果。 8...

    flash图片轮播效果源码

    2. **显示列表**:AS3中的显示列表是所有可显示对象的层次结构,包括`DisplayObject`、`DisplayObjectContainer`等基类。图片轮播中,图片会作为`Bitmap`或`BitmapData`对象添加到舞台上。 3. **事件处理**:使用`...

    这是一个as3相册分类

    `BitmapData`类用于加载和处理图片数据,`Sprite`和`MovieClip`则是常用的基本显示容器。 在项目中,还需要考虑性能优化。大量图片加载可能会导致内存占用过高,所以可以使用懒加载策略,即只在需要时加载图片。...

    flex游戏开发

    2. **DisplayObjectContainer**:可以包含其他显示对象的容器,用于组织和管理游戏界面的布局。 3. **Shape**:用于绘制简单的几何图形,如矩形、圆形等。 4. **Sprite**:类似于`DisplayObjectContainer`,但更专注...

    flash实现遮挡关系

    MovieClip是一个可以包含多个帧序列的显示对象,可以用来创建动态内容,而DisplayObjectContainer则是一个容器,可以容纳多个DisplayObject实例,包括其他MovieClip或图形,这就为创建多层提供了可能。 2. **层级...

    flash actionscript3 纯AS3代码_资源加载进度条.rar

    `DisplayObjectContainer`是AS3中所有可显示对象的基类,如`Sprite`和`MovieClip`。你可以将加载的资源和进度条组件添加到舞台或者其他的显示对象容器中,以便在舞台上展示。 6. **优化加载性能** 为了提高用户...

    完整的egret实例库

    2. **显示对象与容器**:Egret中的DisplayObjectContainer是用于组织和管理显示对象的类,如Stage、Group等。学会如何添加、移除子对象,调整层级关系,以及应用矩阵变换,可以实现复杂的布局和动画效果。 3. **12....

    Flex addChild()方法注意事项

    addChild()是一个常用的方法,用于向容器中添加组件或者显示对象。 一、addChild()方法的基础知识: 在Flex中,addChild()方法是DisplayObjectContainer类的一部分,这是一个允许动态添加子元素的容器。然而,Flex...

Global site tag (gtag.js) - Google Analytics