質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Q&A

解決済

1回答

2000閲覧

ViewPagerとViewAdapterを関連付けたい

youha

総合スコア1

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

1グッド

2クリップ

投稿2020/08/21 07:55

編集2020/08/21 12:32

前提・実現したいこと

Kotlinの学習を始めたばかりのものです
書籍としてはじめてのAndroidプログラミング第4版を使用しています
書籍の情報が古いのもあって、非推奨になっているものも多数ありました、現在の書き方等わからないことがたくさんあるため、どなたか教えていただけませんか?

フラグメントを用いたスライドショーアプリを作っています
ViewPagerとViewAdapterを関連付けるところでつまっています(MainActivityの一番下の箇所)

発生している問題・エラーメッセージ

Type mismatch. Required:(RecyclerView.Adapter<RecyclerView.ViewHolder!>?..RecyclerView.Adapter<*>?) Found:MainActivity.MyAdapter

該当のソースコード

MainActivity

1import androidx.appcompat.app.AppCompatActivity 2import android.os.Bundle 3import androidx.fragment.app.Fragment 4import androidx.fragment.app.FragmentManager 5import androidx.fragment.app.FragmentPagerAdapter 6import kotlinx.android.synthetic.main.activity_main.* 7 8class MainActivity : AppCompatActivity() { 9 10 class MyAdapter(fm: FragmentManager) : FragmentPagerAdapter(fm, BEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENT) {//classのなかにclassを入れることを、ネストしたクラスと言う 11 //わざわざネストする意義としては、MyAdapterはMyActivity専用のクラスである、と言うことが一見してわかるからである 12 private val resources = listOf(//フラグメントに表示する画像を10枚保持するためのInt型リスト 13 R.drawable.slide00, R.drawable.slide01, 14 R.drawable.slide02, R.drawable.slide03, 15 R.drawable.slide04, R.drawable.slide05, 16 R.drawable.slide06, R.drawable.slide07, 17 R.drawable.slide08, R.drawable.slide09 18 ) 19 20 override fun getCount(): Int {//総ページ数を返すメソッド 21 return resources.size 22 } 23 24 override fun getItem(position: Int): Fragment {//引数にページ番号を受け取り、対応するフラグメントを戻り値として返す 25 return ImageFragment.newInstance(resources[position])//newInstanceはクラスImageFragmentのコンパニオンオブジェクトだから、この記述が可能 26 } 27 } 28 29 override fun onCreate(savedInstanceState: Bundle?) { 30 super.onCreate(savedInstanceState) 31 setContentView(R.layout.activity_main) 32 pager.adapter = MyAdapter(supportFragmentManager) 33 } 34}

ImageFragment

1package com.websarva.wings.android.myslidesshow 2 3import android.os.Bundle 4import androidx.fragment.app.Fragment 5import android.view.LayoutInflater 6import android.view.View 7import android.view.ViewGroup 8import kotlinx.android.synthetic.main.fragment_image.* 9 10val IMG_RES_ID = "IMG_RES_ID"//Bundleクラスで値を保存するために使用するkey 11 12class ImageFragment : Fragment() { 13 14 override fun onCreateView( 15 inflater: LayoutInflater, container: ViewGroup?, 16 savedInstanceState: Bundle? 17 ): View? { 18 // Inflate the layout for this fragment 19 return inflater.inflate(R.layout.fragment_image, container, false) 20 } 21 22 companion object {// Javaでいうstatic methodで、このクラスImageFragment内でのmethod 23 //ImageFragment内のImageViewに関するリソースIDを取得して、生成したimageFragmentのインスタンスを返す 24 fun newInstance(imageResourceID: Int) : ImageFragment { 25 val bundle = Bundle() 26 bundle.putInt(IMG_RES_ID, imageResourceID)//上で生成したBundleインスタンスにidを書き込んでいる 27 val imageFragment = ImageFragment() 28 imageFragment.arguments = bundle//フラグメントのデータをargumentsに保存する 29 return imageFragment 30 } 31 } 32 33 private var imgResID: Int? = null 34 35 override fun onCreate(savedInstanceState: Bundle?) {//Bundleから値を取り出す処理 36 super.onCreate(savedInstanceState) 37 arguments?.let{//安全よびだし演算子とスコープ関数()letを使用して、nullではないことを確認している 38 //letを使うことで、スコープ(特定の名前で参照される範囲を限定)でき、いちいちarguments?.getIntと書かずにit.getIntと書くことができる 39 imgResID = it.getInt(IMG_RES_ID) 40 } 41 } 42 43 override fun onActivityCreated(savedInstanceState: Bundle?) { 44 super.onActivityCreated(savedInstanceState) 45 imgResID?.let { 46 imageView.setImageResource(it)//imgResIdに保存しておいた画像リソースIDを使用して、フラグメント内のImageViewに画像を設定 47 } 48 } 49}

activity_main.xml

1<?xml version="1.0" encoding="utf-8"?> 2<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:app="http://schemas.android.com/apk/res-auto" 4 xmlns:tools="http://schemas.android.com/tools" 5 android:layout_width="match_parent" 6 android:layout_height="match_parent" 7 tools:context=".MainActivity"> 8 9 <androidx.viewpager2.widget.ViewPager2 10 android:id="@+id/pager" 11 android:layout_width="0dp" 12 android:layout_height="0dp" 13 app:layout_constraintBottom_toBottomOf="parent" 14 app:layout_constraintEnd_toEndOf="parent" 15 app:layout_constraintStart_toStartOf="parent" 16 app:layout_constraintTop_toTopOf="parent" /> 17</androidx.constraintlayout.widget.ConstraintLayout>

fragment_image.xml

1<?xml version="1.0" encoding="utf-8"?> 2<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:app="http://schemas.android.com/apk/res-auto" 4 xmlns:tools="http://schemas.android.com/tools" 5 android:layout_width="match_parent" 6 android:layout_height="match_parent" 7 tools:context=".ImageFragment"> 8 9 <ImageView 10 android:id="@+id/imageView" 11 android:layout_width="match_parent" 12 android:layout_height="match_parent" 13 android:scaleType="centerCrop" 14 tools:src="@tools:sample/backgrounds/scenic" /> 15</FrameLayout>

試したこと

AdapterにBEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENTというTagを付けました

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

Yuki-Naka👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

keicha_hrs

2020/08/21 12:28 編集

pagerで示されるコンポーネントが、ViewPagerではなくRecyclerViewになっていると思われるのですが、どのようなレイアウトXMLになっているのでしょうか。
youha

2020/08/21 12:41

RecyclerViewに関してはまだ学習中のテキストに出てきてないようです 目次にもありませんでした
guest

回答1

0

ベストアンサー

ViewPager2を従来のViewPagerのように記述すると、確かに質問のようなエラーになるようですね。私もViewPager2はあまり詳しく知らなかったのだけど、下記参考資料を参考にした修正をMainActivityに少し加えれば対応できそうです。

(参考資料)ViewPager2 を使用してフラグメント間をスライドする | Android Developers

kotlin

1class MainActivity : AppCompatActivity() { 2 3 // ☆☆☆修正点1 MyAdapterのコンストラクターの引数型をFragmentActivityにし、FragmentStateAdapterを継承する 4 // (FragmentStateAdapterはRecycleView.Adapterを継承している) 5 class MyAdapter(fa: FragmentActivity) : FragmentStateAdapter(fa) {//classのなかにclassを入れることを、ネストしたクラスと言う 6 //わざわざネストする意義としては、MyAdapterはMyActivity専用のクラスである、と言うことが一見してわかるからである 7 private val resources = listOf(//フラグメントに表示する画像を10枚保持するためのInt型リスト 8 R.drawable.slide00, R.drawable.slide01, 9 R.drawable.slide02, R.drawable.slide03, 10 R.drawable.slide04, R.drawable.slide05, 11 R.drawable.slide06, R.drawable.slide07, 12 R.drawable.slide08, R.drawable.slide09 13 ) 14 15 // ☆☆☆修正点2 オーバーライドする関数を合わせる 16 // getItemCount()とcreateFragment() 17 18 override fun getItemCount(): Int {//総ページ数を返すメソッド 19 return resources.size 20 } 21 22 override fun createFragment(position: Int): Fragment { 23 return ImageFragment.newInstance(resources[position])//newInstanceはクラスImageFragmentのコンパニオンオブジェクトだから、この記述が可能 24 } 25 } 26 27 override fun onCreate(savedInstanceState: Bundle?) { 28 super.onCreate(savedInstanceState) 29 setContentView(R.layout.activity_main) 30 pager.adapter = MyAdapter(this) // ☆☆☆修正点3 MyAdapterの引数をthisにする 31 } 32}

これで対応できないでしょうか?

投稿2020/08/21 13:10

編集2020/08/21 13:46
keicha_hrs

総合スコア6768

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

youha

2020/08/21 13:50

ありがとうございます! 動きました! ちゃんとAndroid Developersを読みこむと書いてあるのですね
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問