如何使用XmlPullparser解析嵌套元素?

时间:2015-01-16 03:47:32

标签: android xml xml-parsing coordinates android-xmlpullparser

这是我的xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<frames>
<frame>
    <name>FRAME-A</name>
    <coordinatesA>
       <x>75</x>
       <y>75</y>
    </coordinatesA>
    <coordinatesB>
       <x>75</x>
       <y>490</y>
    </coordinatesB>
    <coordinatesC>
       <x>645</x>
       <y>75</y>
   </coordinatesC>
    <coordinatesD>
       <x>1215</x>
       <y>75</y>
    </coordinatesD>
    <coordinatesE>
        <x>0</x>
       <y>0</y>
    </coordinatesE>
    <image>@drawable/frameguideone</image>
</frame>

如何解析坐标内的标签x和y A B C D E标签?我不知道该怎么做。任何人都可以帮我解决这个问题?我在谷歌寻找它但没有得到我的解决方案。

这是我的java解析:

public class XMLPullParserHandler {
List<Employee> frames;
private Employee frame;
private String text;

public XMLPullParserHandler() {
    frames = new ArrayList<Employee>();
}

public List<Employee> getEmployees() {
    return frames;
}

public List<Employee> parse(InputStream is) {
    XmlPullParserFactory factory = null;
    XmlPullParser parser = null;
    try {
        factory = XmlPullParserFactory.newInstance();
        factory.setNamespaceAware(true);
        parser = factory.newPullParser();

        parser.setInput(is, null);

        int eventType = parser.getEventType();
        while (eventType != XmlPullParser.END_DOCUMENT) {
            String tagname = parser.getName();
            switch (eventType) {
            case XmlPullParser.START_TAG:
                if (tagname.equalsIgnoreCase("frame")) {
                    // create a new instance of employee
                    frame = new Employee();
                }
                break;

            case XmlPullParser.TEXT:
                text = parser.getText();
                break;

            case XmlPullParser.END_TAG:
                if (tagname.equalsIgnoreCase("frame")) {
                    // add employee object to list
                    frames.add(frame);
                } else if (tagname.equalsIgnoreCase("name")) {
                    frame.setName(text);
                } else if (tagname.equalsIgnoreCase("coordinates")) {
                    frame.setCoordinates(Integer.parseInt(text));
                } else if (tagname.equalsIgnoreCase("image")) {
                    frame.setImage(text);
                }else if(tagname.equalsIgnoreCase("x")){
                    frame.setX(Integer.parseInt(text));
                }else if(tagname.equalsIgnoreCase("y")){
                    frame.setY(Integer.parseInt(text));
                }
                break;
            default:
                break;
            }
            eventType = parser.next();
        }

    } catch (XmlPullParserException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }
    return frames;
}

}

2 个答案:

答案 0 :(得分:0)

当您读取坐标的开始标记时,请创建一个新的坐标对象。在读取x和y时,请在坐标上设置值。读取结束坐标标记时,请在框架上设置坐标。

答案 1 :(得分:0)

您的代码存在两个问题。

首先,这不会起作用:

if (tagname.equalsIgnoreCase("coordinates")) {
    frame.setCoordinates(Integer.parseInt(text));
}

您必须具有与xml标记相同的名称或使用tagname.contains(&#34; coordinates&#34;)。

其次,x和y将始终等于0,因为您正在使用新值擦除先前的值。所以你的Employee对象应该包含一个Coordinate列表,每当你遇到坐标标记时,你应该创建一个新的Coordinate对象,设置x和y并将它添加到列表中。 这样的事情应该有效:

case XmlPullParser.START_TAG:
    if (tagname.equalsIgnoreCase("frame")) {
        frame = new Employee();
    } 
    else if (tagname.contains("coordinates")) {
        frame.addCoordinate(new Coordinate());
    } 
    break;

case XmlPullParser.END_TAG:
    if (tagname.equalsIgnoreCase("x")) {
        // get the coordinate object created in the START_TAG case
        frame.getLastCoordinates().setX(Integer.parseInt(text));
    }
    else if (tagname.equalsIgnoreCase("y")) {
        frame.getLastCoordinates().setY(Integer.parseInt(text));
    }

希望它有所帮助!