Android怎么实现左右滑动切换图片
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍"Android怎么实现左右滑动切换图片"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Android怎么实现左右滑动切换图片"文章能帮助大家解
千家信息网最后更新 2025年11月07日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安全错误
数据库的锁怎样保障安全
php获取淘宝客数据库
佛山智能产品软件开发
广州辛格吧互联网科技有限公司
湖南计算机网络技术专科学校
建筑项目数据库技术
骑马与砍杀最强的服务器
软件开发需要在家学吗
江西一站式软件开发服务价格
软件开发规范认证
数据库访问技术jdbc
警校的网络安全与执法就业方向
北京 软件开发培训机构
软件开发甘特图案例
网络安全攻击电影
公安部网络安全监察网举报
现代战争5服务器超载怎么回事
长春定制化国产服务器
access数据库找回密码
俄服失落的方舟无法连接服务器
服务器安全分析报告
消防软件开发计划书范例
广州华锐互联网科技有限公司
网盘共享软件开发
计算机软件开发和维护
全国网络安全信息峰会
家用二手服务器搭建
软件开发 小程序开发
数据库怎么看是否可为空
数码宝贝资料数据库
嘻嘻网络技术服务