XmlPullParser 学习笔记

来源:互联网 发布:生死狙击桐哥刷枪软件 编辑:程序博客网 时间:2024/06/06 09:13
 在j2me有限的资源上去解释xml是比较慢的,所以j2se上的xml类库是不适合用在j2me上,而XmlPullParser 用起来速度快,而且包也很小。
需求是解释一个标准的wml。比如:
xml 代码
 
  1. <?xml version="1.0"?>  
  2. <!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" "http://www.wapforum.org/DTD/wml_1.1.xml">  
  3. <wml>  
  4. <card id="index" title="天速">  
  5. <p align="center">天速科技</p>  
  6. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=03020047"> 动漫天下 </a></p>  
  7. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=03020048&amp;SPURL=http://211.155.31.143/t/viewPic.a?picId=1308"> 国色天香 </a></p>  
  8. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=04070717&amp;SPURL=http://211.155.31.143/eb/allBook.a">  风月书斋 </a></p>  
  9.   
  10. </card> </wml>  

上面是个简单的wml源文件。不过现在的wap网站差不都这样,基本上没有script,跟html上的各个控件。所以能解释上面的文档,基本上都是可以满足我的需求的。

现在我们来看下我们解释wml的java文件
java 代码
  1. import java.io.ByteArrayInputStream;
  2. import java.io.IOException;
  3. import java.io.InputStreamReader;
  4. import org.kxml2.io.KXmlParser;
  5. import org.xmlpull.v1.XmlPullParser;
  6. import org.xmlpull.v1.XmlPullParserException;
  7. import org.xmlpull.v1.XmlPullParserFactory;
  8. public class Test {
  9. //private static String xml = " apple"
  10. // + "orange" + "pear";
  11. private static String xml =""
  12. +"
  13. +"\"http://www.wapforum.org/DTD/wml_1.1.xml\">"
  14. +""
  15. +""
  16. +"

    天速科技

    "
  17. +"

    动漫天下

    "
  18. +"

    国色天香

    "
  19. +"

    风月书斋

    "
  20. +" ";
  21. public static void main(String args[])
  22. throws XmlPullParserException, IOException {
  23. ByteArrayInputStream bin = new ByteArrayInputStream(xml.getBytes());
  24. InputStreamReader in = new InputStreamReader(bin);
  25. KXmlParser parser = new KXmlParser();
  26. parser.setInput(in);
  27. int eventType = parser.getEventType();
  28. while (eventType != XmlPullParser.END_DOCUMENT) {
  29. if (eventType == XmlPullParser.START_DOCUMENT) {
  30. //System.out.println("Start document:");
  31. else if (eventType == XmlPullParser.END_DOCUMENT) {
  32. //System.out.println("End document");
  33. else if (eventType == XmlPullParser.START_TAG) {
  34. System.out.println(" " + parser.getName());
  35. //System.out.println("Start Count: " + parser.getAttributeCount());
  36. int size = parser.getAttributeCount();
  37. for(int i=0; i
  38. System.out.println(" " + parser.getAttributeName(i));
  39. System.out.println(" " + parser.getAttributeValue(i));
  40. }
  41. else if (eventType == XmlPullParser.END_TAG) {
  42. System.out.println(" " + parser.getName());
  43. else if (eventType == XmlPullParser.TEXT) {
  44. System.out.println(" " + parser.getText());
  45. }
  46. eventType = parser.next();
  47. }
  48. }


现在解释下上面的东西,
XmlPullParser 只是个规范,可以到http://xmlpull.org/ 下载。我们来看看这个规范要求我们做些什么。
里面主要的方法有
java 代码
  1. //定义一个事件采用回调的方式,直到读取xml完毕。
  2. public int getEventType() throws XmlPullParserException ;
  3. //遍历下一个事件,返回一个事件的类型
  4. public int next() throws XmlPullParserException, IOException
  5. //得到当前Tag名字
  6. public String getName();
  7. //获取文本
  8. public String getText();
  9. //得到当前Tag下面的属性数量
  10. public int getAttributeCount() ;
  11. //得到当前Tag下面指定位置的属性名称
  12. public String getAttributeName(int index);
  13. //得到当前Tag下面指定位置的属性植
  14. public String getAttributeValue(int index);

我们理解了XmlPullParser 可以自己实现一个XmlPullParser。不过java世界里好东西就是多。已经有人帮我们做了。
啊就是kxml。
这个API本身很简单。当时要把一个完整的wml解释并绘制在手机上还是要花相当的时间的。