Android - 开发实例(10):让控件变得可拖拽

本文介绍如何在Android中使控件变得可拖拽,通过封装View的onDragEvent()、dispatchDragEvent()和setOnDragListener(),类似于处理触摸事件。启动拖拽操作需使用startDrag()方法,并传入ClipData、DragShadowBuilder对象等参数。DragShadowBuilder用于创建拖拽过程中的阴影效果。详细步骤及官方文档链接可供参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

其实要实现拖拽的控件是非常简单的事情,和让控件支持点击一样简单!我们只需要对View类的

onDragEvent()

dispatchDragEvent()

setOnDragListener()

进行封装就行了,是不是和触摸事件的回调差不多呢?

onTouchEvent()

dispatchTouchEvent()

setOnTouchListener()

所以其用法和处理触摸事件也差不多,可以传入监听器,也可以扩展View类重写事件函数。


我们可以通过View.startDarg(ClipData data, DragShadowBuilder shadowBuilder, Object myLocalState, int flags)来开始拖拽。

这里需要我们传入一个DragShadowBuilder对象,DragShadow就是拖拽阴影,会在你拖动的时候显示出来,

所以DragShadowBuilder有一个传View的构造函数-new DragShadowBuilder(View)。


MainActivity.java

package cn.gavinliu.drag;

import android.app.Activity;
import android.content.ClipData;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.view.DragEvent;
import android.view.View;
import android.view.View.DragShadowBuilder;
import android.view.View.OnDragListener;
import android.view.View.OnLongClickListener;
import android.widget.ImageView;

public class MainActivity extends Activity {

	private String TAG = "DragDemo";

	private ImageView image;
	private ImageView image2;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		image = (ImageView) findViewById(R.id.image);
		image2 = (ImageView) findViewById(R.id.image2);

		image.setOnLongClickListener(new OnLongClickListener() {

			@Override
			public boolean onLongClick(View v) {
				// 创建DragShadowBuilder,我把控件本身传进去
				DragShadowBuilder builder = new DragShadowBuilder(v);
				// 剪切板数据,可以在DragEvent.ACTION_DROP方法的时候获取。
				ClipData data = ClipData.newPlainText("dot", "Dot : " + v.toString());
				// 开始拖拽
				v.startDrag(data, builder, v, 0);
				return true;
			}
		});

		image.setOnDragListener(new OnDragListener() {

			@Override
			public boolean onDrag(View v, DragEvent event) {
				final int action = event.getAction();
				switch (action) {
				// 开始拖拽
				case DragEvent.ACTION_DRAG_STARTED:
					image.setVisibility(View.INVISIBLE);
					Log.d(TAG, "image1 ACTION_DRAG_STARTED");
					break;
				// 结束拖拽
				case DragEvent.ACTION_DRAG_ENDED:
					image.setVisibility(View.VISIBLE);
					Log.d(TAG, "image1 ACTION_DRAG_ENDED");
					break;
				// 拖拽进某个控件后,退出
				case DragEvent.ACTION_DRAG_EXITED:
					Log.d(TAG, "image1 ACTION_DRAG_EXITED");
					break;
				// 拖拽进某个控件后,保持
				case DragEvent.ACTION_DRAG_LOCATION:
					Log.d(TAG, "image1 ACTION_DRAG_LOCATION");
					break;
				// 推拽进入某个控件
				case DragEvent.ACTION_DRAG_ENTERED:
					Log.d(TAG, "image1 ACTION_DRAG_ENTERED");
					break;
				// 推拽进入某个控件,后在该控件内,释放。即把推拽控件放入另一个控件
				case DragEvent.ACTION_DROP:
					Log.d(TAG, "image1 ACTION_DROP");
					break;
				}
				return true;
			}
		});

		image2.setOnDragListener(new OnDragListener() {

			@Override
			public boolean onDrag(View v, DragEvent event) {
				final int action = event.getAction();
				switch (action) {
				case DragEvent.ACTION_DRAG_STARTED:
					Log.d(TAG, "image2 ACTION_DRAG_STARTED");
					break;
				case DragEvent.ACTION_DRAG_ENDED:
					image2.setBackgroundColor(Color.TRANSPARENT);
					Log.d(TAG, "image2 ACTION_DRAG_ENDED");
					break;
				case DragEvent.ACTION_DRAG_EXITED:
					image2.setBackgroundColor(Color.TRANSPARENT);
					Log.d(TAG, "image2 ACTION_DRAG_EXITED");
					break;
				case DragEvent.ACTION_DRAG_ENTERED:
					image2.setBackgroundColor(Color.BLUE);
					Log.d(TAG, "image2 ACTION_DRAG_ENTERED");
					break;
				case DragEvent.ACTION_DRAG_LOCATION:
					Log.d(TAG, "image2 ACTION_DRAG_LOCATION");
				case DragEvent.ACTION_DROP:
					Log.d(TAG, "image2 ACTION_DROP");
				}
				return true;
			}
		});
	}

}
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <ImageView
        android:id="@+id/image"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:src="@drawable/ic_launcher" />

    <ImageView
        android:id="@+id/image2"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_alignParentRight="true"
        android:layout_below="@id/image"
        android:src="@drawable/ic_launcher" />

</RelativeLayout>

详细描述请参见官方文档:http://developer.android.com/guide/topics/ui/drag-drop.html


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值