Не удалось создать экземпляр одного или нескольких классов - PullRequest
0 голосов
/ 30 октября 2018

У меня две проблемы с моим приложением:

Я использую BottomNavigationView и RecyclerView. Я уже создал адаптер и т. Д.

Первая проблема, как показано на рисунке:

enter image description here

Если я изменяю зависимость на более низкую версию, такую ​​как 27.1.0, ошибка исчезает, но возникают некоторые другие, когда я хочу запустить приложение, поэтому я изменил его обратно.

Кроме того, когда я запускаю свое приложение и для высоты RecyclerView я использую что-то вроде 400dp (вместо match_parent или wrap_content), оно показывает значения ТОЛЬКО после того, как я нажму на что-то из BottomNavigation (что я не понимаю) - Если я использую match_parent или wrap_content, список вообще не отображается (даже когда я щелкаю куда-то).

Это мой RecyclerView

<?xml version="1.0" encoding="utf-8"?>

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!-- Main content -->

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/bottom_navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_gravity="bottom"
        android:background="?android:attr/windowBackground"
        app:menu="@menu/navigation" />

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="400dp"
        android:layout_alignParentStart="true"
        android:layout_alignParentTop="true"
        android:padding="4dp"
        android:scrollbars="vertical">

    </android.support.v7.widget.RecyclerView>

</RelativeLayout>

Это адаптер:

package com.example.enis.myapplication.Adapter;

import android.app.Activity;
import android.content.Context;
import android.support.annotation.NonNull;
import android.support.design.widget.Snackbar;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import com.example.enis.myapplication.Model.Event;
import com.example.enis.myapplication.R;

import java.util.ArrayList;


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

    private ArrayList<Event> events;

    public static class ViewHolder extends RecyclerView.ViewHolder{

        int currentItem;
        TextView date, description, location,name;
        ImageView image;

        public ViewHolder(View itemView){
            super(itemView);
            date= (TextView) itemView.findViewById(R.id.date);
            description =(TextView) itemView.findViewById(R.id.description);
            name =(TextView) itemView.findViewById(R.id.name);
            location = (TextView)itemView.findViewById(R.id.location);
            image = (ImageView) itemView.findViewById(R.id.image);

            itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    int pos = getAdapterPosition();
                    Snackbar.make(v, "clicked on " + pos,Snackbar.LENGTH_LONG ).setAction("Action",null).show();
                }
            });
        }
    }

    public EventAdapter(ArrayList<Event> events) {
        this.events = events;
    }


    public ArrayList<Event> getEvents() {
        return events;
    }

    public void setEvents(ArrayList<Event> events) {
        this.events = events;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {


        View itemview = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.cardview_layout,viewGroup,false);
        ViewHolder v = new ViewHolder(itemview);

        return v;

    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder viewHolder, int i) {

        viewHolder.date.setText(events.get(i).getDate());
        viewHolder.description.setText(events.get(i).getDescription());
        viewHolder.location.setText(events.get(i).getLocation());
        viewHolder.name.setText(events.get(i).getName());
        Log.d("Test", String.valueOf(viewHolder.name.getText()));
    }


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

}

Вот как создается экземпляр адаптера и т. Д.

    private BottomNavigationView.OnNavigationItemSelectedListener mOnNavigationItemSelectedListener
            = new BottomNavigationView.OnNavigationItemSelectedListener() { 

@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {return true;}
            };


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_navigation);

        mRecyclerView = (RecyclerView) findViewById(R.id.recycler_view);
        BottomNavigationView navigation = (BottomNavigationView) findViewById(R.id.bottom_navigation);
        navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener);

        mRef = mDatabase.getReference();

        events = new ArrayList<>();


        LinearLayoutManager llm = new LinearLayoutManager(this);
        llm.setOrientation(LinearLayoutManager.VERTICAL);
        mRecyclerView.setLayoutManager(llm);    

        getEventsFromDB();

        adapter = new EventAdapter(events);
        mRecyclerView.setAdapter(adapter);

    }

Зависимости Gradle:

    compileSdkVersion 28
    defaultConfig {
        applicationId "com.example.enis.myapplication"
        minSdkVersion 15
        targetSdkVersion 27
        versionCode 1

        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        vectorDrawables.useSupportLibrary = true
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

repositories {
    jcenter()
    mavenCentral()
    google()
}


dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])


    implementation 'com.android.support:cardview-v7:28.0.0'
    implementation 'com.android.support:recyclerview-v7:28.0.0'
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support:design:28.0.0'
    implementation 'com.facebook.android:facebook-android-sdk:[4,5)'
    implementation 'com.android.support.constraint:constraint-layout:1.1.2'
    implementation 'com.squareup.picasso:picasso:2.5.2'
    implementation 'com.android.support:support-vector-drawable:28.0.0'
    implementation 'com.iarcuschin:simpleratingbar:0.1.3'
    implementation 'com.google.firebase:firebase-database:11.8.0'
    implementation 'com.google.firebase:firebase-auth:11.8.0'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'

}

Надеюсь, кто-нибудь сможет мне помочь :) С наилучшими пожеланиями

РЕДАКТИРОВАТЬ: я не знаю, если это полезно, но я сделал это с ListView, и он работал нормально.

1 Ответ

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

Я действительно нашел решение для моей второй проблемы:

Я должен был использовать:

adapter.notifyDataSetChanged();

Я не могу сказать, почему именно он показал что-то после того, как я нажал на BottomNavigation, но теперь он отображает Контент. Но все же есть визуальные проблемы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...