片段中的工具栏单击侦听器



我在主要活动中使用工具栏,如下所示:

<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="51dp"
android:layout_marginBottom="4dp"
android:background="@android:color/background_light"
android:clipToPadding="false"
android:elevation="0dp"
app:contentInsetEnd="0dp"
app:contentInsetLeft="0dp"
app:contentInsetRight="0dp"
app:contentInsetStart="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="4dp"
android:layout_marginRight="4dp"
android:orientation="horizontal">
<ImageView
android:id="@+id/navBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
app:srcCompat="@drawable/ic_dehaze_black_24dp" />
<TextView
android:id="@+id/toolbar_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:fontFamily="sans-serif-condensed-medium"
android:text="Shop"
android:textAlignment="viewEnd"
android:textColor="@android:color/black"
android:textSize="26sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0" />
<TextView
android:id="@+id/toolbar_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginRight="6dp"
android:layout_weight="1"
android:fontFamily="sans-serif-condensed-medium"
android:text="Lyft"
android:textAlignment="viewStart"
android:textColor="#E91E63"
android:textSize="26sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0" />
<ImageView
android:id="@+id/searchBTn"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_gravity="center"
android:layout_marginRight="8dp"
app:srcCompat="@drawable/ic_search_black_24dp" />


</LinearLayout>
</android.support.v7.widget.Toolbar>

我已经在我的主活动上放置了一个 onclick 方法,如下所示:

ImageView searchBTn=findViewById(R.id.searchBTn);
searchBTn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent sendtoSearch=new Intent(MainActivity.this,Search.class);
startActivity(sendtoSearch);
}
});

现在我已经在我的主要活动中添加了片段。但是我已经确保主活动的工具栏始终在片段上可见。现在我面临的问题是,当我单击任何工具栏图像视图或按钮时,都没有响应。我尝试使用静态方法,但找不到解决方案。我知道如果我们创建一个菜单文件会更容易实现,但是有没有其他方法可以在不更改我的主活动工具栏的情况下做到这一点

您可以使用以下代码从Fragment访问Toolbar

final AppCompatActivity act = (AppCompatActivity) getActivity();
if (act.getSupportActionBar() != null) {
Toolbar toolbar = (Toolbar) act.getSupportActionBar().getCustomView();
}

取自这里。

您将视图保存在工具栏中。更好的方法是使用约束布局并将视图放在工具栏的顶部。看起来您无法单击按钮,因为工具栏与您的视图重叠。

尝试:

<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"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="51dp"
android:layout_marginBottom="4dp"
android:background="@android:color/background_light"
android:clipToPadding="false"
android:elevation="0dp"
app:contentInsetEnd="0dp"
app:contentInsetLeft="0dp"
app:contentInsetRight="0dp"
app:contentInsetStart="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0"/>
<LinearLayout
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/mainToolbar"
app:layout_constraintBottom_toBottomOf="@+id/mainToolbar"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginTop="4dp"
android:layout_marginRight="4dp"
android:orientation="horizontal">
<ImageView
android:id="@+id/navBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
app:srcCompat="@drawable/ic_dehaze_black_24dp" />
<TextView
android:id="@+id/toolbar_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:fontFamily="sans-serif-condensed-medium"
android:text="Shop"
android:textAlignment="viewEnd"
android:textColor="@android:color/black"
android:textSize="26sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0" />
<TextView
android:id="@+id/toolbar_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginRight="6dp"
android:layout_weight="1"
android:fontFamily="sans-serif-condensed-medium"
android:text="Lyft"
android:textAlignment="viewStart"
android:textColor="#E91E63"
android:textSize="26sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0" />
<ImageView
android:id="@+id/searchBTn"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_gravity="center"
android:layout_marginRight="8dp"
app:srcCompat="@drawable/ic_search_black_24dp" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>