Drag---长按控件进行拖动

原创 2016年06月02日 12:33:20

运行效果图:




自定义的控件,新建一个被拖动View控件,Dragging.java:

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;

//自定义的View类型的子类,作为被拖动View
public class Dragging <strong>extends View</strong> {
	//View的构造方法
	public Dragging(Context context) {
		super(context);
	}
	//带参的构造方法
	public Dragging(Context context, AttributeSet attrs) {
		super(context, attrs);
	}
	
}

自定义控件,新建一个拖动完放置的View控件,pass.java:



package com.bzu.test064view;

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
//自定义存放拖动的View
public class Pass <strong>extends View</strong> {

	public Pass(Context context) {
		super(context);
	}

	public Pass(Context context, AttributeSet attrs) {
		super(context, attrs);
	}

}


修改activity_main.xml文件,如下:


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center"
        android:text="拖动效果的展示" />
<!-- 放置拖动对象 -->
    <com.bzu.test064view.Dragging 
        android:id="@+id/ViewD"
        android:layout_width="50dip"
        android:layout_height="50dip"
        android:background="@color/bule"/>
<!-- 定义空白区域 -->
	<TextView 
	    android:layout_width="50dip"
	    android:layout_height="50dip"/>
<!-- 放置安放拖动对象 -->
    <com.bzu.test064view.Pass 
        android:id="@+id/ViewP"
        android:layout_width="50dip"
        android:layout_height="50dip"
        android:background="@color/black"/>
    
</LinearLayout>



修改MainActivity.java文件,如下:



import android.os.Bundle;
import android.app.Activity;
import android.graphics.drawable.Drawable;
import android.util.Log;
import android.view.DragEvent;
import android.view.Menu;
import android.view.View;
import android.view.View.DragShadowBuilder;
import android.view.View.OnDragListener;
import android.view.View.OnLongClickListener;

public class MainActivity extends Activity {
	private View ViewD;
	private View ViewP;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		findById();
		setListener();
	}
	
	private void setListener() {
		//设置监听器,长按后拖动
		ViewD.setOnLongClickListener(new OnLongClickListener() {
			@Override
			public boolean onLongClick(View view) {
				ViewD.startDrag(null, new DragShadowBuilder(view), view, 0);
				return true;
			}
		});
		//开始拖动时回调的函数,setOnDragListener
		ViewP.setOnDragListener(new OnDragListener() {
			@Override
			public boolean onDrag(View mDropview, DragEvent event) {
				boolean result=false;
				switch (event.getAction()) {
				//开始拖动时
				case DragEvent.ACTION_DRAG_STARTED:{
					Log.e("Dragging", "View开始被拖动");
					result=true;
					break;
				}
				//被拖动的额对象进入当前view对象时
				case DragEvent.ACTION_DRAG_ENTERED:{
					Log.e("Dragging", "被拖动的View对象进入当前的View");
					break;
				}
				//被拖动的View进入当前的View后,位置改变时回调
				case DragEvent.ACTION_DRAG_LOCATION:{
					Log.e("Dragging", "被拖动的view进入当前view");
					break;
				}
				//拖动的View被放入当前的View时回调
				case DragEvent.ACTION_DROP:{
					Log.e("Dragging", "拖动的View被放入当前View");
					View mDragView=(View) event.getLocalState();
					//得到拖动视图的背景
					Drawable mDragViewBackGround=mDragView.getBackground();
					mDragView.setBackgroundDrawable(mDropview.getBackground());
					mDropview.setBackgroundDrawable(mDragViewBackGround);
					break;
				}
				//拖动结束时
				case DragEvent.ACTION_DRAG_ENDED:{
					Log.e("Dragging", "View拖动结束");
					break;
				}
				//拖动完成时
				case DragEvent.ACTION_DRAG_EXITED:{
					Log.e("Dragging", "View拖动退出");
					break;
				}
				default :{
					break;
				}
				}
				return result;
			}
		});
	}

	private void findById() {
		ViewD=findViewById(R.id.ViewD);
		ViewP=findViewById(R.id.ViewP);
	}
}






版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

#715 – 在Canvas中使用Thumb控件实现拖动目标的功能(Using the Thumb Control to Drag Objects on a Canvas)

原文地址:https://wpf.2000things.com/2012/12/19/715-using-the-thumb-control-to-drag-objects-on-a-canvas/ ...

自定义Imageview控件实现多种手势操作 (拖动、水平缩放、竖直缩放、等比例缩放、双击、长按)

该自定义控件实现的主要功能是控件的拖动和缩放(注意:不是对控件中的图片进行操作,话说很多帖子都把这两个混了),其中缩放可以按照三个方向进行,就是水平、竖直和等比例。双击操作只做了一个提示,长按加上了一...

加载商品图片控件、长按可拖动、右上角删除按钮

展示图片控件、长按可拖动、右上角删除按钮、可控制行数及一行的个数

让你的控件也具有拖拽(drag-and-drop)功能

让你的控件也具有拖拽(drag-and-drop)功能现在有很多软件都支持拖拽功能,就是用鼠标拖着文件放到软件窗口中某个位置,软件就可以做出相应的反应。比如,Windows自带的播放软件Windows...

常用drag控件

常用drag控件

pb控件强化:一个在drag时可以自动上下滚动的treeview控件对象

在实际使用过程中,当treeview控件允许拖动drag时,由于treeview控件在expand后,高度都会比较高,以至于数据在控件内,无法完全显示,而在drag过程中,经常需要执行大幅度的拖动,这...

drag拖动插件

内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)