Android怎么实现左右滑动切换图片
发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,这篇文章主要介绍"Android怎么实现左右滑动切换图片"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Android怎么实现左右滑动切换图片"文章能帮助大家解
千家信息网最后更新 2024年11月19日Android怎么实现左右滑动切换图片
这篇文章主要介绍"Android怎么实现左右滑动切换图片"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Android怎么实现左右滑动切换图片"文章能帮助大家解决问题。
简要说明
本文采用ImageSwitcher实现左右滑动切换图片。首先调用setFactory方法,设置视图工厂;然后设置手指触碰监听,判断左滑右滑进而切换图片。
本地图片
xml
activity
package com.imageSwitcherimport android.os.Bundleimport android.view.MotionEventimport android.view.Viewimport android.view.animation.AnimationUtilsimport android.widget.ImageViewimport androidx.appcompat.app.AppCompatActivityimport com.bumptech.glide.Glideimport kotlinx.android.synthetic.main.activity_main.*class MainActivity : AppCompatActivity() { // 本地图片 privateval images = arrayOf(R.drawable.t1, R.drawable.t2, R.drawable.t3, R.drawable.t4, R.drawable.t5, R.drawable.t6) // 网络图片 privateval urlImages = arrayOf("http://ip/aa.jpg", "http://ip/bb.jpg", "http://ip/cc.jpg", "http://ip/dd.jpg", "http://ip/ee.jpg", "http://ip/ff.jpg") private var index = 0 private var touchDownX: Float = 0f private var touchUpX: Float = 0f override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) initView() } private fun initView() { // 设置视图工厂 imageSwitcher.setFactory { val imageView = ImageView(this@MainActivity) imageView.setImageResource(images[index]) imageView } // 设置触摸监听 imageSwitcher.setOnTouchListener(object : View.OnTouchListener { override fun onTouch(view: View?, event: MotionEvent?): Boolean { //判断动作是不是按下 if (event?.action == MotionEvent.ACTION_DOWN) { // 获取手指按下时的X坐标 touchDownX = event.x return true } else if (event?.action == MotionEvent.ACTION_UP) { // 获取手指离开后的X坐标 touchUpX = event.x // 判断是左滑还是右滑 if (touchUpX - touchDownX > 100) { // 上一张 if (index == 0) { index = images.size - 1 } else { index-- } } else if (touchDownX - touchUpX > 100) { // 下一张 if (index >= images.size - 1) { index = 0 } else { index++ } } // 使用自带的淡入淡出 imageSwitcher.inAnimation = AnimationUtils.loadAnimation(this@MainActivity, android.R.anim.fade_in); imageSwitcher.outAnimation = AnimationUtils.loadAnimation(this@MainActivity, android.R.anim.fade_out); // 显示另一张图片 imageSwitcher.setImageResource(images[index]) return true } return false } }) }}
网络图片(采用Glide网络加载)
setFactory方法对应替换:
imageSwitcher.setFactory { val imageView = ImageView(this@MainActivity) Glide.with(this).load(urlImages[index]).into(imageView) imageView }
setOnTouchListener对应替换:
Glide.with(this@SwipeRecommend).asBitmap().load(urlImages[index]).into(imageSwitcher.currentView as ImageView)
注意加载http网络图片需要设置网络权限:
AndroidManifest.xml中添加:
AndroidManifest.xml的application标签添加:
android:networkSecurityConfig="@xml/network_security_config"
network_security_config.xml(res/xml/文件夹下,没有自行创建即可)内容为:
效果展示
关于"Android怎么实现左右滑动切换图片"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
图片
切换
网络
手指
方法
知识
内容
坐标
工厂
行业
视图
监听
不同
实用
动作
实用性
实际
效果
文件
文件夹
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
nb无线网络技术
宝塔建的数据库访问不
gridview 数据库
软件开发学什么语言好
服务器地址ping不通
海信网络技术工作
服务器按用途划分为哪些种类
广东企业党建软件开发
网络安全管理保障
重庆市舰拓网络技术有限公司
软件开发的课程都有哪些
网络安全的隶书字
网络安全管理要考体能
如何把连接数据库
联合投资软件开发协议
放服务器的机柜
想学习网络技术加盟联系方式
湖北潮流软件开发价格有哪些
岳阳市公安局网络安全保卫支队
下一代届数据库技术
阜阳手机软件开发需要多少钱
不使用数据库的登录界面
长沙软件开发公司排行
北京梦之网络技术有限公司
重庆安卓软件开发费用
朴妙软件开发
宝山区营销软件开发价格优惠
零基础怎么自学数学软件开发
数据库怎样进行选择存储
深空之眼选哪个服务器