Не удается получить int или double для отображения в RecyclerView после анализа json - PullRequest
0 голосов
/ 01 октября 2018

Когда я просто отображаю строковые данные, кажется, что все нормально, но когда я пытаюсь отобразить int или double, RecyclerView не заполняется.Я вытягиваю из Google местах API JSON.Я думаю, может быть, я использую свой onBindViewHolder()?Спасибо

// MainActivity
private void getJson() {

    String URL = https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=40.7085,-74.003124&opennow&radius=5000&type=restaurant&key=

    JsonObjectRequest root = new JsonObjectRequest(Request.Method.GET, URL, null, new Response.Listener<JSONObject>() {
        @Override
        public void onResponse(JSONObject response) {
            try {
                JSONArray results = response.getJSONArray("results");
                Log.d("RESULTS", String.valueOf(results));
                for(int i = 0; i<results.length(); i++) {
                    JSONObject resultsObj = results.getJSONObject(i);

                    mImageUrls.add(resultsObj.getString("icon"));
                    mTitle.add(resultsObj.getString("name"));
                    //mRating.add(resultsObj.getDouble("rating"));
                    mPriceLevel.add(resultsObj.getInt("price_level"));
                }
                getRecyclerView();

            } catch (JSONException e) {
                e.printStackTrace();
            }
        }
    },new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {

        }
    });

    mRequestQueue.add(root);
}

private void getRecyclerView() {
    // LinearLayoutManager
    recyclerView = findViewById(R.id.recyclerView);
    adapter = new RecyclerViewAdapter(mImageUrls, mTitle, mPriceLevel, this);

    recyclerView.setAdapter(adapter);
    recyclerView.setLayoutManager(new LinearLayoutManager(this));
    recyclerView.setHasFixedSize(true);
}

И класс RecyclerViewAdapter это.

public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.ViewHolder>{

    private static final String TAG = "RecyclerViewAdapter";

    private ArrayList<String> rNames = new ArrayList<>();
    private ArrayList<String> rImageUrls = new ArrayList<>();
    private ArrayList<Double> rRatings = new ArrayList<>();
    private ArrayList<Integer> rPriceLevel = new ArrayList<>();

    private Context mContext;

    public RecyclerViewAdapter(ArrayList<String> image, ArrayList<String> name, ArrayList<Integer> priceLevel, Context context) {//, ArrayList<Double> rating
        this.rImageUrls = image;
        this.rNames = name;
        //this.rRatings = rating;
        this.rPriceLevel = priceLevel;
        mContext = context;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_item, parent, false);
        ViewHolder holder = new ViewHolder(view);
        return holder;
        //return new ViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, final int position) {
        Glide.with(mContext).asBitmap().load(rImageUrls.get(position)).into(holder.image);
        holder.name.setText(rNames.get(position));
        //holder.rating.setText(rRatings.get(position));
        holder.priceLevel.setText(rPriceLevel.get(position));

        holder.parentLayout.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.d(TAG, "onClick: clicked on an image: " + rNames.get(position));
                Toast.makeText(mContext, rNames.get(position), Toast.LENGTH_SHORT).show();
            }
        });
    }

    @Override
    public int getItemCount() {
        return rNames.size(); //we can use rImageUrls/rRatings as well because they are all the same size
    }

    public class ViewHolder extends RecyclerView.ViewHolder{

        ImageView image;
        TextView name;
        TextView rating;
        TextView priceLevel;
        TextView address;
        RelativeLayout parentLayout;

        public ViewHolder(View itemView) {
            super(itemView);
            image = (ImageView) itemView.findViewById(R.id.image);
            name = (TextView) itemView.findViewById(R.id.title);
            //rating = itemView.findViewById(R.id.rating);
            priceLevel = (TextView) itemView.findViewById(R.id.priceLevel);

            parentLayout = itemView.findViewById(R.id.parentLayout);
        }
    }
}

Ответы [ 3 ]

0 голосов
/ 01 октября 2018

Я хотел бы предложить вам создать объект со всеми необходимыми параметрами, а затем передать один список этого объекта в RecyclerViewAdapter.

public class MapElement {
    public String name;
    public String imageUrl;
    public Double rating;
    public Integer price;
}

Затем создайте ArrayList этого объекта, когда получите ответ на вызов функции getJson.Теперь в вашем адаптере просто используйте один список MapElement объекта, чтобы показать данные оттуда.

Модифицированный адаптер должен выглядеть следующим образом.

public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.ViewHolder>{

    private static final String TAG = "RecyclerViewAdapter";

    private ArrayList<MapElement> elements = new ArrayList<>();

    private Context mContext;

    public RecyclerViewAdapter(ArrayList<MapElement> elements, Context context) {
        this.elements = elements;
        mContext = context;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_item, parent, false);
        ViewHolder holder = new ViewHolder(view);
        return holder;
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, final int position) {
        Glide.with(mContext).asBitmap().load(rImageUrls.get(position)).into(holder.image);
        holder.name.setText(elements.get(position).name);
        holder.rating.setText(elements.get(position).rating);
        holder.priceLevel.setText(elements.get(position).price);

        holder.parentLayout.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.d(TAG, "onClick: clicked on an image: " + rNames.get(position));
                Toast.makeText(mContext, elements.get(position).name, Toast.LENGTH_SHORT).show();
            }
        });
    }

    @Override
    public int getItemCount() {
        return elements.size();
    }

    public class ViewHolder extends RecyclerView.ViewHolder{

        ImageView image;
        TextView name;
        TextView rating;
        TextView priceLevel;
        TextView address;
        RelativeLayout parentLayout;

        public ViewHolder(View itemView) {
            super(itemView);
            image = (ImageView) itemView.findViewById(R.id.image);
            name = (TextView) itemView.findViewById(R.id.title);
            rating = itemView.findViewById(R.id.rating);
            priceLevel = (TextView) itemView.findViewById(R.id.priceLevel);

            parentLayout = itemView.findViewById(R.id.parentLayout);
        }
    }
}
0 голосов
/ 01 октября 2018

Сначала вы должны убедиться, что рейтинг, который вы получаете, является двойным значением.Может случиться, что после этой строки выдается исключение

mRating.add(resultsObj.getDouble("rating"))

Также, как @hooray_todd siggested textview принимает только строковое значение, поэтому вам нужно преобразовать данные в строку.

0 голосов
/ 01 октября 2018

Причина в том, что вы не конвертируете Double в String, измените эту строку holder.rating.setText(rRatings.get(position)); на holder.rating.setText(String.valueOf(rRatings.get(position)));

...