日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Android基于AdapterViewFlipper實現的圖片/文字輪播動畫控件

瀏覽:164日期:2022-09-19 09:06:29

Android基于AdapterViewFlipper實現的圖片/文字輪播動畫控件

1. 問題/坑點1.1 item寬高不生效問題

需要注意的是,AdapterViewFlipper 在布局時,寬高一定要用 match_parent 或者 具體dp值。

如果寬、高中使用了 wrap_content 時,會導致 AdapterViewFlipper 容器的寬高,最終變成第一個item的寬高。即使后續item的寬高超過第一個item,也不會生效,內容顯示只會被限定在第一個的寬高范圍內。

原理也很好理解,后續item沒有繪制出來時, wrap_content 計算出來的結果,就是第一個item的寬高。當后續 item 顯示的時候,沒有地方去重新更新父容器 AdapterViewFlipper 的寬高。

2. 常用方法

1.AdapterViewAnimator支持的XML屬性如下:

android:animateFirstView:設置顯示組件的第一個View時是否使用動畫。 android:inAnimation:設置組件顯示時使用的動畫。 android:loopViews:設置循環到最后一個組件時是否自動跳轉到第一個組件。 android:outAnimation:設置組件隱藏時使用的動畫。

2.輪播控制:

startFlipping、stopFlipping : 開始、停止播放 showPrevious、showNext:上一個、下一個

3.輪播狀態與參數

isFlipping:是否輪播中 flipInterval: 動畫間隔

4.設置入場、出場動畫:setInAnimation、setOutAnimation

3. 文字/圖片 輪播 Demo

/** * 圖片/文字輪播 * 坑點:text_flipper height 如果設置wrap_content 導致item寬度只會以第一個item的為準 */class FlipperAnimActivity : AppCompatActivity(), View.OnClickListener { private var textFlipper: AdapterViewFlipper? = null private var imgFlipper: AdapterViewFlipper? = null private var preBtn: Button? = null private var nextBtn: Button? = null private var autoBtn: Button? = null override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_flipper_anim)initTextFlipper()initImgFlipper() } // 文字輪播 private fun initTextFlipper() {textFlipper = findViewById(R.id.text_flipper)val list = listOf('文字輪播測試0', '文字輪播測試02...')textFlipper?.adapter = TextFlipperAdapter(this, list)textFlipper?.setInAnimation(this, R.animator.text_flipper_in_from_bottom)textFlipper?.setOutAnimation(this, R.animator.text_flipper_out_to_top)//textFlipper?.flipInterval//textFlipper?.startFlipping() } // 圖片輪播 private fun initImgFlipper() {imgFlipper = findViewById(R.id.img_flipper)val list = listOf('http://www.nicesoso.com/test/file/img/test.jpg', 'http://www.nicesoso.com/test/file/img/test_h_1.jpg','http://www.nicesoso.com/test/file/img/test_h_2.jpg')imgFlipper?.adapter = ImgFlipperAdapter(this, list)imgFlipper?.setInAnimation(this, R.animator.img_flipper_in)preBtn = findViewById(R.id.prev_btn)nextBtn = findViewById(R.id.next_btn) as ButtonautoBtn = findViewById(R.id.auto_btn) as ButtonpreBtn?.setOnClickListener(this)nextBtn?.setOnClickListener(this)autoBtn?.setOnClickListener(this) } override fun onClick(v: View?) {when (v?.id) { R.id.prev_btn -> {imgFlipper?.showPrevious()imgFlipper?.stopFlipping() } R.id.next_btn -> {imgFlipper?.showNext()imgFlipper?.stopFlipping() } R.id.auto_btn -> {imgFlipper?.startFlipping() }} } override fun onDestroy() {super.onDestroy()textFlipper?.takeIf { it.isFlipping }?.stopFlipping()imgFlipper?.takeIf { it.isFlipping }?.stopFlipping() }}3.1 文字輪播:TextFlipperAdapter

class TextFlipperAdapter(private val context: Context, private val datas: List<String>) : BaseAdapter() { override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {val view = convertView ?: LayoutInflater.from(context).inflate(R.layout.item_flipper_text, parent, false)val textView = view?.findViewById<TextView?>(R.id.text)textView?.text = datas.get(position)return view } override fun getItem(position: Int): Any {return datas.get(position) } override fun getItemId(position: Int): Long {return position.toLong() } override fun getCount(): Int {return datas.size }}3.2 圖片輪播:ImgFlipperAdapter

class ImgFlipperAdapter(private val context: Context, private val datas: List<String>) : BaseAdapter() { override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {val view = convertView ?: ImageView(context)(view as? ImageView)?.scaleType = ImageView.ScaleType.FIT_XYview.layoutParams = ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)(view as? ImageView)?.let { Glide.with(context).load(datas.get(position)).into(it) } return view } override fun getItem(position: Int): Any {return datas.get(position) } override fun getItemId(position: Int): Long {return position.toLong() } override fun getCount(): Int {return datas.size }}3.3 布局:activity_flipper_anim.xml

