Android自定义View-实现图片堆叠效果

一、简介

最近产品要实现一个UI类似于相册堆叠那种,一看就知道是相册,并且可以点进去查看图片,然后就用自定义View的形式实现了下,效果图如下:

二、原理

其实它的原理也很简单,对照着下图来看:

  1. 要实现堆叠的效果,我们需要先将View的宽高获取到,如图最外边的矩形
  2. 然后根据最外边的矩形去将Bitmap进行缩放
  3. 根据自己定义的偏移值,先画第三个图(红色),画到View视图的右边,然后画中间,最后才画第一个Bitmap

三、代码

kotlin 复制代码
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)
            }
        }
    }

}

代码也很简单,这里就不多说了,总体来说这个功能还是很好实现的

相关推荐
TDengine (老段)19 小时前
TDengine 字符串函数 CONCAT_WS 用户手册
android·大数据·数据库·时序数据库·tdengine·涛思数据
会跑的兔子20 小时前
Android 16 Kotlin协程 第一部分
android·开发语言·kotlin
Meteors.21 小时前
安卓进阶——OpenGL ES
android
椰羊sqrt1 天前
CVE-2025-4334 深度分析:WordPress wp-registration 插件权限提升漏洞
android·开发语言·okhttp·网络安全
2501_916008891 天前
金融类 App 加密加固方法,多工具组合的工程化实践(金融级别/IPA 加固/无源码落地/Ipa Guard + 流水线)
android·ios·金融·小程序·uni-app·iphone·webview
sun0077001 天前
Android设备推送traceroute命令
android
来来走走1 天前
Android开发(Kotlin) 高阶函数、内联函数
android·开发语言·kotlin
2501_915921431 天前
Fastlane 结合 开心上架(Appuploader)命令行版本实现跨平台上传发布 iOS App 免 Mac 自动化上架实战全解析
android·macos·ios·小程序·uni-app·自动化·iphone
雨白1 天前
重识 Java IO、NIO 与 OkIO
android·java
啦啦9117141 天前
Niagara Launcher 全新Android桌面启动器!给手机换个门面!
android·智能手机