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

阅读更多
个人分类: 思想精髓集萃
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

不良信息举报

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

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