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

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

ただいまの
回答率

90.12%

WearableActivityを継承したクラスのレイアウトにfragmentをinflateできない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 237

EnderMan

score 3

前提・実現したいこと

Wear OS 向けにスタンドアロンアプリを作成しようとしています。
fragmentを使用してレイアウトを作成しようとしたところfragmentを読み込めない旨のエラーメッセージが出力されました。

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

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.myapplicationtest/com.example.myapplicationtest.Main2Activity}: android.view.InflateException: Binary XML file line #10: Binary XML file line #10: Error inflating class fragment
     Caused by: android.view.InflateException: Binary XML file line #10: Binary XML file line #10: Error inflating class fragment
     Caused by: android.view.InflateException: Binary XML file line #10: Error inflating class fragment
     Caused by: android.app.Fragment$InstantiationException: Trying to instantiate a class com.example.myapplicationtest.BlankFragment that is not a Fragment
   Caused by: java.lang.ClassCastException

該当のソースコード

BlankFragment.kt

package com.example.myapplicationtest

import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup

class BlankFragment : Fragment() {
    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.fragment_blank, container, false)
    }
}


fragment_blank.xml

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
             xmlns:tools="http://schemas.android.com/tools"
             android:layout_width="match_parent"
             android:layout_height="match_parent"
             tools:context=".BlankFragment">
    <TextView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="@string/hello_blank_fragment" />
</FrameLayout>


Main2Activity.kt

package com.example.myapplicationtest

import android.os.Bundle
import android.support.wearable.activity.WearableActivity
import android.view.View
import android.widget.Button

class Main2Activity : WearableActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main2)

        //リスナークラスのインスタンスを生成
        val listener = HelloListener()
        //リソースからボタンの読み込み
        val button_click = findViewById<Button>(R.id.button2)
        //ボタンにリスナを設定
        button_click.setOnClickListener(listener)
    }
    //HalloListenerクラスの定義
    private inner class HelloListener : View.OnClickListener{
        //onClickメソッドの定義
        override fun onClick(view: View){
            //idのR値に応じて処理の分岐
            when(view.id){
                //ボタン動作
                R.id.button2 -> {
                    finish()
                }
            }//End of When
        }
    }
}


activity_main2.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".Main2Activity">
    <fragment
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:name="com.example.myapplicationtest.BlankFragment"
            android:id="@+id/fragment"
            android:layout_marginTop="8dp"
            app:layout_constraintTop_toTopOf="parent" android:layout_marginBottom="8dp"
            app:layout_constraintBottom_toTopOf="@+id/button2" app:layout_constraintStart_toStartOf="parent"
            android:layout_marginStart="8dp" app:layout_constraintEnd_toEndOf="parent" android:layout_marginEnd="8dp"/>
    <Button
            android:text="Button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/button2" android:layout_marginTop="8dp"
            app:layout_constraintTop_toTopOf="parent" android:layout_marginBottom="8dp"
            app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintStart_toStartOf="parent"
            android:layout_marginStart="8dp" app:layout_constraintEnd_toEndOf="parent" android:layout_marginEnd="8dp"/>
</androidx.constraintlayout.widget.ConstraintLayout>

試したこと

ADSのツールで追加したBlankFragmentをMain2Activityのレイアウトに表示させようとしましたがエラーでAppStop。
元アプリはNewProjectで作成できるWear向けBlankAppにMain2Activityを追加してActivity間をボタンで行き来できるようにしただけの状態です。提示したソースのほかにMainActivityとレイアウト/リソース関連ファイルが存在しています。
WearableActivityではなくAppCompatActivityを継承させてスマホ形式で実行した場合すんなりと動いてしまいます。

検索しても恐らくFragmentを扱ううえで基本的なことすぎて原因が判らず助けてください。

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

テスト環境:Wear OS Round Chin API 26 Resolution 300*320:hdpi
ビルド環境: Android Gradle Plugin Version 3.5.0 Gradle Version 5.5.1

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

WearableActivityはFragmentActivityを継承していませんので、サポートライブラリ(もしくはAndroidX)のFragmentを利用することはできません。Android標準のandroid.app.FragmentであればWearableActivityでも利用できますが、こちらは現在非推奨となっています。

ドキュメントによると、WearableActivityは利用せず、AppCompatActivityにAmbientModeの機能を追加する方法がサポートライブラリに用意されていて、現在はこちらが推奨されています。詳しくはドキュメントをご参照ください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/08/22 13:19

    回答ありがとうございます。
    FragmentActivityを継承しているものだとばかり思っていました。
    (Webで拾えるサンプルの殆どが普通にWearableActivityでFragmentを使用していたので。)

    現在の推奨も教えていただきありがとうございます。
    (Wear関連の情報が少なすぎて困っていたので助かりました。)

    キャンセル

  • 2019/08/23 08:35 編集

    回答に追記しましてGoogleのドキュメントが間違っておりAppCompatActivityではなくFragmentActivityを使用するのが正のようです。
    AppCompatActivityはWatchハードウェアをサポートしていないためAppstopエラーとなってしまいます。
    AlwaysOnサンプルのJavaソースはFragmentActivityになっているのですがドキュメントがFragmentActivityに実装しろと書いてるのに提示ソース部分がAppCompatActivity表記になっていました。

    色々と酷いドキュメントです。

    FragmentActivityを使用することで狙った動作を確認できました。

    キャンセル

  • 2019/08/23 12:46

    なるほど、情報ありがとうございます。

    キャンセル

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

  • ただいまの回答率 90.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる