av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Android如何實現翻轉動畫效果(卡片翻轉)

瀏覽:4日期:2023-02-14 15:55:10
目錄前言需求一、先介紹三個插值器二、實現步驟1.效果圖2.布局3.邏輯判斷(是否隱藏)4.翻轉動畫5.bug出現6.bug解決三、源碼四、總結前言

最近好友問計蒙翻轉動畫,恰好在大二那年看Android Api Demo時記了筆記,由此寫一篇文章。

需求

屏幕右滑事件觸發卡片的翻轉效果 ,為了方便,在例子中將右滑事件改成按鈕點擊事件

老規矩,最后有源碼

一、先介紹三個插值器 LinearInterpolator() 其變化速率恒定 AccelerateInterpolator() 其變化開始速率較慢,后面加速 DecelerateInterpolator() 其變化開始速率較快,后面減速 二、實現步驟1.效果圖

Android如何實現翻轉動畫效果(卡片翻轉)

2.布局

一個按鈕,兩個TextView(布局文件在源碼部分)

3.邏輯判斷(是否隱藏)

final TextView visibletext;final TextView invisibletext;//邏輯判斷if (textview1.getVisibility() == View.GONE) { visibletext = textview2; invisibletext = textview1;} else { invisibletext = textview2; visibletext = textview1;}4.翻轉動畫

//LinearInterpolator() 其變化速率恒定ObjectAnimator visToInvis = ObjectAnimator.ofFloat(visibletext, 'rotationY', 0f, 90f);visToInvis.setDuration(500);//AccelerateInterpolator() 其變化開始速率較慢,后面加速visToInvis.setInterpolator(new AccelerateInterpolator());final ObjectAnimator invisToVis = ObjectAnimator.ofFloat(invisibletext, 'rotationY',-90f, 0f);invisToVis.setDuration(500);//DecelerateInterpolator() 其變化開始速率較快,后面減速invisToVis.setInterpolator(new DecelerateInterpolator());visToInvis.addListener(new AnimatorListenerAdapter() { @Override public void onAnimationEnd(Animator anim) {visibletext.setVisibility(View.GONE);invisToVis.start();invisibletext.setVisibility(View.VISIBLE); }});visToInvis.start();5.bug出現

發現實現后,第一次點擊出現bug

Android如何實現翻轉動畫效果(卡片翻轉)

6.bug解決

在找到控件后,默認設置y方向角度

textview2.setRotationY(-90f);三、源碼

MainActivity.java

public class MainActivity extends Activity { private TextView textview1; private TextView textview2; private Button button; @Override protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);initView();//bug解決textview2.setRotationY(-90f);button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) {flipAnimation(); }}); } private void initView() {textview1 = (TextView) findViewById(R.id.textview1);textview2 = (TextView) findViewById(R.id.textview2);button = (Button) findViewById(R.id.button); } private void flipAnimation() {final TextView visibletext;final TextView invisibletext;//邏輯判斷if (textview1.getVisibility() == View.GONE) { visibletext = textview2; invisibletext = textview1;} else { invisibletext = textview2; visibletext = textview1;}//LinearInterpolator() 其變化速率恒定ObjectAnimator visToInvis = ObjectAnimator.ofFloat(visibletext, 'rotationY', 0f, 90f);visToInvis.setDuration(500);//AccelerateInterpolator() 其變化開始速率較慢,后面加速visToInvis.setInterpolator(new AccelerateInterpolator());final ObjectAnimator invisToVis = ObjectAnimator.ofFloat(invisibletext, 'rotationY',-90f, 0f);invisToVis.setDuration(500);//DecelerateInterpolator() 其變化開始速率較快,后面減速invisToVis.setInterpolator(new DecelerateInterpolator());visToInvis.addListener(new AnimatorListenerAdapter() { @Override public void onAnimationEnd(Animator anim) {visibletext.setVisibility(View.GONE);invisToVis.start();invisibletext.setVisibility(View.VISIBLE); }});visToInvis.start(); }}

activity_main.xml

<?xml version='1.0' encoding='utf-8'?><RelativeLayout 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='.MainActivity'><TextView android:layout_width='200dp' android:layout_height='200dp' android:background='#35B9F4' android: android:layout_centerInParent='true' /><TextView android:layout_width='200dp' android:layout_height='200dp' android:background='#03DAC5' android:layout_centerInParent='true' android: /><Button android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_alignParentBottom='true' android:layout_centerHorizontal='true' android: android:text='點擊翻轉'/></RelativeLayout>四、總結

最后將button的點擊事件改成屏幕監聽事件即可。

到此這篇關于Android如何實現翻轉動畫效果的文章就介紹到這了,更多相關Android實現翻轉動畫內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
主站蜘蛛池模板: 中文字幕在线观看一区二区 | 亚洲精品在线看 | 久久久精品网 | 国产精品尤物 | 深夜福利视频在线观看 | 欧美性视频在线 | 国语对白永久免费 | 亚洲精品乱码久久久久久 | 亚洲影院在线 | 国产精品一级二级 | 日韩精品影院 | 天堂一区二区三区 | 超碰中文字幕 | 欧美日韩色 | 久草精品视频在线看网站免费 | 一级黄色片免费 | 亚洲日本国产 | av网站在线免费观看 | 天堂网中文在线 | 国产激情一区 | 色综合五月天 | 色女人影院 | 性一交一乱一伧老太 | 青青草视频网站 | 麻豆av在线免费观看 | 色综合久久久久 | 国产一区二区三区久久 | 一级黄色a| 99视频网 | 在线播放一区 | 亚洲精品播放 | 国产日韩欧美 | 国产精品羞羞答答 | 午夜视频福利 | 亚洲欧美视频 | 久久午夜精品 | 男人天堂亚洲 | 99视频免费在线观看 | 久久久精品在线观看 | 日韩福利视频 | 亚洲免费小视频 |