我使用Xmlpullparser来解析资产文件夹中的xml 这是代码
public class FragmentImg extends Fragment {
static final String KEY_EMP = "emp";
static final String KEY_NAME = "name";
static final String KEY_GENDER = "gender";
static final String KEY_AGE = "age";
List<HashMap<String,String>> imgHashmap;
List<ClassImg> imgList = null;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_img, container, false);
ImgActivity activity = (ImgActivity) getActivity();
String uri = "list_img.xml";
GridView gv_img = (GridView)view.findViewById(R.id.gridViewImg);
try {
XmlPullParserImg parser_Img = new XmlPullParserImg();
imgList = parser_Img.parse(getActivity().getAssets().open(uri));
BinderDataImg bd_img = new BinderDataImg(getActivity(), imgHashmap);
gv_img.setAdapter(bd_img);
gv_img.setOnItemClickListener(new AdapterView.OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
Intent i = new Intent();
i.setClass(getActivity(), ImgDetail.class);
startActivity(i);
}
});
} catch (IOException e) {
e.printStackTrace();
}
return view;
}
public class XmlPullParserImg {
private ClassImg c_i;
private String text;
public XmlPullParserImg() {
danhsachList = new ArrayList<ClassImg>(); }
public List<ClassImg> parse(InputStream is) {
XmlPullParserFactory factory = null;
XmlPullParser parser = null;
try {
imgHashmap = new ArrayList<HashMap<String,String>>();
HashMap<String,String> map = null;
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("KEY_EMP")) {
c_i = new ClassImg();
map = new HashMap<String,String>();
}
break;
case XmlPullParser.TEXT:
text = parser.getText();
break;
case XmlPullParser.END_TAG:
if (tagname.equalsIgnoreCase("KEY_EMP")) {
imgList.add(c_ds);
imgHashmap.add(map);
} else if (tagname.equalsIgnoreCase(KEY_NAME)) {
c_i.setName(text);
map.put(KEY_NAME, text);
} else if (tagname.equalsIgnoreCase(KEY_GENDER)) {
c_i.setGender(text);
map.put(KEY_GENDER, text);
} else if (tagname.equalsIgnoreCase(KEY_AGE)) {
c_i.setAge(text);
map.put(KEY_AGE, text);
break;
default:
break;
}
eventType = parser.next();
}
} catch (Exception e) {
e.printStackTrace();
}
return imgList;
}
}
}
一切正常,之后,我将xml上传到dropbox
这是网址https://www.dropbox.com/s/lh2ucpbvpqloa3e/list_img.xml
如何用我的代码解析它?
谢谢你的阅读。
答案 0 :(得分:0)
试试这个
URL url=new URL("https://www.dropbox.com/s/lh2ucpbvpqloa3e/list_img.xml");
HttpURLConnection http=(HttpURLConnection)url.openConnection();
http.setDoInput(true);
http.connect();
InputStream is=http.getInputStream();
之后,您可以将inputstream分配给setData()函数
parser.setInput(is, null);
你已编写的其他代码