Heyyyy,我正在尝试找到一种简单的方法(或尽可能简单,我是AS3中的新手)在鼠标悬停事件时调整舞台大小。有关详细信息,原始大小为670x40,目标大小为670x230。另外,请回答movieclip。
答案 0 :(得分:1)
您无法从代码中动态更改舞台大小,但您可以使用JS更改它。 请参阅here。
答案 1 :(得分:0)
很抱歉,这是一篇旧帖子,但我希望这可以帮到某些人,我在stage.width,stage.height和stage.stageWidth,stage.stageHeight ......之间看到了很多问题和困惑......
您必须知道的是,您必须使用stage.align = StageAlign.TOP_LEFT或StageAlign.TOP和stage.scaleMode = StageScaleMode.NO_SCALE;
所有应该可以正常工作......
这是一种在触发Event.Resize时重新调整某些内容的方法... 在" com"中创建一个Main.as类文件。包(复制粘贴下面的简单代码,以找出它是如何工作的)并将flash中的主类设置为" com.Main"。
为什么要在触发MouseEvent时执行此操作? 好像废话......
在这种情况下,Event.RESIZE效率更高。 Event.ADDED将初始化您要调整大小的项目...
package com
{
import flash.display.Graphics;
import flash.display.MovieClip;
import flash.display.Stage;
import flash.display.StageAlign;
import flash.display.StageQuality;
import flash.display.StageScaleMode;
import flash.events.Event;
import flash.text.TextField;
public class Main extends MovieClip
{
public static const ORANGE:int = 0xff9900;
private var bg:MovieClip;
private var bg_mask:MovieClip;
private var marginx:int = 10;
private var marginy:int = 10;
private var display:MovieClip;
private var displayTextField:TextField;
private var ellipseWidth:int = 90;
private var ellipseHeight:int = 90;
public function Main()
{
super();
bg = new MovieClip();
bg_mask = new MovieClip();
display = new MovieClip();
displayTextField = new TextField();
this.addChild(bg);
this.addChild(bg_mask);
this.addChild(display);
this.display.addChild(displayTextField);
displayTextField.text = "";
displayTextField.x = ellipseWidth/Math.PI;
displayTextField.y = ellipseHeight/Math.PI;
stage.align = StageAlign.TOP_LEFT; // or StageAlign.TOP
stage.scaleMode = StageScaleMode.NO_SCALE;
drawBackground();
display.mask = bg_mask;
addListeners();
}
private function drawBackground(thickness:int=1,lineColor:int=0x000000,lineAlpha:Number=0.5,fillColor:int=ORANGE,fillAlpha:Number=0.5):void{
var g:Graphics = bg.graphics;
g.clear();
g.lineStyle(thickness,lineColor,lineAlpha);
g.beginFill(fillColor,fillAlpha);
g.drawRoundRect(marginx,marginy,this.stage.stageWidth-marginx*2,this.stage.stageHeight-marginy*2,ellipseWidth,ellipseHeight);
g.endFill();
}
private function drawMask():void{
var g:Graphics = bg_mask.graphics;
g.clear();
g.lineStyle(1,0x000000,0.3);
g.beginFill(0xcccccc,0.1);
g.drawRoundRect(marginx,marginy,this.stage.stageWidth-marginx*2,this.stage.stageHeight-marginy*2,90,90);
g.endFill();
}
private function addListeners():void{
stage.addEventListener(Event.ADDED,updateLabel);
stage.addEventListener(Event.RESIZE,updateLabel);
}
private function updateLabel(e:Event):void{
updateDisplay();
drawBackground();
drawMask();
}
private function updateDisplay():void{
var tf:TextField = displayTextField;
tf.text = ("{" + this.stage.stageWidth + ";" + this.stage.stageHeight + "}");
}
}
}