a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 系統 > Android > 正文

Android工具欄頂出轉場動畫的實現方法實例

2019-12-12 00:32:19
字體:
來源:轉載
供稿:網友

前言

ndroid5.0之后新增了很多好看的轉場動畫,相比于以前的overridePendingTransition()豐富了很多,特別新增了共享元素跳轉的方式。本文將給大家詳細介紹關于Android工具欄頂出轉場動畫實現的相關資料,下面話不多說了,來一起看看詳細的介紹吧

實現效果


為何做這個動畫

起初對于這兩個界面的轉場動畫打算簡單使用android原生的共享元素動畫,可是實現后發現效果并不是很好,在很多手機上流暢度太差。

以下在敘述時把轉場前的頁面稱為A頁面, 轉場的目前頁面稱為B頁面

實現原理

在A頁面,把需要頂出的區域截取出來

val contentView = (context as Activity).window.decorView.findViewById<View>(android.R.id.content) ?: return nullvar captureImage: Bitmap? = nullcontentView.isDrawingCacheEnabled = truecaptureImageFromView(contentView)contentView.destroyDrawingCache()

在B頁面,把A頁面截取的圖片用ImageView展示在頂部,并做上移動畫。同時,取消按鈕做出現的動畫。
ImageView的上移動畫非常簡單:通過不斷改變topMarigin來實現上移效果

 val captureImageUpAnimator = ValueAnimator.ofFloat(0f, 1f).apply { addUpdateListener {  val newTopMargin = captureImageStartLocationY * (animatedValue as Float)  (captureView.layoutParams as LinearLayout.LayoutParams)?.apply {   topMargin = -(newTopMargin.toInt())  } }}val captureImageDownAnimator = ValueAnimator.ofFloat(1f, 0f).apply { addUpdateListener {  val newTopMargin = captureImageStartLocationY * (animatedValue as Float)  (captureView.layoutParams as LinearLayout.LayoutParams)?.apply {   topMargin = -(newTopMargin.toInt())  } }}

取消按鈕的出現動畫,則是通過取消按鈕左側的框不斷變小來實現的。

val rightBtnShowAnimator = ValueAnimator.ofFloat(0f, 1f).apply { addUpdateListener {  val animateWidth = (it.animatedValue as Float) * RIGHT_BTN_WIDTH  flexingView.layoutParams = LinearLayout.LayoutParams(containerWidth - animateWidth.toInt(), UIUtil.dp2px(30f)) }}

下圖大概描述了整個動畫時如何實現的:


動畫實現需要注意的點

頁面A保存的截圖如何傳到B頁面?

1、截圖應該放到內存還是本地?

這個截圖應該放在內存中,如果截圖保存到本地。那么 I/O 占用的時間肯定會導致動畫實現效果不好。

2、對于截取的圖片需要壓縮

對于不同分辨率的手機,截取出的圖片的大小是不一樣的。圖片太大放在內存中是不合適的,因此在截取圖片后對圖片的大小做了壓縮。

private fun captureFromView(view: View): Bitmap? { return translateToRgb555(view.drawingCache)}//為了壓縮大小,同時保證圖片寬高不變,直接將圖片轉成 RGB_565。private fun translateToRgb555(srcBitmap: Bitmap): Bitmap? { try {  /*傳入bitmap參數,返回bitmap。*/  val dataByte = ByteArrayOutputStream()  srcBitmap.compress(Bitmap.CompressFormat.JPEG, 100, dataByte)  val opts = BitmapFactory.Options()  opts.inPreferredConfig = Bitmap.Config.RGB_565  return BitmapFactory.decodeByteArray(dataByte.toByteArray(), 0, dataByte.size(), opts) } catch (e: Exception) {  e.printStackTrace() } catch (e: OutOfMemoryError) {  e.printStackTrace() } return null}

經過上面的處理,大部分手機截圖大小在0.2MB左右

3、B界面如何獲取截取的圖片?

