作者:Eric文章来源:http://gceclub.sun.com.cn
在J2ME中,Profiles是用于定义用户接口API的。MIDP定义了两种这类API,被称为高层API和底层API,高层API要求你使用面向事务的抽象来定义用户接口做什么。你并没有对屏幕上所画的东西的真正控制—实现选择了对设备最佳的实现方式。高层API对于所有MIDP-enabled设备是可移植的,并且它是真正适合于商业应用的。更多有关高层API的信息请关注后续的J2ME技术Tips。
底层API是为游戏开发人员准备的。不像高层API,底层API赋予你完全的对屏幕和事件的访问能力,这种访问能力是有代价的,因为这样你将负责画屏幕上所显示的任何东西。你可以在同一个应用中同时使用高层API和底层API。把应用看作一副扑克牌,同时只能有一张是可见的(很象J2SE平台上提供的java.awt.CardLayout类所提供的功能),每张卡片,可以被认为是MIDP词汇中的屏幕(Screen),对于每一张或者使用高层API,或者使用底层API,但是不能同时使用。唯一的例外是使用命令对象,将在Tips的后面探讨。
在MIDlet中使用底层API,是不许编写一个Canvas类的扩展类:
// Simple canvas
import javax.microedition.lcdui.*;
import javax.microedition.midlet.*;
public class MyCanvas extends Canvas {
private MIDlet midlet;
public MyCanvas( MIDlet midlet ){
this.midlet = midlet;
}
protected void paint( Graphics g ){
g.setColor( 255, 255, 255 );
g.fillRect( 0, 0, getWidth(), getHeight() );
g.setColor( 0, 0, 0 );
g.drawString( "Hello there!", getWidth()/2, 0,
g.TOP | g.HCENTER );
}
}
所有的用户接口类都在javax.microedition.lcdui包中。注意你也需要到如javax.microedition.midlet包,因为你将为每一个canvas传递一个引用到MIDlet。你的canvas子类必须实现一个绘图方法,它是被系统调用来重画屏幕的。绘图方法是通过Graphics对象传递的,Graphics对象是用来定义标准的画图方法的,而这些都是你所需要的,例如,drawArc,drawLine,drawRect和drawString等。MyCanvas范例简单的将屏幕画成白色来清楚屏幕,然后在屏幕的中间上方画一条线(黑色的)。
你激活一个canvas是通过调用MIDlet的Display对象的setCurrent方法来实现的。通常在应用的MIDlet类的startApp方法中调用:
// Simple MIDlet
import javax.microedition.midlet.*;
public class MyMIDlet extends MIDlet {
private Display display;
private MyCanvas canvas;
public MyMIDlet(){
display = Display.getDisplay( this );
canvas = new MyCanvas( this );
}
protected void startApp(){
display.setCurrent( canvas );
}
protected void pauseApp(){
}
protected void destroyApp( boolean unconditional ){
}
public void exit(){
destroyApp( true );
notifyDestroyed();
}
}
尽管这个MIDlet能工作,它有一个问题:没有明显的方式可以从它退出。你需要引导用户以某种方式输入。有两种方式可以实现:使用行输入事件或使用命令事件。
n Canvas允许使用行输入事件,是通过覆盖canvas类定义的适当的事件发送方法来实现的。事件生成的可用方法有:
n 按键(keyPressed,keyRepeated,和keyReleased)
n 使用指针(pointerPressed,pointerDragged和pointerReleased)如果指针在设备上可以使用的话
n 显示canvas(showNotify,hideNotify)
例如,你可以增加一种方式结束应用,通过在canvas中定义一个keyPressed事件:
protected void keyPressed( int keyCode ){
((MyMIDlet) midlet).exit();
}
在所有的键盘事件中,keycode识别按键并激发事件。正值表示Unicode字符,而负值是一个键无法被直观的转换成Unicode。为了避免区分哪一个键表示哪一个,这种有不同设备确定的问题,canvas类为常用键定义了一些限制。特别是,它定义了抽象游戏行为(UP, DOWN, LEFT, RIGHT, FIRE, GAME_A, GAME_B, GAME_C, 和GAME_D)它们的键盘代码映射图可以实时定义。在它初始化过程中,设备可以调用canvas.getGameAction来确定哪种键盘映射更适合于操作。
你可以定义一个基础类,就象:
public abstract class GameCanvas extends Canvas {
protected MIDlet midlet;
protected int fireKey;
protected int leftKey;
protected int rightKey;
protected int upKey;
protected int downKey;
public GameCanvas( MIDlet midlet ){
this.midlet = midlet;
fireKey = getKeyCode( FIRE );
leftKey = getKeyCode( LEFT );
rightKey = getKeyCode( RIGHT );
upKey = getKeyCode( UP );
downKey = getKeyCode( DOWN );
}
}
然后,扩展它,就象:
public class MyCanvas extends GameCanvas {
private String message = "Press any key";
public MyCanvas( MIDlet midlet ){
super( midlet );
}
protected void paint( Graphics g ){
g.setColor( 255, 255, 255 );
g.fillRect( 0, 0, getWidth(), getHeight() );
g.setColor( 0, 0, 0 );
g.drawString( message, getWidth()/2, 0,
g.TOP | g.HCENTER );
}
protected void keyPressed( int keyCode ){
if( keyCode == fireKey ){
message = "FIRE";
} else if( keyCode == leftKey ){
message = "LEFT";
} else if( keyCode == rightKey ){
message = "RIGHT";
} else if( keyCode == upKey ){
message = "UP";
} else if( keyCode == downKey ){
message = "DOWN";
} else {
message = getKeyName( keyCode );
}
repaint();
}
}
指针事件是可选项,因为不是所有的MIDP可用的设备都支持指针。你可以在指针有效的时候来使用它的优势。但是你不能够假设它是可用的。你可以检测是否指针事件可以被激发,通过调用Canvas.hasPointerEvents。指针事件方法获取指针的位置:
protected void pointerPressed( int x, int y ){
// do something here
}
另一种方法引导用户输入是为canvas附加命令。一个命令是一个动作的抽象表现。它有一个用户定义的label, type和优先级。设备使用type映射命令到相应的键或按钮。例如,如果设备有一个标准的OK键,指定一个命令类型为OK,确保OK按钮激发这个命令。有效的类型有BACK, CANCEL, EXIT, HELP, ITEM, OK, SCREEN, 和STOP。一部分或全部这些都可以映射到相同的按键或按钮。这样,当有冲突的时候,设备可以使用优先级来适当的排列命令次序。优先级是一个正整数,1是最高优先级。
命令是使用Command类来创建的,如下:
Command exitCommand = new Command( "Exit", Command.SCREEN, 1 );
你使用addCommand方法来将命令添加到canvas:
canvas.addCommand(exitCommand);
你必须注册命令,使用:
setListener: canvas.setListener( listener ) ;
监听器必须实现CommandListener借口。它对于主要的MIDlet类来实现CommandListener来获取exit命令是通用的,如下所示:
// Simple MIDlet
import javax.microedition.midlet.*;
public class MyMIDlet extends MIDlet implements
CommandListener {
private Display display;
private MyCanvas canvas;
private Command exitCommand = new Command(
"Exit", Command.SCREEN, 1 );
public MyMIDlet(){
display = Display.getDisplay( this );
canvas = new MyCanvas( this );
canvas.addCommand( exitCommand );
canvas.setListener( this );
}
protected void startApp(){
display.setCurrent( canvas );
}
protected void pauseApp(){
}
protected void destroyApp( boolean unconditional ){
}
public void exit(){
destroyApp( true );
notifyDestroyed();
}
public void commandAction( Command c, Displayable d ){
if( c == exitCommand ){
exit();
}
}
}
CommandListener接口定义一个简单的方法,commandAction,它在一个命令被激发的时候被调用。一个激发命令对象的引用被传入,同时一个显示对象的引用被引用,它是在它被激活的时候开始动作的。(同样的命令可以在不同的canvas中共享并且高层API也是一样可以被共享的)当然,监听器负责实际执行这个动作。
分享到:
相关推荐
在"JAVA实现CLDC与MIDP底层编程的代码"中,我们可以期待找到以下内容: 1. **CLDC的底层实现**:可能包括CLDC的虚拟机实现细节,例如如何优化内存管理和线程调度,以及如何在有限资源下运行Java程序。 2. **MIDP的...
Java源码:JAVA实现CLDC与MIDP底层编程的代码 在移动设备领域,Java技术扮演了重要的角色,特别是对于功能手机和早期的智能手机。CLDC(Connected Limited Device Configuration)和MIDP(Mobile Information ...
这个压缩包“JAVA实现CLDC与MIDP底层编程的代码.zip”很可能包含了示例代码,帮助开发者理解如何在这些平台上进行编程。 CLDC是Java ME的基础,定义了运行时环境和最小的API集,适用于内存和处理能力有限的设备。它...
这个压缩包"基于Java的实现CLDC与MIDP底层编程的代码.zip"显然包含了使用Java进行CLDC和MIDP编程的相关示例代码。 CLDC是Java Micro Edition (Java ME) 的一部分,设计用于资源有限的设备,如功能手机、智能卡或者...
在这个"基于java的实现CLDC与MIDP底层编程的代码.zip"压缩包中,可能包含的是实际的Java源代码示例,这些示例展示了如何在CLDC和MIDP环境中进行程序开发。代码可能涉及以下几个方面: 1. **用户界面**:MIDP提供了...
MIDP建立在CLDC之上,提供了更高级的应用程序接口,包括图形用户界面(GUI)、存储管理、设备访问和网络通信等。 **3. 用户界面组件** MIDP2.0的用户界面主要基于 Lightweight User Interface Toolkit (LWUIT) 或者...
本程序员指南讲述如何使用诺基亚Java 用户界面 API 。诺基亚用户界面 API 是标准的移动 信息设备描述(Mobile Information Device Profile ,MIDP )API (请参阅 [MIDP])的扩 展,它在诺基亚支持MIDP-1.0 的电话...
开发者可以深入研究这些源码来理解 MIDP 的工作原理,学习如何使用特定 API,或者进行自定义扩展。 通过研究 Sun 公司的源代码,开发者可以获取到官方实现的洞察,这对于理解底层机制、调试问题以及优化性能都非常...
**CLDC MIDP底层编程实例源码解析** `CLDC`(Connected Limited Device Configuration)和`MIDP`(Mobile Information Device Profile)是Java ME(Micro Edition)平台的一部分,主要用于开发移动设备上的应用程序...
1. **提高开发效率**:通过使用API,开发者可以快速构建应用程序,而不必关注底层实现细节。 2. **代码重用**:API中的方法和类可以在多个项目中重用,减少重复工作量。 3. **易于维护**:当需要对特定功能进行更新...
midp2.0fcs(Final Candidate Specification)文件可能包含了Midp2.0的最终候选规范文档,开发者可以通过它了解完整的API接口和编程指南,以遵循标准进行应用开发。 再者,trustedmidl_windows-i686这一标签提示了...
`javax.microedition.lcdui`包提供了用于构建用户界面的基本类和接口,这些类和接口对于创建MIDlet(基于MIDP的应用程序)至关重要。 ##### 2.1 Display 类 `Display`类是所有显示操作的核心。它负责管理当前屏幕...
Java GameAPI 是Java Micro Edition (JME) 或者 Lightweight Java Game Library (LWJGL) 中用于游戏开发的一组特定接口和类。这些API专为移动设备和嵌入式系统设计,提供了高效的游戏编程功能,简化了游戏逻辑的实现...
开发者可以利用这些API快速构建游戏,而无需从底层实现所有功能。 **j2me部分源代码.rar** 这个RAR文件包含了J2ME的示例源代码,可能涵盖了各种应用场景,如网络连接、文件操作、蓝牙通信等。开发者可以通过阅读和...
在J2ME中,事件处理是通过实现特定的Canvas类或使用Listener接口来完成的。Canvas是用户界面的基本元素,可以自定义绘图和响应用户输入。事件处理通常涉及到键盘事件、触摸屏事件和系统事件。 3. **...
在Java手机游戏编程中,MIDP(Mobile Information Device Profile)是关键的开发框架,它构建在CLDC(Connected Limited Device Configuration)之上,为小型移动设备如手机和寻呼机提供应用程序接口。MIDP图形设计...
在Java MIDP中,CLDC(Connected Limited Device Configuration)作为底层运行环境,负责内存管理和基础的系统服务,而MIDP则提供更高级的应用框架和API。 该应用系统可能包含以下几个核心组成部分: 1. 用户界面...
2.3 MIDP 用户接口API.................. 10 3 一个范例:TICTACTOE MIDLET .............................................................................................................................. ...