电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Android基于AdapterViewFlipper實現(xiàn)的圖片/文字輪播動畫控件

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

Android基于AdapterViewFlipper實現(xiàn)的圖片/文字輪播動畫控件

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

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

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

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

2. 常用方法

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

android:animateFirstView:設(shè)置顯示組件的第一個View時是否使用動畫。 android:inAnimation:設(shè)置組件顯示時使用的動畫。 android:loopViews:設(shè)置循環(huán)到最后一個組件時是否自動跳轉(zhuǎn)到第一個組件。 android:outAnimation:設(shè)置組件隱藏時使用的動畫。

2.輪播控制:

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

3.輪播狀態(tài)與參數(shù)

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

4.設(shè)置入場、出場動畫:setInAnimation、setOutAnimation

3. 文字/圖片 輪播 Demo

/** * 圖片/文字輪播 * 坑點:text_flipper height 如果設(shè)置wrap_content 導(dǎo)致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'><!--寬高要必須設(shè)置填充滿,否則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實現(xiàn)的圖片/文字輪播動畫控件的詳細內(nèi)容,更多關(guān)于Android 實現(xiàn)圖片/文字輪播動畫控件的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Android
相關(guān)文章:
主站蜘蛛池模板: 行业分析:提及郑州火车站附近真有 特殊按摩 ?2025实地踩坑指南 新手如何避坑不踩雷 | 彩超机-黑白B超机-便携兽用B超机-多普勒彩超机价格「大为彩超」厂家 | 软启动器-上海能曼电气有限公司 真空搅拌机-行星搅拌机-双行星动力混合机-广州市番禺区源创化工设备厂 | 杭州代理记账费用-公司注销需要多久-公司变更监事_杭州福道财务管理咨询有限公司 | 活性炭-蜂窝-椰壳-柱状-粉状活性炭-河南唐达净水材料有限公司 | 开云(中国)Kaiyun·官方网站-登录入口| 福建自考_福建自学考试网 | 氧化铁红厂家-淄博宗昂化工| 山东彩钢板房,山东彩钢活动房,临沂彩钢房-临沂市贵通钢结构工程有限公司 | 变压器配件,变压器吸湿器,武强县吉口变压器配件有限公司 | 建筑资质代办-建筑资质转让找上海国信启航 | 便携式谷丙转氨酶检测仪|华图生物科技百科| 路面机械厂家| NM-02立式吸污机_ZHCS-02软轴刷_二合一吸刷软轴刷-厦门地坤科技有限公司 | 探鸣起名网-品牌起名-英文商标起名-公司命名-企业取名包满意 | 机制砂选粉机_砂石选粉机厂家-盐城市助成粉磨科技有限公司 | HDPE储罐_厂家-山东九州阿丽贝防腐设备 | 锥形螺带干燥机(新型耙式干燥机)百科-常州丰能干燥工程 | 铝箔袋,铝箔袋厂家,东莞铝箔袋,防静电铝箔袋,防静电屏蔽袋,防静电真空袋,真空袋-东莞铭晋让您的产品与众不同 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 医疗仪器模块 健康一体机 多参数监护仪 智慧医疗仪器方案定制 血氧监护 心电监护 -朗锐慧康 | loft装修,上海嘉定酒店式公寓装修公司—曼城装饰 | 低压载波电能表-单相导轨式电能表-华邦电力科技股份有限公司-智能物联网综合管理平台 | 南昌旅行社_南昌国际旅行社_南昌国旅在线 | 升降炉_真空气氛炉_管式电阻炉厂家-山东中辰电炉有限公司 | 扬子叉车厂家_升降平台_电动搬运车|堆高车-扬子仓储叉车官网 | 玉米深加工设备|玉米加工机械|玉米加工设备|玉米深加工机械-河南成立粮油机械有限公司 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 宝元数控系统|对刀仪厂家|东莞机器人控制系统|东莞安川伺服-【鑫天驰智能科技】 | 深圳激光打标机_激光打标机_激光焊接机_激光切割机_同体激光打标机-深圳市创想激光科技有限公司 深圳快餐店设计-餐饮设计公司-餐饮空间品牌全案设计-深圳市勤蜂装饰工程 | 番茄畅听邀请码怎么输入 - Dianw8.com | 电动葫芦-河北悍象起重机械有限公司 | 首页-恒温恒湿试验箱_恒温恒湿箱_高低温试验箱_高低温交变湿热试验箱_苏州正合 | 翰墨AI智能写作助手官网_人工智能问答在线AI写作免费一键生成 | 粉丝机械,粉丝烘干机,粉丝生产线-招远市远东粉丝机械有限公司 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 网站建设-网站制作-网站设计-网站开发定制公司-网站SEO优化推广-咏熠软件 | 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 防爆型气象站_农业气象站_校园气象站_农业四情监测系统「山东万象环境科技有限公司」 | 纳米涂料品牌 防雾抗污纳米陶瓷涂料厂家_虹瓷科技 | 示波器高压差分探头-国产电流探头厂家-南京桑润斯电子科技有限公司 |