2017-09-09 32 views
1

私はKotlinで最初のAndroidアプリケーションを作成しています。私はRecyclerViewでonItemClickListnerを実装しようとしていますが、Androidスタジオ3.0ではkotlinを使用していますが、私はmovieListFRagmentを持っている:recyclerViewでonItemClickLitsnerを実装するKotlin -android

class MoviesListFragment : Fragment() {  
    private var mListener: OnFragmentInteractionListener? = null 
    private var movieList = ArrayList<Movies>() 
    private var mAdapter: MoviesRecyclerAdapter? = null  
    override fun onCreateView(inflater: LayoutInflater?, container: ViewGroup?, 
           savedInstanceState: Bundle?): View? { 
     // Inflate the layout for this fragment 
     return inflater!!.inflate(R.layout.fragment_movies_list, container, false) 
    }  
    override fun onViewCreated(view: View?, savedInstanceState: Bundle?) { 
     super.onViewCreated(view, savedInstanceState)  
     mAdapter = MoviesRecyclerAdapter(movieList) 
     val mLayoutManager = LinearLayoutManager(this.activity)  
     recyclerView!!.layoutManager = mLayoutManager 
     recyclerView!!.itemAnimator = DefaultItemAnimator() 
     recyclerView!!.adapter = mAdapter  
     prepareMoviesData() } 

    interface OnFragmentInteractionListener { 
     // TODO: Update argument type and name 
     fun onFragmentInteraction(uri: Uri) 
    }  
    private fun prepareMoviesData() { 
     var movie = Movies("Mad Max: Fury Road", "Action & Adventure", "2015") 
     movieList.add(movie)  
     movie = Movies("Inside Out", "Animation, Kids & Family", "2015") 
     movieList.add(movie) 
     movie = Movies("Star Wars:The Force Awakens", "Action", "2015") 
     movieList.add(movie) 
     mAdapter!!.notifyDataSetChanged() 
    } 
} 

とアダプタMoviesRecyclerAdapter:

class MoviesRecyclerAdapter(private val moviesList: List<Movies>) : RecyclerView.Adapter<MoviesRecyclerAdapter.MyViewHolder>() { 


    class MyViewHolder(view: View ) : RecyclerView.ViewHolder(view) ,View.OnClickListener { 

     var title: TextView = view.findViewById<TextView>(R.id.title) 
     var year: TextView = view.findViewById<TextView>(R.id.year) 
     var genre: TextView = view.findViewById<TextView>(R.id.genre) 
    } 

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder { 
     val itemView = LayoutInflater.from(parent.context) 
       .inflate(R.layout.movie_list_row, parent, false) 

     return MyViewHolder(itemView) 
    } 

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) { 
     val Movies = moviesList[position] 
     holder.title.text = Movies.title 
     holder.genre.text = Movies.genre 
     holder.year.text = Movies.year 

    } 

    override fun getItemCount(): Int { 
     return moviesList.size 
    } 
} 

他のアクティビティを開くには、リスト内の項目をユーザーがクリックしたとき、私はする必要があり、クリーナー、最高のものですそうする方法。

答えて

1

クリックコールバックとしてlambdaを使用できます。

その後、
var onItemClick: (Int) -> Unit = {} 

onCreateViewHolder中:アダプタのクラスプロパティとして

adapter.onClick = { position -> 
    // do something here 
} 

itemView.setOnClickListener { 
    onItemClick(viewHolder.getAdapterPosition()) 
} 

といけないあなたのフラグメントからのコールバックを設定することを忘れ

関連する問題