Android 프로 그래 밍 은 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();
}
더 많은 안 드 로 이 드 관련 내용 에 관심 이 있 는 독자 들 은 본 사이트 의 주 제 를 볼 수 있다.,,,,,,,본 고 에서 말 한 것 이 여러분 의 안 드 로 이 드 프로 그래 밍 에 도움 이 되 기 를 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.