MIDP2.0中Alert的新特性

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

Alert类继续自Screen,它的作用是通知用户发生异常信息。在高级用户界面API中有三个类是不能有父容器的,他们必须要占据屏幕,其中一个就是Alert,另外两个是List和TextBox。在MIDP1.0中,Alert的灵活性比较差,表示的信息比较死板。在MIDP2.0中添加了一个重要的特性就是能够在Alert上添加指示器,因此可以和Guage结合起来使用。

和Alert结合使用的Guage有以下要求1.必须是非交互性的,2.不能同时在其他的容器内,3.Guage的label必须为null,4.Guage不能和Command和CommandListener关联。比如按照如下方式创建一个Guage实例

int max = ... // maximum value

int initial = ... // initial value

Gauge gauge = new Gauge( null, false, max, initial );

通过调用方法setIndicator()可以把Alert和Guage结合起来

Alert a = new Alert( "My alert" );

a.setIndicator( gauge );

由于MIDP的用户界面类都是线程安全的,因此你可以在其他的线程内改变guage的值,Alert会自动的重新绘制屏幕来更新guage的当前值。

在MIDP2.0中,我们可以显式的对Alert添加Command,当然假如你还要实现CommandListener的commandAction()方法来告诉系统当Command被按下的时候该做什么。在MIDP1.0中,有个默认的Command和Alert关联在一起的,假如我们在Alert中显式的添加了Command的话,那么这个默认的Command就被取代,假如添加的Command被删除,默认的Command会自动恢复和Alert的关联。假如我们在Alert上添加了两个以上的Command,那么它的Timeout会自动设置为FOREVER。

下面的应用程序很好的说明了如何使用不同的Alert表示不同的信息

import Javax.microedition.lcdui.*;

import javax.microedition.midlet.*;

// A simple MIDlet for testing various alerts.

public class AlertTest extends MIDlet implements CommandListener

{

// An abstract class for our alert tests.

public abstract class AlertRunner

{

protected static final int ONE_SECOND = 1000;

protected static final int FIVE_SECONDS = 5000;

public AlertRunner(String title)

{

_title = title;

}

public abstract Alert doAlert();

public String getTitle()

{

return _title;

}

public String toString()

{

return getTitle();

}

private String _title;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航