Android可拖拽排序的多图上传组件UploadMultiImageView

UploadMultiImageView 多图上传组件

项目中经常会有多图上传的需求,每次都重复写,实在不是一个好办法。于是基于 【recycleview】 来实现一个仅仅需要 【十几行代码】 就可拥有拖拽排序功能的多图上传组件。

目前使用的AndroidX,不是的同学,请尽快升级吧!

先看效果

效果图

UploadMultiImageView源码传送门

使用说明

1、在根目录 build.gradle 添加:

allprojects {
		repositories {
			...
			maven { url 'https://jitpack.io' }
		}
	}

2、在module项目下的build.gradle中添加:

dependencies {
	        implementation 'com.gitee.mtj_java:UploadMultiImageView:1.0.0'
	}

3、在布局xml中添加组件

<cn.mtjsoft.multiimagelibrary.UploadMultiImageView
        android:id="@+id/uploadMultiImageView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#fff"
        app:addRes="@drawable/img_add"
        app:deleteRes="@drawable/img_delete"
        app:column_count="3"
        app:is_Drag="true"
        app:is_showAdd="true"
        app:item_spacing="2dp"
        app:max_count="9" />

版本及自定义属性说明

V1.0.0

1.0.0 属性属性说明
img_height图片高度(dp)默认与宽度相等
item_spacing图片之间的间隔(dp)默认2dp
column_count列数 默认每行3列
max_count最多显示张数 默认 Integer.MAX_VALUE
is_showDelete是否显示删除按钮 默认true
is_showAdd是否显示添加按钮 默认false
deleteRes设置删除按钮
deleteWH删除按钮的宽高(dp)默认25dp
deleteResMargin删除按钮的边距(dp)默认6dp
addRes设置添加按钮
is_Drag是否开启拖拽排序 默认false

代码实现(这里用kotlin写的)

1、Activity

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        // 循环添加几条数据
        val list: MutableList<ImageModel> = ArrayList()
        for (i in 0..7) {
            val model = ImageModel()
            model.path = R.mipmap.android
            list.add(model)
        }
        
        /**
        * 核心实现在这里,是不是只有仅仅十几行代码?
        */
        uploadMultiImageView
            .setImageInfoList(list.toList())
            // 所有属性都可以在代码中再设置
            // 开启拖拽排序
            .setDrag(true)
            // 设置每行3列
            .setColumns(3)
            // 显示新增按钮
            .setShowAdd(true)
            // item点击回调
            .setImageItemClickListener { position ->
                // imageview点击
                Toast.makeText(baseContext, "点击第了${position}个", Toast.LENGTH_SHORT).show()
            }
            // 图片加载
            .setImageViewLoader { context, path, imageView ->
                // 图片加载(这里自己选择图片加载框架,不做限制)
                imageView.setImageResource(path as Int)
            }
            // 新增按钮点击回调
            .setAddClickListener {
                // 模拟新增一条数据
                addNewData()
            }
            .show()
    }

    /**
     * 新增一条或多条数据
     */
    private fun addNewData() {
        val tempList: MutableList<ImageModel> = ArrayList()
        val model = ImageModel()
        model.path = R.mipmap.android
        tempList.add(model)
        // 调用新增数据
        uploadMultiImageView.addNewData(tempList.toList())
    }
}

2、数据实体类 实现 ImageInfo

/**
 * 实现 ImageInfo
 */
public class ImageModel implements ImageInfo {

    private Object path;

    public Object getPath() {
        return path;
    }

    public void setPath(Object path) {
        this.path = path;
    }

    /**
     * @return 图片地址
     */
    @Override
    public Object getImagePath() {
        return path;
    }

    /**
     * @return 固定返回 false
     */
    @Override
    public boolean isLastAddViewData() {
        return false;
    }
}

完结

怎么样?是不是十分的简洁,核心实现是不是只有仅仅十几行代码?

本人公众号,关注一波,共同交流吧。
在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
您好,针对您的问题,我理解您想实现在 Android 应用中,用户可以通过长按某个元素并动,实现多张片的放。我可以为您提供以下思路和代码示例: 首先,您需要为每一张片设置一个触摸事件,以便用户可以通过长按并片。例如,在您的布局文件中,可以为每个片添加如下代码: ```xml <ImageView android:id="@+id/image1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/image1" android:tag="draggable" android:longClickable="true" android:onLongClick="onLongClickImage" /> ``` 其中,`android:tag="draggable"` 表示该元素可以被,`android:longClickable="true"` 表示该元素可以被长按,`android:onLongClick="onLongClickImage"` 表示当用户长按该元素时,会调用 `onLongClickImage` 方法。 接下来,您需要实现 `onLongClickImage` 方法,以便能够在用户长按片时启动事件。例如,可以使用 `View.OnLongClickListener` 接口来实现该方法: ```java public class MainActivity extends AppCompatActivity implements View.OnLongClickListener { private ImageView mSelectedImage; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 为每个片添加长按事件 findViewById(R.id.image1).setOnLongClickListener(this); findViewById(R.id.image2).setOnLongClickListener(this); findViewById(R.id.image3).setOnLongClickListener(this); } @Override public boolean onLongClick(View v) { // 记录选中的片 mSelectedImage = (ImageView) v; // 启动事件 View.DragShadowBuilder shadowBuilder = new View.DragShadowBuilder(v); v.startDragAndDrop(null, shadowBuilder, null, 0); return true; } } ``` 在这个例子中,当用户长按某个片时,会记录选中的片并启动事件。事件使用 `View.startDragAndDrop` 方法来启动,并使用 `View.DragShadowBuilder` 创建一个的阴影。 最后,您需要实现 `View.OnDragListener` 接口来处理事件。例如,可以使用以下代码来实现: ```java public class MainActivity extends AppCompatActivity implements View.OnLongClickListener, View.OnDragListener { private ImageView mSelectedImage; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 为每个片添加长按事件 findViewById(R.id.image1).setOnLongClickListener(this); findViewById(R.id.image2).setOnLongClickListener(this); findViewById(R.id.image3).setOnLongClickListener(this); // 设置事件 findViewById(R.id.container).setOnDragListener(this); } @Override public boolean onLongClick(View v) { // 记录选中的片 mSelectedImage = (ImageView) v; // 启动事件 View.DragShadowBuilder shadowBuilder = new View.DragShadowBuilder(v); v.startDragAndDrop(null, shadowBuilder, null, 0); return true; } @Override public boolean onDrag(View v, DragEvent event) { switch (event.getAction()) { case DragEvent.ACTION_DRAG_STARTED: // 事件开始,返回 true 表示可以接收事件 return true; case DragEvent.ACTION_DRAG_ENTERED: // 事件进入容器,改变容器的背景色 v.setBackgroundColor(Color.YELLOW); break; case DragEvent.ACTION_DRAG_EXITED: // 事件离开容器,恢复容器的背景色 v.setBackgroundColor(Color.TRANSPARENT); break; case DragEvent.ACTION_DROP: // 事件释放,将片从原位置移动到容器中 ViewGroup viewGroup = (ViewGroup) mSelectedImage.getParent(); viewGroup.removeView(mSelectedImage); ((ViewGroup) v).addView(mSelectedImage); break; case DragEvent.ACTION_DRAG_ENDED: // 事件结束,恢复容器的背景色 v.setBackgroundColor(Color.TRANSPARENT); break; } return true; } } ``` 在这个例子中,当用户将到容器中时,会将片从原位置移动到容器中。您可以根据需要修改代码,实现更复杂的放功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

帅气的铅笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值