关闭

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

337人阅读 评论(0) 收藏 举报
分类:

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

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:323388次
    • 积分:5846
    • 等级:
    • 排名:第4535名
    • 原创:266篇
    • 转载:40篇
    • 译文:0篇
    • 评论:84条