设置舞台属性

Stage 类用于覆盖 DisplayObject 类的大多数属性和方法。如果调用其中一个已覆盖的属性或方法,Flash Player 会引发异常。例如,Stage 对象不具有 xy 属性,因为作为应用程序的主容器,该对象的位置是固定的。xy 属性是指显示对象相对于其容器的位置,由于舞台没有包含在其它显示对象容器中,因此这些属性不适用。

注意

 

如果显示对象与加载的第一个 SWF 文件不在同一个安全沙箱中,则 Stage 类的某些属性和方法不适用于这些显示对象。有关详细信息,请参阅Stage 安全性

子主题

控制回放帧速率
控制舞台缩放比例
处理全屏模式

控制回放帧速率

Stage 类的 framerate 属性用于设置加载到应用程序中的所有 SWF 文件的帧速率。有关详细信息,请参阅《ActionScript 3.0 语言和组件参考》。

控制舞台缩放比例

当调整 Flash Player 屏幕的大小时,Flash Player 会自动调整舞台内容来加以补偿。Stage 类的 scaleMode 属性可确定如何调整舞台内容。此属性可以设置为四个不同值,如 flash.display.StageScaleMode 类中的常量所定义。

对于 scaleMode 的三个值(StageScaleMode.EXACT_FITStageScaleMode.SHOW_ALLStageScaleMode.NO_BORDER),Flash Player 将缩放舞台的内容以容纳在舞台边界内。三个选项在确定如何完成缩放时是不相同的。

或者,如果将 scaleMode 设置为 StageScaleMode.NO_SCALE,则当查看者调整 Flash Player 窗口大小时,舞台内容将保持定义的大小。仅在缩放模式中,Stage 类的 widthheight 属性才可用于确定 Flash Player 窗口调整大小后的实际像素尺寸。(在其它缩放模式中,stageWidthstageHeight 属性始终反映的是 SWF 的原始宽度和高度。)此外,当 scaleMode 设置为 StageScaleMode.NO_SCALE 并且调整了 SWF 文件大小时,将调度 Stage 类的 resize 事件,允许您进行相应地调整。

因此,将 scaleMode 设置为 StageScaleMode.NO_SCALE 可以更好地控制如何根据需要调整屏幕内容以适合窗口大小。例如,在包含视频和控制栏的 SWF 中,您可能希望在调整舞台大小时控制栏的大小保持不变,而仅更改视频窗口大小以适应舞台大小的更改。以下示例中演示了这一点:

// videoScreen 是一个包含视频的显示对象(例如,视频实例)
//;它位于舞台左上角,并且
// 在调整 SWF 大小时其大小也应调整。

// controlBar 是一个包含多个按钮的显示对象(例如,Sprite),
// 它应位于舞台(在 videoScreen 的下方)的左下角,
// 在调整 SWF 大小时其大小将不会
// 调整。

import flash.display.Stage;
import flash.display.StageAlign;
import flash.display.StageScaleMode;
import flash.events.Event;

var swfStage:Stage = videoScreen.stage;
swfStage.scaleMode = StageScaleMode.NO_SCALE;
swfStage.align = StageAlign.TOP_LEFT;

function resizeDisplay(event:Event):void
{
    var swfWidth:int = swfStage.stageWidth;
    var swfHeight:int = swfStage.stageHeight;

    // Resize the video window.
    var newVideoHeight:Number = swfHeight - controlBar.height;
    videoScreen.height = newVideoHeight;
    videoScreen.scaleX = videoScreen.scaleY;
    
    // Reposition the control bar.
    controlBar.y = newVideoHeight;
}

swfStage.addEventListener(Event.RESIZE, resizeDisplay);

处理全屏模式

使用全屏模式可令 SWF 填充查看器的整个显示器,没有任何边框、菜单栏等。Stage 类的 displayState 属性用于切换 SWF 的全屏模式。可以将 displayState 属性设置为由 flash.display.StageDisplayState 类中的常量定义的其中一个值。要打开全屏模式,请将 displayState 设置为 StageDisplayState.FULL_SCREEN

// mySprite 是一个 Sprite 实例,已添加到显示列表中
mySprite.stage.displayState = StageDisplayState.FULL_SCREEN;

要退出全屏模式,请将 displayState 属性设置为 StageDisplayState.NORMAL

mySprite.stage.displayState = StageDisplayState.NORMAL;

此外,用户可以通过将焦点切换到其它窗口或使用以下组合键之一来选择退出全屏模式:Esc(所有平台)、Ctrl-W (Windows)、Command-W (Mac) 或 Alt-F4 (Windows)。

全屏模式的舞台缩放行为与正常模式下的相同;缩放比例由 Stage 类的 scaleMode 属性控制。通常,如果将 scaleMode 属性设置为 StageScaleMode.NO_SCALE,则 Stage 的 stageWidthstageHeight 属性将发生更改,以反映由 SWF 占用的屏幕区域的大小(在本例中为整个屏幕)。

打开或关闭全屏模式时,可以使用 Stage 类的 fullScreen 事件来检测和响应。例如,进入或退出全屏模式时,您可能需要重新定位、添加或删除屏幕中的项目,如本例中所示:

import flash.events.FullScreenEvent;

function fullScreenRedraw(event:FullScreenEvent):void
{
    if (event.fullScreen)
    {
        // 删除输入文本字段。
        // 添加关闭全屏模式的按钮。
    }
    else
    {
        // 重新添加输入文本字段。
        // 删除关闭全屏模式的按钮。
    }
}

mySprite.stage.addEventListener(FullScreenEvent.FULL_SCREEN, fullScreenRedraw);

正如此代码所示,fullScreen 事件的事件对象是 flash.events.FullScreenEvent 类的实例,它包含指示是启用 (true) 还是禁用 (false) 全屏模式的 fullScreen 属性。

在 ActionScript 中处理全屏模式时,需要记住以下注意事项:

还有其它几个需要了解的与安全有关的限制。这些将在安全沙箱中予以介绍。


Flash CS3

 

评论添加到页面后给我发送电子邮件 | 评论报告

当前页: http://livedocs.adobe.com/flash/9.0_cn/main/00000150.html