android實現(xiàn)撲克卡片翻轉
今天看見一個Android 撲克卡片翻轉效果的帖子,于是手癢想學一學,由于接觸過的Animation動畫等比較少,所以感覺很新奇。
首先,說一下布局,是FrameLayout,這個布局設置一點點擊方法,要設置id,之后會用到。這個布局還包括兩個子布局,分別是Poke的正面和反面布局。上代碼:
還需額外注意一點:這是剛剛才發(fā)現(xiàn)的問題,在主activity中,正反面那個xml文件放在后面就會優(yōu)先默認顯示那個xml文件,所以,如果我需要一打開app就看到正面的話,那么正面xml文件需要放到反面xml文件的下面,就是
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" ? ? xmlns:tools="http://schemas.android.com/tools" ? ? android:layout_width="match_parent" ? ? android:layout_height="match_parent" ? ? android:paddingBottom="@dimen/activity_vertical_margin" ? ? android:paddingLeft="@dimen/activity_horizontal_margin" ? ? android:paddingRight="@dimen/activity_horizontal_margin" ? ? android:paddingTop="@dimen/activity_vertical_margin" ? ? android:onClick="flipCard" ? ? android:id="@+id/main_fl_container" ? ? tools:context="com.example.chenxuanhe.poketest.MainActivity"> ? ? <include layout="@layout/cell_card_back" ? ? ? ? /> ? ? <include layout="@layout/cell_card_front" ? ? ? ? /> </FrameLayout>
根據代碼的邏輯線走,則是接下來的兩個layout:
這兩個FrameLayout也是需要寫id的,之后會用到。
cell_card_back.xml:
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" ? ? android:layout_width="match_parent" ? ? android:layout_height="match_parent" ? ? android:id="@+id/main_fl_card_back" ? ? > ? ? <ImageView ? ? ? ? android:src="@drawable/rectangle_back" ? ? ? ? android:contentDescription="@null" ? ? ? ? android:padding="16dp" ? ? ? ? android:layout_width="match_parent" ? ? ? ? android:layout_height="match_parent" ? ? ? ? /> ? ? <TextView ? ? ? ? android:textColor="@color/colorAccent" ? ? ? ? android:text="反面" ? ? ? ? android:textSize="40dp" ? ? ? ? android:layout_gravity="center" ? ? ? ? android:gravity="center" ? ? ? ? android:layout_width="match_parent" ? ? ? ? android:layout_height="match_parent" /> </FrameLayout>
cell_card_front.xml:
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" ? ? android:layout_width="match_parent" ? ? android:layout_height="match_parent" ? ? android:id="@+id/main_fl_card_front"> ? ? <ImageView ? ? ? ? android:src="@drawable/rectangle_front" ? ? ? ? android:padding="16dp" ? ? ? ? android:contentDescription="@null" ? ? ? ? android:layout_width="match_parent" ? ? ? ? android:layout_height="match_parent" /> ? ? <TextView ? ? ? ? android:textSize="40dp" ? ? ? ? android:textColor="@color/colorPrimary" ? ? ? ? android:text="正面" ? ? ? ? android:gravity="center" ? ? ? ? android:layout_gravity="center" ? ? ? ? android:layout_width="match_parent" ? ? ? ? android:layout_height="match_parent" /> </FrameLayout>
繼續(xù)順著上面兩個布局的邏輯線來走,就需要用到兩個Drawable的文件作為背景圖,所以接著看drawable文件:
rectangle_back.xml:
大概是一個黑邊紅底色帶圓角的卡片界面
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" ? ? android:shape="rectangle"> ? ? <corners android:radius="16dp"/> ? ? <solid android:color="@color/cardBack"/> ? ? <stroke android:width="2dp" ? ? ? ? android:color="@android:color/black"/> </shape>
rectangle_front.xml:
大概是一個黑邊灰底色帶圓角的卡片界面
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" ? ? android:shape="rectangle"> ? ? <corners android:radius="16dp"/> ? ? <solid android:color="@color/cardFront"/> ? ? <stroke android:width="2dp" ? ? ? ? android:color="@android:color/black"/> </shape>
走完界面UI的邏輯線之后,就去看Java代碼,發(fā)現(xiàn)需要兩個Animator,于是在res文件下創(chuàng)建一個animator資源文件夾,在下創(chuàng)建兩個動畫文件:
anim-in.xml:
這是一個從左邊進入的動畫,一開始是隱藏的,逆向旋轉,當旋轉到一半時,顯示卡片
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> ? ? <!--消失--> ? ? <objectAnimator ? ? ? ? android:duration="0" ? ? ? ? android:propertyName="alpha" ? ? ? ? android:valueFrom="1.0" ? ? ? ? android:valueTo="0.0"/> ? ? <!--旋轉--> ? ? <objectAnimator ? ? ? ? android:duration="3000" ? ? ? ? android:propertyName="rotationY" ? ? ? ? android:valueFrom="-180" ? ? ? ? android:valueTo="0"/> ? ? <!--出現(xiàn)--> ? ? <objectAnimator ? ? ? ? android:duration="0" ? ? ? ? android:propertyName="alpha" ? ? ? ? android:startOffset="1500" ? ? ? ? android:valueFrom="0.0" ? ? ? ? android:valueTo="1.0"/> </set>
anim_out.xml:
這是一個右邊出去的動畫,旋轉180度,旋轉到一半時,卡片就消失了。
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> ? ? <objectAnimator ? ? ? ? android:duration="3000" ? ? ? ? android:propertyName="rotationY" ? ? ? ? android:valueFrom="0" ? ? ? ? android:valueTo="180"/> ? ? <!--消失--> ? ? <objectAnimator ? ? ? ? android:duration="0" ? ? ? ? android:propertyName="alpha" ? ? ? ? android:startOffset="1500" ? ? ? ? android:valueFrom="1.0" ? ? ? ? android:valueTo="0.0"/> </set>
接著看Java代碼:
MainActivity:
public class MainActivity extends AppCompatActivity { ? ? @Bind(R.id.main_fl_card_back) ? ? FrameLayout mFlCardBack; ? ? @Bind(R.id.main_fl_card_front) ? ? FrameLayout mFlCardFront; ? ? @Bind(R.id.main_fl_container) ? ? FrameLayout mFlContainer; ? ? private AnimatorSet mLeftInSet; ? ? private AnimatorSet mRightOutSet; ? ? private boolean mIsShowBack; ? ? @Override ? ? protected void onCreate(Bundle savedInstanceState) { ? ? ? ? super.onCreate(savedInstanceState); ? ? ? ? setContentView(R.layout.activity_main); ? ? ? ? ButterKnife.bind(this); ? ? ? ? setAnimation();//設置動畫 ? ? ? ? setCameraDistance();//設置鏡頭距離,在這里不是太懂 ? ? } ? ? private void setAnimation() { ? ? //mLeftInSet是左邊進入的動畫 ? ? ? ? mLeftInSet = (AnimatorSet) AnimatorInflater.loadAnimator(this, R.animator.anim_in); ? ?//mRightOutSet是右邊出去的動畫 ? ? ? ? mRightOutSet = (AnimatorSet) AnimatorInflater.loadAnimator(this, R.animator.anim_out); ? ? ? ? //點擊事件 ? ? ? ? //通過ListenerAdapter就不需重寫所有方法,只需寫需要寫的方法 ? ? ? ? mRightOutSet.addListener(new AnimatorListenerAdapter() { ? ? ? ? //動畫開始時候 ? ? ? ? ? ? @Override ? ? ? ? ? ? public void onAnimationStart(Animator animation) { ? ? ? ? ? ? ? ? super.onAnimationStart(animation); ? ? ? ? ? ? ? ? mFlContainer.setClickable(false); ? ? ? ? ? ? } ? ? ? ? }); ? ? ? ? //動畫結束的時候 ? ? ? ? mLeftInSet.addListener(new AnimatorListenerAdapter() { ? ? ? ? ? ? @Override ? ? ? ? ? ? public void onAnimationEnd(Animator animation) { ? ? ? ? ? ? ? ? super.onAnimationEnd(animation); ? ? ? ? ? ? ? ? mFlContainer.setClickable(true);//主布局中framelayouy的就允許你去點擊了 ? ? ? ? ? ? } ? ? ? ? }); ? ? } //一直不是很懂的設置鏡頭距離, //帖子上的注釋寫著:改變視角距離,貼近屏幕 ? ? private void setCameraDistance() { ? ? ? ? int distance = 16000; ? ? ? ? float scale = getResources().getDisplayMetrics().density*distance; ? ? ? ? mFlCardFront.setCameraDistance(scale);//設置距離 ? ? ? ? mFlCardBack.setCameraDistance(scale);//設置距離 ? ? } //這是主Framelayout的點擊方法 ? ? public void flipCard(View view){ ? ? //mIsShowBack可以理解為互斥,所以為boolean ? ? ? ? if(!mIsShowBack){ ? ? ? ? //右出動畫設置在正面卡片界面 ? ? ? ? ? ? mRightOutSet.setTarget(mFlCardFront); ? ? ? ? //左入動畫設置在反面卡片界面 ? ? ? ? ? ? ? ? mLeftInSet.setTarget(mFlCardBack); ? ? ? ? ? ? //開始動畫? ? ? ? ? ? ? mRightOutSet.start(); ? ? ? ? ? ? mLeftInSet.start(); ? ? ? ? ? ? mIsShowBack = true; ? ? ? ? }else { ? ? ? ? //右出動畫設置在卡片背面界面 ? ? ? ? ? ? mRightOutSet.setTarget(mFlCardBack); ? ? ? ? ?//左入動畫設置在卡片正面界面 ? ? ? ? ? ? mLeftInSet.setTarget(mFlCardFront); ? ? ? ? ? ? mRightOutSet.start(); ? ? ? ? ? ? mLeftInSet.start(); ? ? ? ? ? ? mIsShowBack = false; ? ? ? ? } ? ? } ? ? //這一點我一直沒想到,還可以在onDestroy方法中解綁ButterKnife ? ? protected void onDestroy(){ ? ? ? ? super.onDestroy(); ? ? ? ? ButterKnife.unbind(this); ? ? } }
到這一步,基本就全部完成了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android應用圖標在狀態(tài)欄上顯示實現(xiàn)原理
Android應用圖標在狀態(tài)欄上顯示,以及顯示不同的圖標,其實很研究完后,才發(fā)現(xiàn),很簡單,具體實現(xiàn)如下,感興趣的朋友可以參考下哈2013-06-06Android中導航組件Navigation的實現(xiàn)原理
大家好,本篇文章主要講的是Android中導航組件Navigation的實現(xiàn)原理,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下2022-02-02Kotlin使用flow實現(xiàn)倒計時功能(示例詳解)
這篇文章主要介紹了Kotlin使用flow實現(xiàn)倒計時功能,本文通過圖文實例相結合給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-02-02Android?RecyclerLineChart實現(xiàn)圖表繪制教程
這篇文章主要為大家介紹了Android?RecyclerLineChart實現(xiàn)圖表繪制教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12