WAP之家:为您提供最全最新的WAP技术,CP.SP.3G等行业资讯。 WAP之家交流论坛全新开放 点击进入>>
WAP资讯 | 3G动态 | SP动态 | 运营商动态 | 内容商动态 | 制造商动态 | 论坛讨论>> 每次自动访问
WAP技术 | WAP源码 | 手机编程 | 手机源码 | 无线技术 | J2ME技术 | 手机软件 添加到收藏夹
IVR技术 | SP资料 | SMS MMS技术 | 商业方案 | IVR下载 | 书籍教程 | 工具软件 语言:繁體中文

WAP之家技术文章J2ME技术J2ME基础如何在MIDP中实现图片放缩

如何在MIDP中实现图片放缩
作者:Jagie  来源:csdn  发布时间:2005-9-6 9:33:01
无论在midp1.0还是在midp2.0中,系统都没有给我们提供对图片进行伸缩操作的api.但是其实我们只要在程序代码中略施小计,就能达到这个效果,只是效果要比美术做出来的图片,呵呵,差多啦,同时也会造成性能损失。伸缩图片的构造原理就是简单沿x,y轴按比例放缩,比如说我们需要把一张16*16的png图片转化成一张32*32的图片,那么我们可以先对该图片做一个水平方向上的拉伸操作,然后再把水平拉伸后的图片按垂直方向再做一次拉伸操作。做拉伸操作时,比如水平方向上,我们需要构造一张32*16的mutable Image,获取其Graphics,利用该Graphics,绘制该mutable Graphics的每一列像素,这一列像素就来自于原始图片中的按比例对应的某一列像素。垂直方向上的拉伸操作也是如法炮制。因为是一种按比例的对应关系,图像的缩小操作也可按该办法进行。
效果如下图所示

原始图片

图片放大为全屏幕大小

图片缩小为原来的1/4大小
好了,我们来看代码
  1. import javax.microedition.lcdui.Graphics;
  2. import javax.microedition.lcdui.Image;
  3. /**
  4. * 图像工具类
  5. * @author Jagie
  6. *
  7. */
  8. public class ImageUtil {
  9. /**
  10. * 图像放缩方法
  11. * @param srcImage 原始的Image对象
  12. * @param newW 放缩后的Image的宽度
  13. * @param newH 放缩后的Image的高度
  14. * @return 放缩后的Image对象
  15. */
  16. public static final Image scale (Image srcImage, int newW, int newH) {
  17. int srcW = srcImage.getWidth();
  18. int srcH = srcImage.getHeight();
  19. //先做水平方向上的伸缩变换
  20. Image tmp = Image.createImage(newW, srcH);
  21. Graphics g = tmp.getGraphics();
  22. for (int x = 0; x < newW; x++) {
  23. g.setClip(x, 0, 1, srcH);
  24. //按比例放缩
  25. g.drawImage(srcImage,x-x*srcWnewW,0,Graphics.LEFT | Graphics.TOP);
  26. }
  27. //再做垂直方向上的伸缩变换
  28. Image dst = Image.createImage(newW, newH);
  29. g = dst.getGraphics();
  30. for (int y = 0; y < newH; y++) {
  31. g.setClip(0, y, newW, 1);
  32. //按比例放缩
  33. g.drawImage(tmp,0,y-y*srcHnewH,Graphics.LEFT | Graphics.TOP);
  34. }
  35. return dst;
  36. }
  37. }


也许有同学会提出疑问,既然是按x,y方向按等比例放缩,那我写成这样岂不是代码更简洁:


  1. public static final Image scale2(Image srcImage, int newW, int newH) {
  2. int srcW = srcImage.getWidth();
  3. int srcH = srcImage.getHeight();
  4. Image dst=Image.createImage(newW,newH);
  5. Graphics g=dst.getGraphics();
  6. for (int x = 0; x < newW; x++) {
  7. for (int y = 0; y < newH; y++) {
  8. g.setClip(x, y, 1, 1);
  9. g.drawImage(srcImage, x-x*srcWnewW, y - y * srcH / newH, Graphics.LEFT
  10. | Graphics.TOP);
  11. }
  12. }
  13. return dst;
  14. }


这种做法效果上和前者无异,但是并不可取,只要算算它的时间复杂度就知道,基本上是前者的平方。在我的机器上,做一次全屏幕的放缩操作,前者耗时60ms,而后者耗时7150ms。


作者简介


陈万飞,网名Jagie,培训师,爱好java技术.可通过chen_cwf@163.com与他联系
[] [返回上一页] [打 印]
文章评论

用户名: 查看更多评论

分 值:100分 85分 70分 55分 40分 25分 10分 0分

内 容:

         (注“”为必填内容。) 验证码: 验证码,看不清楚?请点击刷新验证码