<?xml version='1.0' encoding='utf-8'?><LinearLayout 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:orientation='vertical'> <RelativeLayoutandroid:layout_width='match_parent'android:layout_height='100dp'android:background='@android:color/holo_red_light'android:orientation='vertical'><!--寬高要必須設置填充滿,否則wrap_content時,大小變成第一個item的大小--><AdapterViewFlipper android: android:layout_width='match_parent' android:layout_height='match_parent' android:autoStart='true' android:flipInterval='2000' /> </RelativeLayout> <RelativeLayoutandroid:layout_width='match_parent'android:layout_height='0dp'android:layout_weight='1'><AdapterViewFlipper android: android:layout_width='match_parent' android:layout_height='match_parent' android:layout_alignParentTop='true' android:flipInterval='5000' /><TextView android:layout_width='match_parent' android:layout_height='wrap_content' android:layout_alignParentTop='true' android:gravity='center' android:text='圖片輪播測試(5s)' android:textSize='24sp' /><Button android: android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_alignParentLeft='true' android:layout_alignParentBottom='true' android:text='上一個' /><Button android: android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_alignParentBottom='true' android:layout_centerHorizontal='true' android:text='下一個' /><Button android: android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_alignParentRight='true' android:layout_alignParentBottom='true' android:text='自動播放' /> </RelativeLayout></LinearLayout>

文字item布局:item_flipper_text.xml

<?xml version='1.0' encoding='utf-8'?><LinearLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='match_parent' android:layout_height='100dp' android:background='@android:color/holo_blue_light'> <TextViewandroid: android:layout_width='match_parent'android:layout_height='match_parent'android:layout_marginLeft='5dp'android:layout_weight='1'android:background='@android:color/holo_green_light'android:gravity='center'android:maxLines='1'android:textSize='22sp' /></LinearLayout>3.4 動畫

文字輪播,入場動畫:res/animator/text_flipper_in_from_bottom.xml

<?xml version='1.0' encoding='utf-8'?><objectAnimator xmlns:android='http://schemas.android.com/apk/res/android' android:duration='300' android:interpolator='@android:anim/accelerate_decelerate_interpolator' android:propertyName='y' android:valueFrom='100' android:valueTo='0' android:valueType='floatType' />

文字輪播,出場動畫:res/animator/text_flipper_out_to_top.xml

<?xml version='1.0' encoding='utf-8'?><objectAnimator xmlns:android='http://schemas.android.com/apk/res/android' android:duration='300' android:interpolator='@android:anim/accelerate_decelerate_interpolator' android:propertyName='y' android:valueFrom='0' android:valueTo='-100' android:valueType='floatType' />

圖片輪播,入場動畫:res/animator/img_flipper_in.xml

<?xml version='1.0' encoding='utf-8'?><objectAnimator xmlns:android='http://schemas.android.com/apk/res/android' android:duration='300' android:interpolator='@android:anim/accelerate_decelerate_interpolator' android:propertyName='x' android:valueFrom='500' android:valueTo='0' android:valueType='floatType' />參考

https://www.jb51.net/article/210687.htm

