无法在 Kotlin 中将 CustomToolbar 替换为 ActionBar

Unable to replace CustomToolbar with ActionBar in Kotlin

提问人:Nima Khalili 提问时间:5/29/2023 最后编辑:Nima Khalili 更新时间:5/29/2023 访问量:307

问:

我创建了一个自定义并将其放置在活动中,但出现此错误:Toolbar

java.lang.IllegalStateException: Activity com.example.citiesdistance.feature.main.MainActivity@3a04806 does not have an ActionBar set via setSupportActionBar()

注意:

当我将默认值设置为显示自定义正常工作时,但它在默认值下。ActionBarToolbarActionBar

CustomToolbar 类:

class BaseToolbar(context: Context, attrs: AttributeSet?) : FrameLayout(context, attrs) {
    private lateinit var binding: ViewToolbarBinding

    init {
        if (attrs != null) {
            binding = ViewToolbarBinding.inflate(LayoutInflater.from(context), this, true)
            val attr = context.obtainStyledAttributes(attrs, R.styleable.BaseToolbar)
            val title = attr.getString(R.styleable.BaseToolbar_bs_title)
            if (!title.isNullOrEmpty())
                binding.toolbarTitleTv.text = title
            attr.recycle()
        }
    }
}

view_toolbar.xml (CustomToolbar Xml):

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="56dp"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools">
    <ImageView
        android:id="@+id/backBtn"
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:scaleType="centerInside"
        android:background="?selectableItemBackgroundBorderless"
        android:layout_gravity="center_vertical|start"
        android:layout_marginStart="16dp"
        app:srcCompat="@drawable/ic_back"/>
    <TextView
        android:id="@+id/toolbarTitleTv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_vertical|start"
        android:layout_marginStart="56dp"
        style="?textAppearanceHeadline6"
        tools:text="نام صفحه"/>
</FrameLayout>

activity_main.xml :

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    style="@style/WidthHeight.All.BothMatchParent"
    tools:context=".feature.main.MainActivity">

    <com.google.android.material.appbar.AppBarLayout
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <com.example.view.BaseToolbar
            android:id="@+id/testToolBar"
            android:layout_width="match_parent"
            android:layout_height="?actionBarSize"
            app:bs_title="Page 1" />
    </com.google.android.material.appbar.AppBarLayout>

</androidx.constraintlayout.widget.ConstraintLayout>

主题.xml :

<resources xmlns:tools="http://schemas.android.com/tools">
    <!-- Base application theme. -->
    <style name="Theme.CitiesDistance" parent="Theme.MaterialComponents.DayNight.NoActionBar">
        .
        .
        .
    </style>
</resources>

默认 ActionBar :

enter image description here

NoActionBar :

enter image description here

安卓 kotlin actionbar -工具栏 安卓 视图绑定

评论


答:

0赞 Ariczek 5/29/2023 #1

我认为您唯一缺少的步骤是 https://developer.android.com/develop/ui/views/components/appbar/setting-up 中的第 5 步

在 Activity 的 onCreate() 方法中,调用 Activity 的 setSupportActionBar() 方法,并传递 Activity 的工具栏。

评论

0赞 Nima Khalili 5/29/2023
setSupportActionBar() 需要一个 ToolBar,但我的 CustomToolbar 类扩展了 FrameLayout
0赞 Ariczek 5/29/2023
您可以在工具栏中定义自定义布局 - digitalocean.com/community/tutorials/...
0赞 Nima Khalili 5/29/2023
我需要这个类进行依赖注入
0赞 Ariczek 5/29/2023
为什么需要它从 FrameLayout 继承?也许它可以从工具栏继承(也是 ViewGroup)......
0赞 Nima Khalili 5/29/2023
我只想为工具栏中的某些特定活动添加额外的项目,我可以用 FrameLayout 来完成。此外,据我所知,这是最好的方法。
0赞 Nima Khalili 5/29/2023 #2

我用 DarkActionBar 设置默认值,然后添加 Activity 的 onCreate 方法。 如果我找到更好的答案,我会更新答案。ActionBarsupportActionBar?.hide()

<resources xmlns:tools="http://schemas.android.com/tools">
    <!-- Base application theme. -->
    <style name="Theme.CitiesDistance" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
        .
        .
        .
    </style>
</resources>


override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    supportActionBar?.hide()
}