1

这是我的 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 BCDE 标签?我不知道该怎么做。任何人都可以帮我解决这个问题吗?我在谷歌中寻找它,但没有得到我的解决方案。

这是我的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;
}

}

4

2 回答 2

0

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

于 2015-01-16T04:00:48.643 回答
0

您的代码有两个问题。

首先,这不起作用:

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

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

其次,x 和 y 将始终等于 0,因为您正在用新值擦除以前的值。因此,您的 Employee 对象应该包含一个坐标列表,每次遇到坐标标签时,您应该创建一个新的 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));
    }

希望它有所帮助!

于 2015-01-16T05:01:25.643 回答