我已将最小SDK从21更改为19,在19API中,抽屉活动中的切换按钮和工具栏(打开菜单)不会显示。
API> 21 toggle and Toolbar appear
API 19 nothing shows
我的布局是两个文件:app_bar_main和content_main
APP_BAR_MAIN
H
CONTENT_MAIN
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 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"
tools:context="gchmapplications.hermandadsantamariavictoria.Actividades.MainActivity">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:popupTheme="@style/AppTheme.PopupOverlay" />
</android.support.design.widget.AppBarLayout>
<include layout="@layout/content_main" />
</android.support.design.widget.CoordinatorLayout>
我已经尝试过其他配置并且它没有解决问题,但问题是它存在于视图中但是在屏幕外显示出来。因为当我更改某些值时,它会显示在工具栏enter image description here
上方我已经注意到,从零开始我在API19中遵循的教程(https://www.youtube.com/watch?v=0aLFCpaoOZo)并没有出现,所以问题就在于我所遵循的教程。
答案 0 :(得分:1)
尝试使用下面提到的代码来实现您的实施:
<android.support.v4.widget.DrawerLayout 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:id="@+id/myDrawerLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="in.assamtourism.atdc_demo.MainActivity"
tools:openDrawer="left">
<RelativeLayout>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#b71c1c"
android:theme="@style/DrawerArrowStyle"
app:layout_scrollFlags="scroll|enterAlways" />
<TextView
android:id="@+id/textview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:background="#8c000000"
android:gravity="center_horizontal"
android:padding="20dp"
android:textColor="#ffffff"/>
<!--All Your UI codes should be here-->
</RelativeLayout>
<android.support.design.widget.NavigationView
android:id="@+id/myNavigationView"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="left"
android:fitsSystemWindows="true"
app:itemIconTint="#e53935"
app:headerLayout="@layout/nav_header" />
</android.support.v4.widget.DrawerLayout>
然后在“YourActivity”.java文件中声明这些变量:
Toolbar toolbar;
DrawerLayout drawerLayout;
NavigationView navigationView;
在onCreate方法中,添加以下行:
toolbar = findViewById(R.id.toolbar);
drawerLayout = findViewById(R.id.myDrawerLayout);
navigationView = findViewById(R.id.myNavigationView);
navigationView.getMenu().clear();
navigationView.inflateMenu(R.menu.nav_menu);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setHomeButtonEnabled(true);
ActionBarDrawerToggle drawerToggle = new ActionBarDrawerToggle(
this,
drawerLayout,
toolbar,
R.string.navigation_drawer_open,
R.string.navigation_drawer_close
);
drawerLayout.addDrawerListener(drawerToggle);
drawerToggle.syncState();
完成后,根据您的需要进行定制。
答案 1 :(得分:1)
我不知道为什么现在布局比底部的屏幕大。在大多数视图中我有5dp的余量,现在它削减了边距和一点内容......
这是实际的activity_main
<android.support.v4.widget.DrawerLayout 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:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:openDrawer="start">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@color/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay"
app:titleTextColor="@android:color/white" />
<android.support.design.widget.CoordinatorLayout
android:id="@+id/contenedor"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
android:theme="@style/AppTheme.AppBarOverlay" />
</android.support.design.widget.CoordinatorLayout>
</LinearLayout>
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:itemIconTint="#981e73be"
app:itemTextColor="#2E2E2E"
app:menu="@menu/activity_main_drawer" />