安卓自定义视图-实现图片堆叠效果
作者:访客发布时间:2023-10-26分类:程序开发学习浏览:132
导读:一、简介最近产品要实现一个UI类似于相册堆叠那种,一看就知道是相册,并且可以点进去查看图片,然后就用自定义视图的形式实现了下,效果图如下:二、原理其实它的原理也很简单,对照着下图来...
一、简介
最近产品要实现一个UI类似于相册堆叠那种,一看就知道是相册,并且可以点进去查看图片,然后就用自定义视图的形式实现了下,效果图如下:
二、原理
其实它的原理也很简单,对照着下图来看:
- 要实现堆叠的效果,我们需要先将视图的宽高获取到,如图最外边的矩形
- 然后根据最外边的矩形去将位图进行缩放
- 根据自己定义的偏移值,先画第三个图(红色),画到查看视图的右边,然后画中间,最后才画第一个位图
三、代码
class StackingView @JvmOverloads constructor(
private val context: Context,
attrs: AttributeSet? = null,
defStyleAttr: Int = 0
) :
View(context, attrs, defStyleAttr) {
private val bitmapList = mutableListOf<Bitmap>()
//间距大小
private val padding = 120
init {
this.post {
val photo01 = BitmapFactory.decodeResource(context.resources, R.mipmap.photo_01)
val photo02 = BitmapFactory.decodeResource(context.resources, R.mipmap.photo_02)
val photo03 = BitmapFactory.decodeResource(context.resources, R.mipmap.photo_03)
//将Bitmap缩放统一大小
val reSizeWidth = width-padding
val reSizeHeight = height-padding
val scale01 = photo01.scale(reSizeWidth, reSizeHeight, true)
val scale02 = photo02.scale(reSizeWidth, reSizeHeight, true)
val scale03 = photo03.scale(reSizeWidth, reSizeHeight, true)
bitmapList.add(scale01)
bitmapList.add(scale02)
bitmapList.add(scale03)
invalidate()
}
}
override fun onDraw(canvas: Canvas?) {
super.onDraw(canvas)
val offset = padding/2f
if (bitmapList.isNotEmpty()) {
//这里倒序绘制
for (i in 2 downTo 0) {
canvas?.drawBitmap(bitmapList[i], offset*i, -offset*(i-2),null)
}
}
}
}
代码也很简单,这里就不多说了,总体来说这个功能还是很好实现的
- 程序开发学习排行
-
- 1鸿蒙HarmonyOS:Web组件网页白屏检测
- 2HTTPS协议是安全传输,为啥还要再加密?
- 3HarmonyOS鸿蒙应用开发——数据持久化Preferences
- 4记解决MaterialButton背景颜色与设置值不同
- 5鸿蒙HarmonyOS实战-ArkUI组件(RelativeContainer)
- 6鸿蒙HarmonyOS实战-ArkUI组件(Stack)
- 7[Android][NDK][Cmake]一文搞懂Android项目中的Cmake
- 8Android广播如何解决Sending non-protected broadcast问题
- 9鸿蒙HarmonyOS实战-ArkUI组件(mediaquery)
- 最近发表
-
- WooCommerce最好的WordPress常用插件下载博客插件模块的相关产品
- 羊驼机器人最好的WordPress常用插件下载博客插件模块
- IP信息记录器最好的WordPress常用插件下载博客插件模块
- Linkly for WooCommerce最好的WordPress常用插件下载博客插件模块
- 元素聚合器Forms最好的WordPress常用插件下载博客插件模块
- Promaker Chat 最好的WordPress通用插件下载 博客插件模块
- 自动更新发布日期最好的WordPress常用插件下载博客插件模块
- WordPress官方最好的获取回复WordPress常用插件下载博客插件模块
- Img to rss最好的wordpress常用插件下载博客插件模块
- WPMozo为Elementor最好的WordPress常用插件下载博客插件模块添加精简版