以上就是Android基于AdapterViewFlipper實現的圖片/文字輪播動畫控件的詳細內容,更多關于Android 實現圖片/文字輪播動畫控件的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
麻豆视频在线观看免费网站黄| 美国三级日本三级久久99| 亚洲一二av| 亚洲三级网站| 婷婷精品在线观看| 国产日韩在线观看视频| 国产精品一站二站| 国产一区二区三区四区| 欧美成人a交片免费看| 色88888久久久久久影院| 91精品啪在线观看国产18 | 免费一区二区三区在线视频| 精品国产a一区二区三区v免费| 黄色aa久久| 亚洲成人日韩| 日韩精品一区二区三区免费视频| 欧美一区成人| 理论片午夜视频在线观看| 欧美午夜不卡| 国产日韩免费| 三上悠亚国产精品一区二区三区| 99国产精品视频免费观看一公开| 亚洲va久久久噜噜噜久久| 精品视频亚洲| 亚洲欧美日韩精品一区二区| 久久国内精品视频| 国产videos久久| 自拍日韩欧美| 国产探花在线精品一区二区| 日韩国产欧美一区二区| 三级一区在线视频先锋| 亚洲精品麻豆| 麻豆理论在线观看| 亚洲3区在线| 日本免费一区二区三区四区| 亚洲精品第一| 久久精品中文| 国产精品片aa在线观看 | 久久成人高清| 久久久夜精品| 日产欧产美韩系列久久99| 国产精品成人一区二区不卡| 久热re这里精品视频在线6| 国产精品成人**免费视频| 国产一区二区三区自拍| 国产精品17p| 国产精品日韩久久久| 精品视频91| 日韩在线麻豆| 黄色不卡一区| 国产在线视频欧美一区| 蜜臀av一区二区三区| 日韩大片在线播放| 国产精品亲子伦av一区二区三区 | 亚洲综合三区| 岛国av免费在线观看| 日韩精品一区二区三区中文| av一区二区高清| 亚洲精品成人图区| 国产精品magnet| 亚洲精品在线二区| 激情欧美一区二区三区| 麻豆视频一区| 日韩精品中文字幕一区二区| 五月综合激情| 成人在线超碰| 国产精品激情电影| 日韩精品一区二区三区免费视频| 婷婷激情综合| 色婷婷狠狠五月综合天色拍| 麻豆精品蜜桃视频网站| 欧美日韩亚洲一区| 日本国产欧美| 亚洲精品国模| 亚洲涩涩av| 亚洲激精日韩激精欧美精品| 成人精品中文字幕| 老牛影视精品| 国产一区二区三区不卡视频网站| 国产三级一区| 日韩午夜视频在线| 亚洲tv在线| 三级久久三级久久久| 亚洲久久视频| 亚洲欧洲美洲国产香蕉| 亚洲最新av| 在线精品一区| 免费成人在线影院| 午夜在线视频一区二区区别| 婷婷精品进入| 亚洲综合不卡| 亚洲一区日韩在线| 亚洲一区二区动漫| 免费一区二区视频| 亚洲婷婷丁香| 免费视频最近日韩| 日韩不卡一区二区| 久久精品超碰| 国产精品白丝一区二区三区| 国产精品乱战久久久| 久久久久久亚洲精品美女| 精品视频一区二区三区在线观看 | 亚洲一区二区三区免费在线观看| 亚洲精品极品少妇16p| 亚洲免费观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲欧美日韩国产一区| 亚洲五月综合| 欧美精品中文字幕亚洲专区| 国产精品大片免费观看| 日韩av在线中文字幕| 激情黄产视频在线免费观看| 日韩欧美一区二区三区在线观看| 美女少妇全过程你懂的久久| 亚洲一区成人| 日本精品在线播放| 欧美一区二区三区久久| 日韩欧美午夜| 精品久久一区| 久久精品福利| 中文在线免费视频| 日韩中文视频| 日韩一区二区三区免费| 国产99久久| 香蕉久久国产| 日本综合精品一区| 麻豆国产精品| 999国产精品999久久久久久| 91精品一区国产高清在线gif| 亚洲一区二区三区免费在线观看 | 日韩视频中文| 日韩av成人高清| 四季av一区二区凹凸精品| 久久久蜜桃一区二区人| 在线精品一区二区| 丁香婷婷久久| 婷婷亚洲五月| 国产日韩一区| 日韩欧美网址| 综合国产在线| 麻豆91小视频| 亚洲ww精品| 欧美国产专区| 久久中文字幕av| 日韩欧美激情电影| 日韩成人综合| 日韩免费精品| 91精品国产调教在线观看| 色综合视频一区二区三区日韩 | 国产精品v日韩精品v欧美精品网站 | 国产精品三级| 香蕉久久99| 精品视频一区二区三区在线观看| 日韩中文字幕| 美女国产一区二区三区| 久久国产电影| 国产精品男女| 欧美午夜不卡影院在线观看完整版免费| 日韩精品欧美成人高清一区二区| 国产一区二区三区亚洲| 午夜在线一区二区| 黑森林国产精品av| 日本不卡视频在线| 日产精品一区| 国产日韩高清一区二区三区在线| 中文字幕在线高清| 日本亚州欧洲精品不卡| 久久精品国产68国产精品亚洲| 国产亚洲一区二区三区啪| 亚洲精品小说| 日本不良网站在线观看| 欧美偷窥清纯综合图区| 中文在线不卡| 亚洲播播91| 麻豆视频一区| 欧美亚洲三级| 蜜桃视频一区二区三区| 91久久久精品国产| 久久久男人天堂| 欧美一区二区三区久久精品| 亚洲婷婷免费| 久久久久免费| 国产精品一区亚洲| 综合一区av| 亚洲一区二区成人| 欧美成人综合| 亚洲不卡av不卡一区二区| 国产成人精品三级高清久久91 | 午夜国产精品视频| 午夜欧美巨大性欧美巨大| 麻豆精品在线播放| 国产精品日韩精品在线播放| 91麻豆精品激情在线观看最新 | 亚洲伦乱视频| 精品国产aⅴ| 精品亚洲a∨| 高清在线一区| 国产福利电影在线播放| 狠狠久久伊人| 成人国产精品一区二区免费麻豆|