Android 프로 그래 밍 은 ActionBar 의 홈 아이콘 애니메이션 전환 효 과 를 실현 합 니 다.

이 사례 는 안 드 로 이 드 프로 그래 밍 이 ActionBar 의 홈 아이콘 애니메이션 전환 효 과 를 실현 하 는 것 을 보 여 준다.여러분 께 참고 하도록 공유 하 겠 습 니 다.구체 적 으로 는 다음 과 같 습 니 다.
Material Design 의 중요 한 특징 중 하 나 는 사 이 드 슬라이드 메뉴 가 펼 쳐 지 거나 닫 힐 때 Action Bar 의 홈 아이콘 도 애니메이션 으로 전환 하 는 것 입 니 다.본 사례 에서 실현 하고 자 하 는 것 은 바로 이 효과 이다.그림 과 같다.

이 효 과 를 실현 하려 면 몇 단계 만 필요 합 니 다.
1.우선,이 페이지 의 레이아웃 은 DrawerLayout 입 니 다.코드 는 다음 과 같 습 니 다.

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:id="@+id/main_drawer"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <!--     -->
  <FrameLayout
    android:id="@+id/main_content"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
  <!--     -->
  <android.support.design.widget.NavigationView
    android:id="@+id/main_navigation"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    app:headerLayout="@layout/navigation_header"
    app:menu="@menu/menu_drawer" />
</android.support.v4.widget.DrawerLayout>

2.프로그램 에 Actionbar 화살표 단추 스타일 을 지정 합 니 다.즉,다음 코드 의 DrawerArrowStyle 입 니 다.

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
</style>
<style name="DrawerArrowStyle" parent="Widget.AppCompat.DrawerArrowToggle">
    <item name="spinBars">true</item>
    <item name="color">@android:color/white</item>
</style>

그리고 AppTheme 을 manifest 의 application 태그 에 적용 합 니 다.
3.Activity 는 AppCompatActivity 에서 계승 한 다음 onCreate 방법 에 코드 를 추가 합 니 다(Toolbar 를 사용 하면 이와 유사 합 니 다).

ActionBar mActionBar = getSupportActionBar();
if (mActionBar != null) {
  mActionBar.setDisplayHomeAsUpEnabled(true);
  mActionBar.setHomeButtonEnabled(true);
}
//    home  “  ”   “  ”       (   xml       )
drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, R.string.drawer_open, R.string.drawer_close);
drawerLayout.setDrawerListener(drawerToggle);

4.Activity 의 onPostCreate 에 다음 코드 를 추가 하고 새로 고침 이 필요 한 다른 곳 에서 drawerToggle.syncState()방법 을 호출 합 니 다.

@Override
protected void onPostCreate(Bundle savedInstanceState) {
    super.onPostCreate(savedInstanceState);
    drawerToggle.syncState();
}

더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.,,,,,,,
본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기