作者:林刚 文章来源:http://blogs.sun.com/lirincy
关键字:优化 paint J2ME, 局部刷新,局部重画,图片
我们经常会遇到这样的问题,在模拟器上跑得很好的程序在实际的手机上却很慢,甚至运行不了,这大多数是因为重画机制的使用不当所致,J2ME中的paint()函数起到了画屏幕的作用,往往在需要动画的情况下非常频繁地需要调用,而且在一些低端手机或移动设备上面,对于paint()函数的频繁调用会引起相应时间长甚至无法正常工作等问题。所以,对于paint()函数的优化就显得特别重要。这里,我们提出几点优化paint()函数的方法和注意事项,在编程中大家可以参考:
1.不要在paint()函数当中使用耗时的操作,比如:
try{
Image image_Splash = Image.createImage("/back.png");
g.drawImage(image_Splash, 0, 0,Graphics.TOP | Graphics.LEFT);
}
catch(Exception ex) {
}
其中的创建图片的方法由于需要IO操作非常费时,因此要尽量避免,创建操作只在初始化的时候做一遍。
2.使用像素较小的图片,一般来书,颜色种类少的图片显示时间就少,因此,尽量避免使用256色以上的图片,一些色调丰富,过度缓慢的图片往往需要 多种像素来满足需求,因此,尽量使用卡通图片,或者转换成256或16色的图片,会减少绘图时间。
3.局部刷新, 每次的重画repaint()都要调用paint(),而并不是每一次repaint()都要重画整个屏幕,因此有时候之需要重画部分屏幕即可,这又有两种方法可以实现,第一种是利用Clip,Clip是一个矩形的绘图区域,当重绘时,仅仅重绘这个区域以内的内容,而不管其他部分,因此可以节省操作,可 以通过setClip()等函数设定绘图区域。
另外可以通过repaint( x,y,width,height )来重画指定的某一个区域,这个函数实际上也是设定了某一个重绘Clip(),不过使用起来会更加方便。
4.减少repaint()的次数,尽量只在产生作用的时候才重画。
5.将paint()函数的部分内容提到外面来做,使得重画减少计算量和操作。
6.使用双缓存技术,某些设备本身就支持双缓存技术,判断设备是否支持双缓存可以用Canvas类的isDoubleBuffered()方法。实现双缓存可以使用Image 类的可变图像技术。如,利用:
image = Image.createImage( width, height );
Graphics g = image.getGraphics();
来建立一个可变图像,它和Canvas一样都能够得到Graphics绘图对象的绘制。而且可以不在paint()函数里面,这一点非常重要。可以在init()中放入绘图语句,或者放到一个单独的函数中,把图片绘制到屏幕外缓冲当中,然后在paint()函数中仅仅是把这个Image绘制到当前的Canvas里面了,这样就可以节省很多计算操作。比如:
public void paint(Graphics g){
g.translate(x - g.getTranslateX(), y - g.getTranslateY());//设置当前坐标系统
g.drawImage(image,0,0,g.TOP|g.LEFT);
g.translate(x - g.getTranslateX(), y - g.getTranslateY());//改回原来的坐标系统
}
分享到:
相关推荐
本文将深入探讨J2ME中旋转图形的核心知识点,包括使用的基本函数、步骤以及示例代码。 J2ME的图形渲染主要通过`Graphics`类来实现,它提供了一系列的方法用于绘制和操作2D图形。在J2ME中,我们可以使用`translate()...
首先,Canvas是J2ME中的一个关键类,它提供了直接在设备屏幕上进行图形绘制的能力。Canvas提供了以下几个主要方法: 1. `getGameAction(int keyCode)`:将硬件按键的编码转换为游戏动作,使得开发者可以以抽象的...
在这些事件的处理函数中,可以获取到当前坐标,并在 `Graphics` 对象上绘制线条,连接起始坐标和当前坐标,从而形成用户的绘画轨迹。 总的来说,这个J2ME画图程序利用了 `Canvas` 类提供的基本绘图能力,结合 `...
J2ME中的时间处理主要依赖于`System.currentTimeMillis()`函数,它返回自1970年1月1日00:00:00 GMT以来的毫秒数。这个值可以用来计算两个时间点之间的差值,从而实现计时和定时功能。 1. **使用`Thread.sleep()`...
在这个项目中,开发者利用J2ME的技术实现了一个经典的游戏——贪吃蛇。贪吃蛇游戏是一个简单但具有挑战性的游戏,玩家通过控制蛇的方向来吃食物,每次吃到食物,蛇的长度会增加,如果蛇头碰到边界或者自己的身体,...
- **延迟初始化**:不在构造函数中一次性初始化所有资源,而是按需加载,减少构造函数中的内存峰值。 - **关闭未使用的资源**:及时关闭RMS、网络连接和流,释放相关资源。 2. **图片优化** - **图片压缩**:...
描述中提到,这个九宫格菜单是结合了网上的参考资料和个人项目改编而来的,这表明开发者可能对J2ME的图形用户界面(GUI)组件和事件处理有深入的理解,并且进行了自定义的适配和优化,使其更符合特定应用场景的需求...
此源码集合是《J2ME MIDP手机游戏程序设计》这本书的配套材料,书中的实例和练习代码都被包含在内。通过研究这些源码,读者可以深入理解J2ME游戏开发的基本概念、技术以及实际操作技巧。这些源码通常包括游戏逻辑、...
5. 状态管理:游戏可能包含多个状态(如游戏开始、进行中、结束),这些状态可以通过状态机模式进行管理,每个状态对应一个类或函数,根据游戏流程进行切换。 6. 存储数据:J2ME提供了RecordStore API用于在设备上...
J2ME的`Canvas`类提供了`paint()`方法,我们可以在这个方法中绘制精灵并更新屏幕。 ```java protected void paint(Graphics g) { g.drawImage(characterSprite.getImage(), characterSprite.getX(), ...
综上所述,J2ME源代码中的“运动的小球”程序展示了基础的移动应用开发技术,包括图形绘制、动画实现、事件处理以及性能优化。通过学习和理解这个例子,开发者可以进一步掌握J2ME的编程技能,并应用于更复杂的项目。
在`MyCanvas`的构造函数中,使用`Image.createImage()`方法加载图像。注意,你需要将图像资源路径转换为字节数组流(`InputStream`)。 ```java public MyCanvas() { try { InputStream is = getClass()....
5. **性能优化**:由于J2ME运行在资源有限的设备上,所以性能优化至关重要。这包括减少内存消耗、避免不必要的计算、使用位图操作而非复杂的绘图函数等。 **Symbian S60平台** Symbian S60是一个流行的操作系统,...
- **继承关系**:`Game` 类继承自 `Canvas` 类,这是J2ME中用于绘制图形的基本组件。 - **实现 Runnable 接口**:通过实现 Runnable 接口,`Game` 类可以被线程调用,从而实现游戏循环。 - **成员变量**: - `...
3. **构造函数**:在这个构造函数中,尝试加载背景图片,并检查是否存在异常。如果图片加载失败,则设置`imgexit`为`false`。 4. **`startApp()`方法**:这个方法负责启动应用程序。如果图片加载成功,则显示欢迎...
4. **显示缓冲图像:** 在`paint(Graphics g)`函数中,将`buf`(缓冲屏幕上的图片)复制到真实屏幕上,完成从缓冲到实际显示的过渡。 虽然步骤看起来较为复杂,但双缓冲技术能显著提升游戏的流畅度,避免了屏幕闪烁...
在 `paint()` 方法中,它使用 `Graphics` 对象绘制了一个红色背景和白色 "Hello World!" 文本。 #### ExampleMIDlet 示例分析 - **文件头注释**:这段代码来源于《J2ME in a Nutshell》一书,作者为 Kim Topley,...
通过重写paint()方法和keyPressed()等事件处理函数,可以实现丰富的图形和交互。 3. **切换机制**:在HLUI与LLUI之间切换,一般会使用Command对象。Command可以附加到Form上作为操作选项,当用户选择该Command时,...
例如,你可能在`loop()`函数中使用`System.currentTimeMillis()`来计算间隔时间,并根据需要调用`repaint()`或直接调用`paint()`来刷新画面。 总结起来,J2ME手机开发涉及MIDlet类的生命周期管理和Canvas类的自定义...
渲染部分,J2ME的Graphics类提供了各种绘图函数,如drawRect()用于绘制方块,fillRect()填充颜色,以及setColor()和clearScreen()来改变颜色和清屏。开发者需要在Canvas的paint()方法中完成所有绘图操作,每次游戏...