#android
#Android
Вопрос:
package com.devinfotech.glind.activity;
import android.app.ProgressDialog;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.GridLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.Toolbar;
import android.util.Log;
import android.view.View;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.JsonArrayRequest;
import com.devinfotech.glind.R;
import com.devinfotech.glind.adapter.GalleryAdapter;
import com.devinfotech.glind.app.AppController;
import com.devinfotech.glind.model.Image;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
private String TAG = MainActivity.class.getSimpleName();
private static final String endpoint = "http://api.androidhive.info/json/glide.json";
private ArrayList<Image> images;
private ProgressDialog pDialog;
private GalleryAdapter mAdapter;
private RecyclerView recyclerView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
recyclerView = (RecyclerView) findViewById(R.id.recycler_view);
pDialog = new ProgressDialog(this);
images = new ArrayList<>();
mAdapter = new GalleryAdapter(getApplicationContext(), images);
RecyclerView.LayoutManager mLayoutManager = new GridLayoutManager(getApplicationContext(), 2);
recyclerView.setLayoutManager(mLayoutManager);
recyclerView.setItemAnimator(new DefaultItemAnimator());
recyclerView.setAdapter(mAdapter);
recyclerView.addOnItemTouchListener(new GalleryAdapter.RecyclerTouchListener(getApplicationContext(), recyclerView, new GalleryAdapter.ClickListener() {
@Override
public void onClick(View view, int position) {
Bundle bundle = new Bundle();
bundle.putSerializable("images", images);
bundle.putInt("position", position);
FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
SlideshowDialogFragment newFragment = SlideshowDialogFragment.newInstance();
newFragment.setArguments(bundle);
newFragment.show(ft, "slideshow");
}
@Override
public void onLongClick(View view, int position) {
}
}));
fetchImages();
}
private void fetchImages() {
pDialog.setMessage("Downloading json...");
pDialog.show();
JsonArrayRequest req = new JsonArrayRequest(endpoint,
new Response.Listener<JSONArray>() {
@Override
public void onResponse(JSONArray response) {
Log.d(TAG, response.toString());
pDialog.hide();
images.clear();
for (int i = 0; i < response.length(); i ) {
try {
JSONObject object = response.getJSONObject(i);
Image image = new Image();
image.setName(object.getString("name"));
JSONObject url = object.getJSONObject("url");
image.setSmall(url.getString("small"));
image.setMedium(url.getString("medium"));
image.setLarge(url.getString("large"));
image.setTimestamp(object.getString("timestamp"));
images.add(image);
} catch (JSONException e) {
Log.e(TAG, "Json parsing error: " e.getMessage());
}
}
mAdapter.notifyDataSetChanged();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.e(TAG, "Error: " error.getMessage());
pDialog.hide();
}
});
// Adding request to request queue
AppController.getInstance()
.addToRequestQueue(req);
}
}
package com.devinfotech.glind.app;
import android.app.Application;
import android.text.TextUtils;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.toolbox.Volley;
/**
* Created by Lincoln on 04/04/16.
*/
public class AppController extends Application {
public static final String TAG = AppController.class
.getSimpleName();
private RequestQueue mRequestQueue;
private static AppController mInstance;
@Override
public void onCreate() {
super.onCreate();
mInstance = this;
}
public static synchronized AppController getInstance() {
return mInstance;
}
public RequestQueue getRequestQueue() {
if (mRequestQueue == null) {
mRequestQueue = Volley.newRequestQueue(getApplicationContext());
}
return mRequestQueue;
}
public <T> void addToRequestQueue(Request<T> req, String tag) {
// set the default tag if tag is empty
req.setTag(TextUtils.isEmpty(tag) ? TAG : tag);
getRequestQueue().add(req);
}
public <T> void addToRequestQueue(Request<T> req) {
req.setTag(TAG);
getRequestQueue().add(req);
}
public void cancelPendingRequests(Object tag) {
if (mRequestQueue != null) {
mRequestQueue.cancelAll(tag);
}
}
}
Ошибка:
10-10 13:01:02.030 23482-23482/? E/dalvikvm: не удалось создать символическую ссылку /storage/internalsd на /storage/emulated/ legacy: файл существует 10-10 13:01:02.210 23482-23482/com.devinfotech.glind E/dalvikvm: не удалось найти класс ‘android.graphics.drawable.RippleDrawable’, на который ссылается метод android.support.v7.widget.AppCompatImageHelper.hasOverlappingRendering 10-10 13:01:02.300 23482-23482 /? E / AndroidRuntime: ФАТАЛЬНОЕ ИСКЛЮЧЕНИЕ: основной процесс: com.devinfotech.glind, PID: 23482 java.lang.RuntimeException: Не удается запустить activity ComponentInfo{com.devinfotech.glind/com.devinfotech.glind.activity.MainActivity}: java.lang.Исключение NullPointerException в android.app.ActivityThread.performLaunchActivity(ActivityThread.java: 2299) в android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2349) в android.app.ActivityThread.access $ 800(ActivityThread.java:151) в android.app.ActivityThread $ H.handleMessage(ActivityThread.java: 1243) на android.os.Handler.DispatchMessage(Handler.java: 102) на android.os.Looper.loop(Looper.java: 136) на android.app.ActivityThread.main(ActivityThread.java: 5372) на java.lang.reflect.Method.invokeNative (собственный метод) в java.lang.reflect.Method.invoke(Method.java: 515) в com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:970) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java:786) в dalvik.system.NativeStart.main(роднойМетод) Вызвано: java.lang.Исключение NullPointerException в com.devinfotech.glind.activity.MainActivity.Извлекаемые изображения (MainActivity.java: 123) в com.devinfotech.glind.activity.MainActivity.onCreate(MainActivity.java: 75) на android.app.Activity.performCreate(Activity.java: 5258) на android.app.Instrumentation.callActivityOnCreate(Instrumentation.java: 1099) на android.app.ActivityThread.performLaunchActivity(ActivityThread.java: 2239) на android.app.ActivityThread.handleLaunchActivity(ActivityThread.java: 2349) на android.app.ActivityThread.access $ 800(ActivityThread.java:151) на android.app.ActivityThread$ H.handleMessage(ActivityThread.java: 1243) на android.os.Handler.DispatchMessage(Handler.java: 102) на android.ос.Looper.loop(Looper.java: 136) в android.app.ActivityThread.main(ActivityThread.java: 5372) в java.lang.reflect.Method.invokeNative (собственный метод) в java.lang.reflect.Method.invoke(Method.java: 515) в com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:970) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java:786) в dalvik.system.NativeStart.main(роднойМетод)
Комментарии:
1. Вы смотрели на эту строку
com.devinfotech.glind.activity.MainActivity.fetchImages(MainActivity.java:123)
2. да, но знаете ли вы решение, которое меня так смущает
3. // Добавление запроса в очередь запросов AppController.getInstance() .addToRequestQueue(запрос);