Enable不能和MouseOver、Out等并列作为状态

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等并列定义为【状态】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值