MouseOver/Out作为状态可以用来控制UI外观的切换,比如按钮颜色。
而Enable不能作为【状态】和MouseOver/Out同等定义。
因为它们是不同级别的。
举例:
按钮在鼠标移入,移出时改变按钮的颜色。
点击按钮后,让按钮失效(Enable->Disable)。
代码实现方法:
在按钮上监听MouseEvent.ROLLOVER、MouseEvent.ROLLOUT、MouseEvent.CLICK事件。
ROLLOVER
{
//改变按钮颜色:蓝色
}
ROLLOUT
{
//改变按钮颜色:红色
}
CLICK
{
//让按钮不响应鼠标事件
this.mouseEnabled = true;
this.mouseChildren = false;
//改变按钮颜色:灰色
this.enable = false ;
}
public function set enable(v:boolean):void
{
_enable = v ;
this.mouseEnabled = _enable;
}
===============================================
你会发现点击按钮后,按钮颜色并没有如预期变为灰色,而是红色。
为什么?
因为 【this.enable = fase 】的时候,首先把【状态】设置成为【DISABLE】。
而在【public function set enable(v:boolean):void】中进而把【this.mouseEnabled = false】,
从而触发了this的【ROLLOUT】事件,把【状态】覆盖成了【ROLLOUT】,也就是变成了红色。
因此不能把enable与mouseRollOver等并列定义为【状态】