我在主要活动中使用的工具栏如下:
<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>
并且我在mainactivty上放置了一个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);
}
});
现在,我已将片段添加到我的主要活动中。但是我确保mainactivty的工具栏在片段上始终可见。现在我面临的问题是,当我单击任何工具栏图像视图或按钮时,都没有响应。我尝试使用静态方法,但无法找到解决方案。我知道如果我们创建菜单文件会更容易实现,但是还有其他方法可以做到,而无需更改我的mainactivty工具栏
答案 0 :(得分:0)
您可以使用以下代码从Toolbar
访问Fragment
:
final AppCompatActivity act = (AppCompatActivity) getActivity();
if (act.getSupportActionBar() != null) {
Toolbar toolbar = (Toolbar) act.getSupportActionBar().getCustomView();
}
来自here。
答案 1 :(得分:0)
您将视图保存在工具栏中。更好的方法是使用约束布局,并将视图放置在工具栏的顶部。看来您无法单击按钮,因为工具栏重叠了您的视图。
尝试:
<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>