Я получаю не могу создать экземпляр абстрактного класса в предупреждении kotlin? - PullRequest
0 голосов
/ 17 декабря 2018

Я новичок в Котлине.У меня есть два класса, один адаптер и один фрагмент.Когда я хочу вызвать класс адаптера во фрагменте, я получаю следующее предупреждение: cannot create an instance of the abstract class in Kotlin.

Ниже моего фрагмента, где я получаю предупреждение

class FavouriteExercisesFragment : BaseMvpFragment(), FavoriteExerciseView {

    var adapter: FavoriteExerciseAdapter = FavoriteExerciseAdapter()
   // cannot create instance of abstract class in kotlin

Ниже абстрактного класса адаптера

class FavouriteExercisesFragment : BaseMvpFragment(), FavoriteExerciseView {

    var adapter: FavoriteExerciseAdapter = FavoriteExerciseAdapter()
    val presenter: FavoriteExercisePresenter = FavoriteExercisePresenter(this)

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        rootView = inflater.inflate(R.layout.fragment_favorite_ex, container, false)
        return rootView
    }

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)
        initToolbar()
        initList()
        presenter.getFavoriteExercise()
    }

    private fun initList() {
        rvExercise.layoutManager = LinearLayoutManager(context)
        rvExercise.adapter = adapter
        val helper = ItemTouchHelper(object : ItemTouchHelper.SimpleCallback(ItemTouchHelper.UP or ItemTouchHelper.DOWN, ItemTouchHelper.RIGHT) {
            override fun onMove(recyclerView: RecyclerView?, viewHolder: RecyclerView.ViewHolder, target: RecyclerView.ViewHolder): Boolean {
                adapter.onItemMove(viewHolder.adapterPosition, target.adapterPosition)
                return true
            }

            override fun onSwiped(viewHolder: RecyclerView.ViewHolder, direction: Int) {
                val position = viewHolder.adapterPosition
                val item = adapter.data[position]
                adapter.onItemDismiss(viewHolder.adapterPosition)
                presenter.deleteFromFavorite(item, position)
                showEmptyData(adapter.data.isEmpty())

            }
        })
        rvExercise.addItemDecoration(object : RecyclerView.ItemDecoration() {
            override fun getItemOffsets(outRect: Rect, view: View?, parent: RecyclerView, state: RecyclerView.State?) {
                super.getItemOffsets(outRect, view, parent, state)
                val position = parent.getChildAdapterPosition(view)
                if (position == 0) {
                    outRect.top = 58.dp
                } else {
                    outRect.top = 0
                }

            }
        })
        helper.attachToRecyclerView(rvExercise)
        adapter.helper = helper
        adapter.actions = object : FavoriteExerciseAdapter.AdapterAction {
            override fun playExercise(exercise: Exercise) {
                val file = exercise.files.firstOrNull { it.mainFile }
                val uri = file?.getFile() ?: ""

                context?.startActivityFromCenter(VideoActivity.newInstance(context, uri), rootView, VideoActivity.REQUEST_CODE)
            }
        }
    }

    private fun initToolbar() {
        toolbar.setOnNavigateIconClickListener { router.exit() }
        toolbar.setOnToolIconClickListener { openNavDrawer() }
    }

    override fun setFavoriteExercises(exercises: ArrayList<Exercise>) {
        showEmptyData(exercises.isEmpty())
        adapter.addData(exercises)
    }

    override fun showDeleteMessage(item: Exercise, position: Int) {
        val snack = Snackbar.make(rootView, R.string.message_remove_from_favorite, Snackbar.LENGTH_LONG)
        snack.setAction(R.string.action_undo) {
            presenter.addToFavorite(item)
            adapter.addItemOnPosition(item, position)
            showEmptyData(adapter.data.isEmpty())
        }
        snack.show()
    }

    private fun showEmptyData(show: Boolean) {
        tvEmpty.visibility = if (show) View.VISIBLE else View.GONE
        emptyIcon.visibility = if (show) View.VISIBLE else View.GONE
    }
}

Ответы [ 2 ]

0 голосов
/ 18 декабря 2018

Из вашей проблемы я могу догадаться, что FavoriteExerciseAdapter абстрактно.вам нужно добавить новый конкретный класс в ваш проект, например, назвать его MyFavoriteExerciseAdapter.MyFavoriteExerciseAdapter должен расширять FavoriteExerciseAdapter и переопределяет все абстрактные методы FavoriteExerciseAdapter, теперь создаёт экземпляр MyFavoriteExerciseAdapter вместо FavoriteExerciseAdapter:

var adapter: FavoriteExerciseAdapter = MyFavoriteExerciseAdapter()// instantiate MyFavoriteExerciseAdapter
0 голосов
/ 17 декабря 2018

Вы не можете создать экземпляр абстрактного класса.Вы должны удалить abstract из объявления класса или создать новый класс, расширяющий абстрактный класс, и создавать экземпляры этого класса.

...