Получение ошибки при рисовании ripple

#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(запрос);