我对Android很陌生。我需要制作一个应用程序,在从互联网上的 API 检索的概览中显示一堆视频
下面是 API 的样子:
[{"名称":"9VJirQKuoxs","图片":"http://i.ytimg.com/vi/9VJirQKuoxs/default.jpg"}]
这如我所愿。“名称:”是视频 ID,我需要打开 Youtube 应用程序并打开这个特定的视频。我该如何打开这个?我来自 PHP 开发,我无法弄清楚,因为我仍处于“网络”状态。谁能让我走上正确的道路?或者甚至可以提供一个例子?
谢谢,如果我需要提供代码,请询问。
编辑:
我测试打开 youtube 应用程序并且它可以工作,但我需要在已单击的特定项目上打开应用程序。
如何获取点击项目的变量?在这种情况下,变量是一个名为 video_id 的字符串,这是创建变量的部分:
String url = params[0];
HttpClient client = new DefaultHttpClient();
HttpGet get = new HttpGet(url);
HttpResponse response;
response = client.execute(get);
InputStream content = response.getEntity().getContent();
BufferedReader reader;
reader = new BufferedReader(new InputStreamReader(content));
String line;
String json = "";
while ((line = reader.readLine()) != null) {
json += line;
}
JSONArray array = new JSONArray(json);
ArrayList<JSONFields> alData = new ArrayList<JSONFields>();
for (int i = 0; i < array.length(); i++) {
JSONFields data = new JSONFields();
JSONObject obj = array.getJSONObject(i);
data.setName(obj.getString("name"));
data.setUrl(obj.getString("url"));
data.setVideoid(obj.getString("name"));
alData.add(data);
}
System.out.println("Data returned sucessfully");
return alData;
这是 onclick 监听器
listview = (ListView) findViewById(R.id.listView1);
listview.setClickable(true);
listview.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int position, long arg3) {
System.out.println(arg3);
}
});
请帮帮我!
编辑2:
package com.bounty4u.jsonparsing.data;
public class JSONFields {
private String name;
private String url;
private String video_id;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public void setVideoid(String video_id){
this.video_id = video_id;
}
public String getVideoid(){
return video_id;
}
}
这也是错误日志:
05-22 16:44:42.280:E/AndroidRuntime(24776):致命异常:主要 05-22 16:44:42.280:E/AndroidRuntime(24776):java.lang.NullPointerException 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.bounty4u.jsonparsing.MainActivity$1.onItemClick(MainActivity.java:49) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.widget.AdapterView.performItemClick( AdapterView.java:298) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.widget.AbsListView.performItemClick(AbsListView.java:1202) 05-22 16:44:42.280: E/AndroidRuntime( 24776): 在 android.widget.AbsListView$PerformClick.run(AbsListView.java:2975) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.widget.AbsListView$1.run(AbsListView.java: 3657) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Handler.handleCallback(Handler.java:615) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Handler.dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper .java:137) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776 ): at java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): at java.lang.reflect.Method.invoke(Method.java:511) 05 -22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776 ): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik.system.NativeStart.main(Native Method)E/AndroidRuntime(24776): 在 android.os.Handler.dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java :137) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776):在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776):在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik.system.NativeStart.main(Native Method)E/AndroidRuntime(24776): 在 android.os.Handler.dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java :137) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776):在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776):在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik.system.NativeStart.main(Native Method)在 android.os.Handler.dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java:137) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect。 Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): at java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E /AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal。 os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): at dalvik.system.NativeStart.main(Native Method)在 android.os.Handler.dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java:137) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect。 Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): at java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E /AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal。 os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): at dalvik.system.NativeStart.main(Native Method)dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java:137) 05-22 16:44:42.280: E/ AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): at com.android.internal.os.ZygoteInit.main(ZygoteInit .java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik.system.NativeStart.main(Native Method)dispatchMessage(Handler.java:92) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.os.Looper.loop(Looper.java:137) 05-22 16:44:42.280: E/ AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): at com.android.internal.os.ZygoteInit.main(ZygoteInit .java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik.system.NativeStart.main(Native Method)在 android.os.Looper.loop(Looper.java:137) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method .invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik。 system.NativeStart.main(本机方法)在 android.os.Looper.loop(Looper.java:137) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 android.app.ActivityThread.main(ActivityThread.java:4765) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method .invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16 :44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 dalvik。 system.NativeStart.main(本机方法)4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java .lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java: 786) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime( 24776):在 dalvik.system.NativeStart.main(本机方法)4765) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java.lang.reflect.Method.invokeNative(Native Method) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 java .lang.reflect.Method.invoke(Method.java:511) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java: 786) 05-22 16:44:42.280: E/AndroidRuntime(24776): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280: E/AndroidRuntime( 24776):在 dalvik.system.NativeStart.main(本机方法)ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280:E/AndroidRuntime(24776):在 dalvik.system.NativeStart.main(本机方法)ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 05-22 16:44:42.280: E/AndroidRuntime(24776): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 05-22 16:44:42.280:E/AndroidRuntime(24776):在 dalvik.system.NativeStart.main(本机方法)
编辑:
JSONArray array = new JSONArray(json);
ArrayList<JSONFields> alData = new ArrayList<JSONFields>();
for (int i = 0; i < array.length(); i++) {
JSONFields data = new JSONFields();
JSONObject obj = array.getJSONObject(i);
data.setName(obj.getString("name"));
data.setUrl(obj.getString("url"));
data.setVideoid(obj.getString("video_id"));
System.out.println("Video ID: " + obj.getString("video_id"));
alData.add(data);
}