放在intent中傳給B

這樣是有問題的,雖然android官方說intent中可以傳遞小于1MB的圖片,但是國內各anroid廠商對framework做了不同的定制,有可能你的圖片0.3MB就會出現崩潰,即TransactionTooLargeException

放在Fresco的緩存中?

嘗試將圖片放入Fresco緩存中,不過Fresco提供的接口十分不友好,(大概就不是給框架外使用的:

CloseableReference<V> cache(K key, CloseableReference<V> value);

放在全局靜態變量中

不過需要注意的是在頁面finish時,將這個變量置null,以免占用內存

覆蓋系統原生轉場動畫

如果對于默認轉場動畫不做處理的話,效果就不是我們想要的,因此要取消默認的轉場動畫

需要把B頁面的Theme的動畫相關屬性置null就可以了

<style name="NullAnimation" parent="@android:style/Animation.Activity"><item name="android:activityOpenEnterAnimation">@null</item><item name="android:activityOpenExitAnimation">@null</item><item name="android:activityCloseEnterAnimation">@null</item><item name="android:activityCloseExitAnimation">@null</item></style>

不過這樣后,在一些手機,比如華為,還是會有默認的轉場動畫,為了保險起見,在startActivity是最好這樣

 context.overridePendingTransition(0, 0)

頁面閃爍的問題

在覆蓋了系統原生動畫后,大部分手機效果都還是ok的,不過在一些手機上會出現閃屏的問題,比如華為 Mate10。在網上參考一些大家的解決方法:

 <item name="android:windowIsTranslucent">true</item>

即設置B頁面的背景為透明的。

不過問題到這里還沒有結束

windowIsTranslucent引發的崩潰問題

在設置windowIsTranslucent屬性后,在Mate10進行測試,發現頁面啟動就崩潰:

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.linkedin.android.XXXX.XXXX/com.linkedin.android.XXXX.XXXX.activity.LoginActivity}:
java.lang.IllegalStateException: Only fullscreen activities can request orientation

最后google找到了原因,原來 Android 8.0某SDK要求,如果界面是鎖死方向的,那么是不允許設置這個屬性的,不然會引發崩潰, 如果想知道詳細細節可以看一下這篇文章:http://www.5lwq4hdr.cn/article/146945.htm

怎么解決呢?

前有山后有虎,腦殼子疼,最后決定取消B頁面的鎖屏屬性,并且頁面旋轉時頁面不做變化。

 <activity  android:name=".activity.BActivity"  android:exported="false"  android:configChanges="orientation|keyboardHidden|screenSize"  android:theme="@style/AnimationTheme">

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品久久久久久久久免费桃花 | 日日爱夜夜爱 | 天天天干天天射天天天操 | 欧美日韩不卡合集视频 | 国产在线一级片 | 在线日本视频 | 狠狠干天天干 | 奇米精品一区二区三区在线观看 | 看a网站| 国产中文字幕在线观看 | 91精品国产综合久久婷婷香蕉 | 精品国产乱码久久久久久1区二区 | 久久久蜜桃一区二区人 | 国产精品成人免费视频 | 亚洲精品久久久久久久久久久久久 | 午夜精品久久久久久99热软件 | 欧美激情 | 久久成人免费网站 | 一区二区免费 | 中文字幕在线观看精品视频 | 成人激情视频在线播放 | 九九九色 | 国产欧美日韩中文字幕 | 91在线观 | 操操操操操 | 成年人在线视频免费观看 | 欧美在线视频一区二区 | 午夜视频一区二区 | 久久夜色精品国产 | www夜夜操com | 久久不射电影网 | 免费视频一区 | 韩国久久 | 国产精品一区二区三区在线 | 色噜噜狠狠狠综合曰曰曰 | 亚洲日韩欧美一区二区在线 | 亚洲精品乱码 | 一区二区三区日本 | 国产精品免费av | 国产视频中文字幕 | 午夜精品久久久久久 |