안 드 로 이 드 모방 위 챗 슬라이딩 종료 활동
원리:
원 리 는 한 마디 로 분명하게 묘사 할 수 있다.Activity 의 dispatchTouchEvent 를 다시 쓰 고 미 끄 러 질 때 Activity 스 택 의 스 택 꼭대기 Activity 의 이전 Activity 의 ContentView 를 스 택 꼭대기 Activity 의 DecorView 에 추가 하여 미 끄 러 지 는 과정 에서 보 기 를 평평 하 게 이동 시 키 고 미끄럼 이 끝 난 후에 앞에서 가 져 온 ContentView 를 이전 Activity 에 돌려 준 다음 finish 현재 Activity.
ActivityStack:
응용 프로그램.activity LifecycleCallbacks 인 터 페 이 스 를 실현 하고 앱 의 응용 프로그램 에 이 창 고 를 등록 합 니 다.앱 의 Activity 가 추가 되 거나 삭 제 될 때 인터페이스 에 있 는 방법 을 되 돌려 줍 니 다.
public class ActivityBackStack implements Application.ActivityLifecycleCallbacks {
private Stack<Activity> mActivityStack;
public ActivityBackStack() {
mActivityStack = new Stack<>();
}
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
mActivityStack.add(activity);
}
@Override
public void onActivityStarted(Activity activity) {
}
@Override
public void onActivityResumed(Activity activity) {
}
@Override
public void onActivityPaused(Activity activity) {
}
@Override
public void onActivityStopped(Activity activity) {
}
@Override
public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
}
@Override
public void onActivityDestroyed(Activity activity) {
if (activity != null) {
mActivityStack.remove(activity);
}
}
/**
* Activity
*
* @return
*/
public Activity getLastActivity() {
return mActivityStack.lastElement();
}
/**
* Activity
*
* @return
*/
public Activity getPreActivty() {
int size = mActivityStack.size();
if (size < 2) {
return null;
}
return mActivityStack.get(size - 2);
}
public int getSize() {
return mActivityStack.size();
}
}
그리고 애플 리 케 이 션 에 이 실현 클래스 를 등록 합 니 다.
registerActivityLifecycleCallbacks(mBackStack);
DecorView:1.DecorView 는 전체 Window 인터페이스의 맨 위 뷰 입 니 다.
2.DecorView 는 하나의 키 View LinearLayout 만 있 고 전체 Window 인터페이스 를 대표 합 니 다.ton 알림 표시 줄,제목 표시 줄,내용 구역 을 포함 합 니 다.
3.DecorView:activity.getWindow().getDecorView()가 져 오기
슬라이더:
Activity 의 dispatchTouchEvent 를 다시 쓰 고 밸브 값 을 설정 합 니 다.밸브 값 에서 출발 할 때 이전 Activity 의 ContentView 를 현재 DecorView 에 추가 합 니 다.index 는 0 으로 가장 낮 습 니 다.미 끄 러 지 는 과정 에서 용기 의 X 값 을 동적 으로 바 꾸 어 이동 효 과 를 내 고 손 을 놓 은 후 취소 하거나 애니메이션 을 닫 습 니 다.애니메이션 이 끝나 면 앞에서 받 은 ContentView 를 돌려 줍 니 다.
DEMO:
https://github.com/gumingwei/SwipeBackActivity
위 에서 말 한 것 은 편집장 이 소개 한 안 드 로 이 드 가 위 챗 을 모방 하여 활동 을 종료 하 는 것 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 면 저 에 게 메 시 지 를 남 겨 주세요.편집장 은 신속하게 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Kotlin의 기초 - 2부지난 글에서는 Kotlin이 무엇인지, Kotlin의 특징, Kotlin에서 변수 및 데이터 유형을 선언하는 방법과 같은 Kotlin의 기본 개념에 대해 배웠습니다. 유형 변환은 데이터 변수의 한 유형을 다른 데이터...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.